我已经绘制了一张地图google_maps_flutter
,上面有 2 个标记。我想在它们之间画一条路线。有谁能够帮我?
当我使用@CopsOnRoad建议的那个时,我会显示图片。我希望这条路线是蓝线,这是最好的前进方式。
我已经绘制了一张地图google_maps_flutter
,上面有 2 个标记。我想在它们之间画一条路线。有谁能够帮我?
当我使用@CopsOnRoad建议的那个时,我会显示图片。我希望这条路线是蓝线,这是最好的前进方式。
由于您尚未共享任何代码,因此我将从这里举一个示例
将此添加到您的StatefulWidget
子类中。
Map<PolylineId, Polyline> _mapPolylines = {};
int _polylineIdCounter = 1;
void _add() {
final String polylineIdVal = 'polyline_id_$_polylineIdCounter';
_polylineIdCounter++;
final PolylineId polylineId = PolylineId(polylineIdVal);
final Polyline polyline = Polyline(
polylineId: polylineId,
consumeTapEvents: true,
color: Colors.red,
width: 5,
points: _createPoints(),
);
setState(() {
_mapPolylines[polylineId] = polyline;
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text("Maps"),
actions: <Widget>[IconButton(icon: Icon(Icons.add), onPressed: _add)],
),
body: GoogleMap(
initialCameraPosition: const CameraPosition(target: LatLng(0, 0), zoom: 4.0),
polylines: Set<Polyline>.of(_mapPolylines.values),
),
);
}
List<LatLng> _createPoints() {
final List<LatLng> points = <LatLng>[];
points.add(LatLng(1.875249, 0.845140));
points.add(LatLng(4.851221, 1.715736));
points.add(LatLng(8.196142, 2.094979));
points.add(LatLng(12.196142, 3.094979));
points.add(LatLng(16.196142, 4.094979));
points.add(LatLng(20.196142, 5.094979));
return points;
}
很高兴有一条你想要的路线,它必须有几个点和有效的街道,这在你的情况下非常重要。我建议你为现有的服务付费,比如谷歌方向。您可以通过谷歌方向获取坐标和街道名称。
API(谷歌方向)
https://maps.googleapis.com/maps/api/directions/json?origin=LAT,LON&destination=LAT,LON&key=API_KEY
示例 绘制路线(谷歌方向)
https://github.com/DeveloperLibs/flutter_google_map_route/blob/master/lib/map_screen.dart