Flutter地图展示与交互插件syncfusion_flutter_maps的使用

发布于 1周前 作者 itying888 来自 Flutter

Flutter地图展示与交互插件syncfusion_flutter_maps的使用

Flutter Maps library

Syncfusion Flutter Maps package 是一个数据可视化库,用于从shape文件或WMTS服务创建美观、交互性强且可定制的地图,以可视化地理区域。

Disclaimer: 这是一个商业包。要使用此包,您需要拥有 Syncfusion® 商业许可证或 Free Syncfusion® Community许可证。更多详情,请查看LICENSE文件。

功能概述

Shape Layer 特性

  • Bubbles - 为形状添加信息,如人口密度和用户数量。
  • Markers - 使用内置符号或自定义小部件在特定经纬度上标记位置。
  • Marker alignment - 标记可以基于其坐标点对齐到各种位置。
  • Shape selection - 选择形状以突出显示地图上的某个区域。
  • Legend - 提供关于地图上绘制数据的清晰信息。
  • Colors - 根据底层值自定义形状颜色。
  • Tooltip - 使用可自定义的工具提示显示有关形状、气泡和标记的附加信息。
  • Shape sublayer - 添加带有GeoJSON数据的形状子层以显示有关特定区域的更多详细信息。
  • Vector layer - 在形状层中添加多边形、线、圆等矢量图形。
  • Zooming and panning - 支持缩放和平移操作来查看特定区域。
  • Inverted circleInverted polygon - 支持倒置圆形和多边形的颜色填充。

Tile Layer 特性

  • Markers - 显示特定纬度和经度的标记。
  • Shape sublayer - 添加带有GeoJSON数据的形状子层。
  • Vector layer - 添加多边形、线、圆等矢量图形。
  • Zooming and panning - 支持缩放和平移操作来查看特定区域。
  • Custom bounds - 指定可视范围以查看特定区域。

安装

pub.dev 安装最新版本。

import 'package:syncfusion_flutter_maps/maps.dart';

示例代码

创建地图

import 'package:flutter/material.dart';
import 'package:syncfusion_flutter_maps/maps.dart';

void main() {
  return runApp(const MapsApp());
}

/// This widget will be the root of application.
class MapsApp extends StatelessWidget {
  const MapsApp({super.key});

  @override
  Widget build(BuildContext context) {
    return const MaterialApp(
      title: 'Maps Demo',
      home: MyHomePage(),
    );
  }
}

/// This widget is the home page of the application.
class MyHomePage extends StatefulWidget {
  /// Initialize the instance of the [MyHomePage] class.
  const MyHomePage({Key? key}) : super(key: key);

  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  late List<Model> _data;
  late MapShapeSource _mapSource;

  @override
  void initState() {
    _data = const <Model>[
      Model('New South Wales', Color.fromRGBO(255, 215, 0, 1.0), '       New\nSouth Wales'),
      Model('Queensland', Color.fromRGBO(72, 209, 204, 1.0), 'Queensland'),
      Model('Northern Territory', Color.fromRGBO(255, 78, 66, 1.0), 'Northern\nTerritory'),
      Model('Victoria', Color.fromRGBO(171, 56, 224, 0.75), 'Victoria'),
      Model('South Australia', Color.fromRGBO(126, 247, 74, 0.75), 'South Australia'),
      Model('Western Australia', Color.fromRGBO(79, 60, 201, 0.7), 'Western Australia'),
      Model('Tasmania', Color.fromRGBO(99, 164, 230, 1), 'Tasmania'),
      Model('Australian Capital Territory', Colors.teal, 'ACT')
    ];

    _mapSource = MapShapeSource.asset(
      'assets/australia.json',
      shapeDataField: 'STATE_NAME',
      dataCount: _data.length,
      primaryValueMapper: (int index) => _data[index].state,
      dataLabelMapper: (int index) => _data[index].stateCode,
      shapeColorValueMapper: (int index) => _data[index].color,
    );
    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: SizedBox(
        height: 520,
        child: Center(
          child: SfMaps(
            layers: <MapShapeLayer>[
              MapShapeLayer(
                source: _mapSource,
                showDataLabels: true,
                legend: const MapLegend(MapElement.shape),
                tooltipSettings: MapTooltipSettings(
                    color: Colors.grey[700],
                    strokeColor: Colors.white,
                    strokeWidth: 2),
                strokeColor: Colors.white,
                strokeWidth: 0.5,
                shapeTooltipBuilder: (BuildContext context, int index) {
                  return Padding(
                    padding: const EdgeInsets.all(8.0),
                    child: Text(
                      _data[index].stateCode,
                      style: const TextStyle(color: Colors.white),
                    ),
                  );
                },
                dataLabelSettings: MapDataLabelSettings(
                  textStyle: TextStyle(
                      color: Colors.black,
                      fontWeight: FontWeight.bold,
                      fontSize: Theme.of(context).textTheme.bodySmall!.fontSize),
                ),
              ),
            ],
          ),
        ),
      ),
    );
  }
}

/// Collection of Australia state code data.
class Model {
  const Model(this.state, this.color, this.stateCode);

  final String state;
  final Color color;
  final String stateCode;
}

关于 Syncfusion®

Syncfusion 成立于2001年,总部位于北卡罗来纳州的研究三角园区。我们有超过20,000个客户和超过1百万用户,包括大型金融机构、财富500强公司和全球IT咨询公司。今天,我们提供1000多个控件和框架,适用于Web、移动和桌面开发,并提供企业级软件解决方案。


更多关于Flutter地图展示与交互插件syncfusion_flutter_maps的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter地图展示与交互插件syncfusion_flutter_maps的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


当然,以下是一个关于如何在Flutter中使用syncfusion_flutter_maps插件来展示和交互地图的代码示例。这个示例将展示如何加载一个基本的地图,并在地图上添加一些交互功能,比如点击事件。

首先,确保你已经在pubspec.yaml文件中添加了syncfusion_flutter_maps依赖:

dependencies:
  flutter:
    sdk: flutter
  syncfusion_flutter_maps: ^x.y.z  # 请替换为最新版本号

然后,运行flutter pub get来安装依赖。

接下来是完整的Flutter应用代码示例:

import 'package:flutter/material.dart';
import 'package:syncfusion_flutter_maps/maps.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Syncfusion Flutter Maps Example',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MapScreen(),
    );
  }
}

class MapScreen extends StatefulWidget {
  @override
  _MapScreenState createState() => _MapScreenState();
}

class _MapScreenState extends State<MapScreen> {
  // 地图点击事件处理函数
  void onMapTap(MapsTapEventArgs args) {
    final position = args.position;
    print("Tapped at: Latitude: ${position.latitude}, Longitude: ${position.longitude}");
    // 可以在这里添加更多逻辑,比如显示一个Snackbar或Dialog
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Syncfusion Flutter Maps'),
      ),
      body: SfMaps(
        layers: [
          // 添加一个基础地图图层
          TileLayer(
            urlTemplate: "https://{subDomain}.tile.openstreetmap.org/{zoom}/{x}/{y}.png",
            subDomains: ['a', 'b', 'c'],
          ),
          // 添加一个标记图层(可选)
          MarkerLayer(
            markers: [
              Marker(
                latitude: 37.7749,
                longitude: -122.4194,
                child: Container(
                  width: 20,
                  height: 20,
                  decoration: BoxDecoration(
                    shape: BoxShape.circle,
                    color: Colors.red,
                  ),
                ),
              ),
            ],
          ),
        ],
        // 地图点击事件监听
        onTap: onMapTap,
        // 地图初始化中心点
        initialCameraPosition: CameraPosition(
          target: LatLng(37.7749, -122.4194), // 旧金山
          zoom: 12.0,
        ),
      ),
    );
  }
}

代码解释:

  1. 依赖导入

    • 导入flutter/material.dart用于构建UI。
    • 导入syncfusion_flutter_maps/maps.dart用于地图功能。
  2. 应用入口

    • MyApp是一个无状态组件,它定义了应用的主题和主页。
  3. 地图页面

    • MapScreen是一个有状态组件,用于管理地图的状态。
    • onMapTap函数处理地图点击事件,并打印点击位置的经纬度。
  4. 地图构建

    • SfMaps组件用于显示地图。
    • TileLayer用于加载OpenStreetMap的基础地图图层。
    • MarkerLayer用于在地图上添加标记(可选)。
    • onTap属性用于监听地图点击事件。
    • initialCameraPosition属性设置地图的初始视角。

这个示例展示了如何使用syncfusion_flutter_maps插件在Flutter应用中展示和交互地图。你可以根据需要进一步自定义和扩展这个示例。

回到顶部