mappls_gl 1.1.2 mappls_gl: ^1.1.2 copied to clipboard
A Flutter plugin for integrating MapmyIndia Maps inside a Flutter application on Android, iOS and web platfroms.
import 'dart:convert';
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:location/location.dart';
import 'package:mappls_gl_example/model/feature_list.dart';
import 'package:mappls_gl_example/samples/add_mappls_pin_marker.dart';
import 'package:mappls_gl_example/samples/add_marker.dart';
import 'package:mappls_gl_example/samples/add_multiple_marker.dart';
import 'package:mappls_gl_example/samples/add_polygon_widget.dart';
import 'package:mappls_gl_example/samples/add_polyline_wdget.dart';
import 'package:mappls_gl_example/samples/autosuggest_widget.dart';
import 'package:mappls_gl_example/samples/camera_mappls_pin_feature.dart';
import 'package:mappls_gl_example/samples/camera_feature.dart';
import 'package:mappls_gl_example/samples/current_location_widget.dart';
import 'package:mappls_gl_example/samples/direction_widget.dart';
import 'package:mappls_gl_example/samples/geoanalytics_widget.dart';
import 'package:mappls_gl_example/samples/geocode_widget.dart';
import 'package:mappls_gl_example/samples/gradient_polyline_widget.dart';
import 'package:mappls_gl_example/samples/hateos_nearby_widget.dart';
import 'package:mappls_gl_example/samples/heatmap_widget.dart';
import 'package:mappls_gl_example/samples/indoor_widget.dart';
import 'package:mappls_gl_example/samples/location_camera_option.dart';
import 'package:mappls_gl_example/samples/map_click_event.dart';
import 'package:mappls_gl_example/samples/map_long_click.dart';
import 'package:mappls_gl_example/samples/marker_dragging_widget.dart';
import 'package:mappls_gl_example/samples/nearby_widget.dart';
import 'package:mappls_gl_example/samples/poi_along_route_widget.dart';
import 'package:mappls_gl_example/samples/reverse_geocode_widget.dart';
import 'package:mappls_gl_example/samples/style_widget.dart';
import 'package:mappls_gl_example/samples/tracking_widget.dart';
import 'package:mappls_gl_example/utils/color.dart';
import 'package:mappls_gl_example/utils/feature_type.dart';
import 'package:mappls_gl/mappls_gl.dart';
final List<FeatureList> animationFeatures = <FeatureList>[
FeatureList('Tracking sample', 'To track a vehicle on map', '/Tracking')
];
final List<FeatureList> mapEvents = <FeatureList>[
FeatureList(
'Map Tap', 'Click on map and get Latitude Longitude', '/MapClick'),
FeatureList('Map Long Click', 'Long press on map and get Latitude Longitude',
'/MapLongClick'),
FeatureList(
'Map Style', 'To change and update Mappls Styles', '/MapStyle'),
];
final List<FeatureList> layersFeatures = <FeatureList>[
FeatureList(
'Show Heatmap data', 'Add a heatmap to visualize data', '/HeatMapWidget'),
FeatureList(
'Indoor',
'Show indoor widget when focus on multi storey building',
'/IndoorWidget'),
FeatureList(
'Geoanalytics Plugin',
'To gets the layer specified which is stored in Mappls Database and gives a WMS layer as an output',
'/GeoAnalyticsPlugin'),
];
final List<FeatureList> cameraFeatures = <FeatureList>[
FeatureList('Camera Features', "Animate, Move or Ease Camera Position",
'/CameraFeature'),
FeatureList('Camera Features with mappls pin',
"Animate, Move or Ease Camera Position", '/CameraMapplsPinFeature'),
FeatureList("Location Camera Options", "Location camera and render mode",
'/LocationCameraOptions')
];
final List<FeatureList> markerFeatures = <FeatureList>[
FeatureList('Add Marker', 'Way to add Marker on Map', '/AddMarker'),
FeatureList('Add Multiple Marker', 'Way to add Marker on Map', '/AddMultipleMarker'),
FeatureList('Add Mappls Pin Marker', 'Way to add Marker on Map using Mappls Pin',
'/AddMapplsPinMarker'),
FeatureList('Marker Dragging', 'Way to add Marker on Map', '/MarkerDragging'),
];
final List<FeatureList> locationFeatures = <FeatureList>[
FeatureList(
'Current Location',
'Location camera options for render and tracking modes',
'/CurrentLocation')
];
final List<FeatureList> restApiFeatures = <FeatureList>[
FeatureList('Autosuggest', 'Auto suggest places on the map', '/AutoSuggest'),
FeatureList('Geocode', 'Geocode rest API call', '/Geocode'),
FeatureList(
'Reverse Geocode', 'Reverse Geocode rest API call', '/ReverseGeocode'),
FeatureList('Nearby', 'Show nearby results on the map', '/Nearby'),
FeatureList('Direction',
'Get directions between two points and show on the map', '/Direction'),
FeatureList(
'Hateos Nearby Api', 'Nearby places using hateos api', '/HateOsWidget'),
FeatureList(
'POI Along Route',
'User will be able to get the details of POIs of a particular category along his set route',
'/POIAlongRoute'),
];
final List<FeatureList> polylineFeatures = <FeatureList>[
FeatureList(
'Draw Polyline',
'Draw a polyline with given list of latitude and longitude',
'/AddPolyline'),
FeatureList(
'Polyline with Gradient color',
'Draw a polyline with given list of latitude and longitude',
'/GradientPolyline'),
FeatureList('Draw Polygon',
'Draw a polygon with given list of latitude and longitude', '/AddPolygon')
];
class MapsDemo extends StatefulWidget {
@override
State<StatefulWidget> createState() {
return MapDemoState();
}
}
void main() {
runApp(MaterialApp(
home: MapsDemo(),
routes: <String, WidgetBuilder>{
'/MapClick': (BuildContext context) => MapClickEvent(),
'/MapLongClick': (BuildContext context) => MapLongClick(),
'/CameraFeature': (BuildContext context) => CameraFeature(),
'/CameraMapplsPinFeature': (BuildContext context) => CameraMapplsPinFeature(),
'/LocationCameraOptions': (BuildContext context) =>
LocationCameraOption(),
'/AddMarker': (BuildContext context) => AddMarkerWidget(),
'/AddMultipleMarker': (BuildContext context) => AddMultipleMarker(),
'/AddMapplsPinMarker': (BuildContext context) => AddMapplsPinMarkerWidget(),
'/MarkerDragging': (BuildContext context) => MarkerDraggingWidget(),
'/CurrentLocation': (BuildContext context) => CurrentLocationWidget(),
'/AddPolyline': (BuildContext context) => AddPolylineWidget(),
'/AddPolygon': (BuildContext context) => AddPolygonWidget(),
'/AutoSuggest': (BuildContext context) => AutoSuggestWidget(),
'/Geocode': (BuildContext context) => GeocodeWidget(),
'/ReverseGeocode': (BuildContext context) => ReverseGeocodeWidget(),
'/Nearby': (BuildContext context) => NearbyWidget(),
'/Direction': (BuildContext context) => DirectionWidget(),
'/POIAlongRoute': (BuildContext context) => POIAlongRouteWidget(),
'/MapStyle': (BuildContext context) => StyleWidget(),
'/HeatMapWidget': (BuildContext context) => HeatMapWidget(),
'/GradientPolyline': (BuildContext context) => GradientPolylineWidget(),
'/IndoorWidget': (BuildContext context) => IndoorWidget(),
'/HateOsWidget': (BuildContext context) => HateOsNearbyWidget(),
'/GeoAnalyticsPlugin': (BuildContext context) => GeoAnalyticsWidget(),
'/Tracking': (BuildContext context) => TrackingWidget(),
},
));
}
class MapDemoState extends State {
static const String MAP_SDK_KEY = "";
static const String REST_API_KEY = "";
static const String ATLAS_CLIENT_ID = "";
static const String ATLAS_CLIENT_SECRET = "";
FeatureType? selectedFeatureType;
void setPermission() async {
PlaceDetailResponse? placeDetailResponse = await MapplsPlaceDetail(mapplsPin: "2VILU5").callPlaceDetail();
print(json.encode(placeDetailResponse));
if (!kIsWeb) {
final location = Location();
final hasPermissions = await location.hasPermission();
if (hasPermissions != PermissionStatus.granted) {
await location.requestPermission();
}
}
}
@override
void initState() {
super.initState();
MapplsAccountManager.setMapSDKKey(MAP_SDK_KEY);
MapplsAccountManager.setRestAPIKey(REST_API_KEY);
MapplsAccountManager.setAtlasClientId(ATLAS_CLIENT_ID);
MapplsAccountManager.setAtlasClientSecret(ATLAS_CLIENT_SECRET);
setState(() {
selectedFeatureType = FeatureType.MAP_EVENT;
});
setPermission();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar:
AppBar(backgroundColor: MyColor.colorPrimary, title: titleMap()),
drawer: mapDrawer(),
body: itemList(context));
}
Drawer mapDrawer() {
return Drawer(
child: ListView(
padding: EdgeInsets.only(top: 0.0, bottom: 0.0, left: 0.0, right: 0.0),
children: <Widget>[
Container(
decoration: BoxDecoration(
gradient: LinearGradient(
colors: [
MyColor.colorPrimary,
MyColor.colorPrimaryDark,
MyColor.colorAccent
],
begin: Alignment.topLeft,
end: Alignment.bottomRight,
)),
height: 170,
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
mainAxisSize: MainAxisSize.max,
children: <Widget>[
SizedBox(
height: 110,
),
Text(
"Mappls Flutter Sample",
style: TextStyle(
fontSize: 18,
color: Colors.white,
fontWeight: FontWeight.bold),
),
SizedBox(
height: 30,
),
],
),
),
ListTile(
title: Text('Map Events'),
onTap: () => {
setState(() {
selectedFeatureType = FeatureType.MAP_EVENT;
}),
Navigator.pop(context)
},
),
ListTile(
title: Text('Map Layers'),
onTap: () => {
setState(() {
selectedFeatureType = FeatureType.MAP_LAYERS;
}),
Navigator.pop(context)
},
),
ListTile(
title: Text('Camera'),
onTap: () => {
setState(() {
selectedFeatureType = FeatureType.CAMERA_FEATURE;
}),
Navigator.pop(context)
},
),
ListTile(
title: Text('Marker'),
onTap: () => {
setState(() {
selectedFeatureType = FeatureType.MARKER_FEATURE;
}),
Navigator.pop(context)
},
),
ListTile(
title: Text('Location'),
onTap: () => {
setState(() {
selectedFeatureType = FeatureType.LOCATION_FEATURE;
}),
Navigator.pop(context)
},
),
ListTile(
title: Text('Polylines'),
onTap: () => {
setState(() {
selectedFeatureType = FeatureType.POLYLINE_FEATURE;
}),
Navigator.pop(context)
},
),
ListTile(
title: Text('Rest Api Call'),
onTap: () => {
setState(() {
selectedFeatureType = FeatureType.REST_API_CALLS;
}),
Navigator.pop(context)
},
),
ListTile(
title: Text('Animations'),
onTap: () => {
setState(() {
selectedFeatureType = FeatureType.ANIMATION_FEATURE;
}),
Navigator.pop(context)
},
)
],
),
);
}
Widget itemList(BuildContext context) {
if (selectedFeatureType == FeatureType.CAMERA_FEATURE) {
return ListView.builder(
itemCount: cameraFeatures.length,
itemBuilder: (_, int index) =>
itemWidget(cameraFeatures[index], context));
} else if (selectedFeatureType == FeatureType.MARKER_FEATURE) {
return ListView.builder(
itemCount: markerFeatures.length,
itemBuilder: (_, int index) =>
itemWidget(markerFeatures[index], context));
} else if (selectedFeatureType == FeatureType.MAP_LAYERS) {
return ListView.builder(
itemCount: layersFeatures.length,
itemBuilder: (_, int index) =>
itemWidget(layersFeatures[index], context));
} else if (selectedFeatureType == FeatureType.LOCATION_FEATURE) {
return ListView.builder(
itemCount: locationFeatures.length,
itemBuilder: (_, int index) =>
itemWidget(locationFeatures[index], context));
} else if (selectedFeatureType == FeatureType.REST_API_CALLS) {
return ListView.builder(
itemCount: restApiFeatures.length,
itemBuilder: (_, int index) =>
itemWidget(restApiFeatures[index], context));
} else if (selectedFeatureType == FeatureType.POLYLINE_FEATURE) {
return ListView.builder(
itemCount: polylineFeatures.length,
itemBuilder: (_, int index) =>
itemWidget(polylineFeatures[index], context));
} else if (selectedFeatureType == FeatureType.ANIMATION_FEATURE) {
return ListView.builder(
itemCount: animationFeatures.length,
itemBuilder: (_, int index) =>
itemWidget(animationFeatures[index], context));
} else {
return ListView.builder(
itemCount: mapEvents.length,
itemBuilder: (_, int index) => itemWidget(mapEvents[index], context));
}
}
titleMap() {
if (selectedFeatureType == FeatureType.CAMERA_FEATURE) {
return Text('Camera');
} else if (selectedFeatureType == FeatureType.MARKER_FEATURE) {
return Text('Marker');
} else if (selectedFeatureType == FeatureType.LOCATION_FEATURE) {
return Text('Location');
} else if (selectedFeatureType == FeatureType.REST_API_CALLS) {
return Text('Rest Api Call');
} else if (selectedFeatureType == FeatureType.POLYLINE_FEATURE) {
return Text('Polyline');
} else if (selectedFeatureType == FeatureType.MAP_LAYERS) {
return Text('Map Layers');
} else if (selectedFeatureType == FeatureType.ANIMATION_FEATURE) {
return Text('Animations');
} else {
return Text('Map Events');
}
}
}
Widget itemWidget(FeatureList featureList, BuildContext context) {
return GestureDetector(
child: Column(
children: <Widget>[
SizedBox(
height: 12,
),
Text(
featureList.featureTitle,
style: TextStyle(fontSize: 16, fontWeight: FontWeight.bold),
),
SizedBox(
height: 4,
),
Text(
featureList.featureDescription,
style: TextStyle(fontSize: 12),
),
SizedBox(
height: 12,
),
Divider(
height: 4,
thickness: 2,
)
],
),
onTap: () => {Navigator.pushNamed(context, featureList.routeName)},
);
}