You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1204 lines
51 KiB
1204 lines
51 KiB
// import 'dart:convert'; |
|
// import 'dart:io'; |
|
// import 'dart:ui'; |
|
// import 'package:flutter/cupertino.dart'; |
|
// import 'package:flutter/material.dart'; |
|
// |
|
// import 'package:flutter_easyloading/flutter_easyloading.dart'; |
|
// import 'package:flutter_smart_dialog/flutter_smart_dialog.dart'; |
|
// import 'package:huixiang/utils/flutter_utils.dart'; |
|
// import 'package:huixiang/utils/font_weight.dart'; |
|
// import 'package:huixiang/utils/location.dart'; |
|
// import 'package:flutter_screenutil/flutter_screenutil.dart'; |
|
// import 'package:permission_handler/permission_handler.dart'; |
|
// import 'package:url_launcher/url_launcher.dart'; |
|
// |
|
// import '../generated/l10n.dart'; |
|
// import '../retrofit/data/store_info.dart'; |
|
// import '../view_widget/custom_image.dart'; |
|
// import '../view_widget/location_tips.dart'; |
|
// import '../view_widget/round_button.dart'; |
|
// |
|
// class LocationMap extends StatefulWidget { |
|
// final Map<String, dynamic> arguments; |
|
// |
|
// LocationMap({this.arguments}); |
|
// |
|
// @override |
|
// State<StatefulWidget> createState() { |
|
// return _LocationMap(); |
|
// } |
|
// } |
|
// |
|
// class _LocationMap extends State<LocationMap> with WidgetsBindingObserver { |
|
// StoreInfo storeInfo; |
|
// int navigationState = 0; |
|
// double distance; |
|
// int navigationType = 0; |
|
// bool positionSorta = false; |
|
// String myAddress; |
|
// String myCity; |
|
// String hours; |
|
// String minutes; |
|
// String polylineId; |
|
// bool _isShowLocalTips = false; |
|
// |
|
// @override |
|
// void initState() { |
|
// super.initState(); |
|
// WidgetsBinding.instance.addObserver(this); |
|
// storeInfo = widget.arguments["storeInfo"]; |
|
// distance = widget.arguments["distance"]; |
|
// getLocation(); |
|
// } |
|
// |
|
// void getLocation() async { |
|
// bool powerFlag = false; |
|
// try { |
|
// Future.delayed(Duration(seconds: 5), () { |
|
// LocationInstance.getInstance().stopLocation(); |
|
// }); |
|
// powerFlag = await LocationInstance.getInstance().startLocation(context, |
|
// (BaiduLocation result) { |
|
// if (result != null && |
|
// result.latitude != null && |
|
// result.longitude != null) { |
|
// print("location: $result"); |
|
// myLatLng = Latlng(result.latitude, result.longitude); |
|
// myAddress = result.locationDetail; |
|
// myCity = result.city; |
|
// if (distance == null) calculate(); |
|
// // AppUtils.coordConvert(myLatLng).then((value) { |
|
// // this.myLatLng = value; |
|
// locationShow(); |
|
// // }); |
|
// LocationInstance.getInstance().stopLocation(); |
|
// } |
|
// }); |
|
// } finally { |
|
// if (!powerFlag) { |
|
// if (await Permission.locationWhenInUse.status.isGranted) { |
|
// getLocation(); |
|
// } else { |
|
// _isShowLocalTips = true; |
|
// } |
|
// // else { |
|
// // SmartDialog.showToast("您定位服务未开启,请前往系统设置中开启定位服务", |
|
// // alignment: Alignment.center); |
|
// // } |
|
// } |
|
// setState(() {}); |
|
// } |
|
// } |
|
// |
|
// calculate() async { |
|
// Latlng bmfCoordinate = Latlng( |
|
// double.tryParse(storeInfo.latitude), |
|
// double.tryParse(storeInfo.longitude), |
|
// ); |
|
// distance = double.tryParse( |
|
// await AppUtils.calculateDistance(bmfCoordinate, myLatLng, isMi: true)); |
|
// } |
|
// |
|
// locationShow() { |
|
// BMFLocation location = BMFLocation( |
|
// coordinate: myLatLng, |
|
// altitude: 0, |
|
// horizontalAccuracy: 5, |
|
// verticalAccuracy: -1.0, |
|
// speed: -1.0, |
|
// course: -1.0, |
|
// ); |
|
// BMFUserLocation userLocation = BMFUserLocation( |
|
// location: location, |
|
// ); |
|
// setState(() { |
|
// _mapController.updateLocationData(userLocation); |
|
// }); |
|
// } |
|
// |
|
// @override |
|
// void dispose() { |
|
// WidgetsBinding.instance.removeObserver(this); |
|
// LocationInstance.getInstance().stopLocation(); |
|
// super.dispose(); |
|
// } |
|
// |
|
// @override |
|
// void didChangeAppLifecycleState(AppLifecycleState state) { |
|
// if (state == AppLifecycleState.resumed) { |
|
// // 处理应用程序切换回前台的逻辑 |
|
// permissionSettings(); |
|
// } else if (state == AppLifecycleState.paused) { |
|
// // 处理应用程序切换到后台的逻辑 |
|
// } |
|
// } |
|
// |
|
// void permissionSettings() async { |
|
// if (_isShowLocalTips && await Permission.location.isGranted) { |
|
// _isShowLocalTips = false; |
|
// getLocation(); |
|
// } |
|
// } |
|
// |
|
// @override |
|
// Widget build(BuildContext context) { |
|
// return Scaffold( |
|
// // appBar: MyAppBar( |
|
// // background: Color(0xFFF7F7F7), |
|
// // title: widget.arguments["storeName"], |
|
// // titleColor: Colors.black87, |
|
// // titleSize: 18.sp, |
|
// // leadingColor: Colors.black, |
|
// // ), |
|
// body: Stack( |
|
// children: [ |
|
// Stack( |
|
// children: [ |
|
// Column( |
|
// children: [ |
|
// Expanded( |
|
// child: Container( |
|
// //BMFMapWidget 组件会自动默认沾满全屏,并且挡住所有遮盖物 ,BMFTextureMapWidget不会强制遮盖其他控件。 |
|
// child: (Platform.isAndroid) |
|
// ? BMFTextureMapWidget( |
|
// mapOptions: BMFMapOptions( |
|
// center: Latlng( |
|
// double.tryParse(widget.arguments["lat"]), |
|
// double.tryParse(widget.arguments["lng"]), |
|
// ), |
|
// showZoomControl: false, |
|
// showMapScaleBar: false, |
|
// rotateEnabled: false, |
|
// zoomLevel: 15, |
|
// ), |
|
// onBMFMapCreated: onMapCreated, |
|
// ) |
|
// : BMFMapWidget( |
|
// mapOptions: BMFMapOptions( |
|
// center: Latlng( |
|
// double.tryParse(widget.arguments["lat"]), |
|
// double.tryParse(widget.arguments["lng"]), |
|
// ), |
|
// showZoomControl: false, |
|
// showMapScaleBar: false, |
|
// rotateEnabled: false, |
|
// zoomLevel: 15, |
|
// ), |
|
// onBMFMapCreated: onMapCreated, |
|
// )), |
|
// flex: 3, |
|
// ), |
|
// navigationState == 0 |
|
// ? Container( |
|
// height: 253.h, |
|
// padding: EdgeInsets.only( |
|
// top: 16.h, left: 16.w, right: 28.w), |
|
// decoration: BoxDecoration( |
|
// color: Colors.white, |
|
// boxShadow: [ |
|
// BoxShadow( |
|
// color: Color(0x08213303), |
|
// offset: Offset(0, 2), |
|
// blurRadius: 4, |
|
// spreadRadius: 0, |
|
// ), |
|
// ], |
|
// borderRadius: BorderRadius.vertical( |
|
// top: Radius.circular(8), |
|
// ), |
|
// ), |
|
// child: Column( |
|
// crossAxisAlignment: CrossAxisAlignment.start, |
|
// children: [ |
|
// Expanded( |
|
// child: Row( |
|
// children: [ |
|
// Expanded( |
|
// child: Column( |
|
// children: [ |
|
// Text( |
|
// storeInfo?.storeName ?? "", |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// fontSize: 20.sp, |
|
// color: Color(0xFF0D0D0D), |
|
// fontWeight: MyFontWeight.medium, |
|
// ), |
|
// ), |
|
// Row( |
|
// children: [ |
|
// Text( |
|
// S.of(context).ren( |
|
// storeInfo != null |
|
// ? storeInfo |
|
// .perCapitaConsumption |
|
// : "", |
|
// ), |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// fontSize: 12.sp, |
|
// fontWeight: |
|
// MyFontWeight.regular, |
|
// color: Color(0xFF4D4D4D), |
|
// ), |
|
// ), |
|
// SizedBox( |
|
// width: 20.w, |
|
// ), |
|
// ]..addAll(itemServer( |
|
// storeInfo != null |
|
// ? storeInfo.businessService |
|
// : "")), |
|
// ), |
|
// Text( |
|
// S.of(context).yingyeshijian(storeInfo == |
|
// null |
|
// ? "" |
|
// : (storeInfo.openStartTime == |
|
// null && |
|
// storeInfo.openEndTime == |
|
// null) |
|
// ? S.of(context).quantian |
|
// : "${storeInfo.openStartTime.substring(0, storeInfo.openStartTime.lastIndexOf(":"))} " |
|
// "- ${storeInfo.openEndTime.substring(0, storeInfo.openEndTime.lastIndexOf(":"))}"), |
|
// style: TextStyle( |
|
// color: Color(0xFF4D4D4D), |
|
// fontWeight: MyFontWeight.medium, |
|
// fontSize: 12.sp, |
|
// ), |
|
// ), |
|
// ], |
|
// mainAxisAlignment: |
|
// MainAxisAlignment.spaceAround, |
|
// crossAxisAlignment: |
|
// CrossAxisAlignment.start, |
|
// ), |
|
// ), |
|
// MImage( |
|
// storeInfo != null ? storeInfo.logo : "", |
|
// width: 72.h, |
|
// height: 72.h, |
|
// fit: BoxFit.cover, |
|
// errorSrc: "assets/image/default_1.webp", |
|
// fadeSrc: "assets/image/default_1.webp", |
|
// ), |
|
// ], |
|
// ), |
|
// ), |
|
// Padding( |
|
// padding: EdgeInsets.only(bottom: 32.h), |
|
// child: Text( |
|
// "${storeInfo != null ? storeInfo.address : ""}", |
|
// maxLines: 2, |
|
// textAlign: TextAlign.justify, |
|
// style: TextStyle( |
|
// color: Color(0xFF353535), |
|
// fontWeight: MyFontWeight.regular, |
|
// fontSize: 12.sp, |
|
// ), |
|
// ), |
|
// ), |
|
// GestureDetector( |
|
// behavior: HitTestBehavior.opaque, |
|
// onTap: () { |
|
// if (myLatLng == null) { |
|
// // onOpenBaiduMap(); |
|
// SmartDialog.showToast( |
|
// "您定位服务未开启,请前往系统设置中开启定位服务", |
|
// alignment: Alignment.center); |
|
// } else { |
|
// navigationState = 1; |
|
// if ((distance ?? 0) < 500) |
|
// navigationType = 1; |
|
// else if ((distance ?? 0) < 1500) |
|
// navigationType = 2; |
|
// else |
|
// navigationType = 4; |
|
// navigationPosition(); |
|
// } |
|
// }, |
|
// child: Container( |
|
// alignment: Alignment.center, |
|
// width: double.infinity, |
|
// padding: EdgeInsets.symmetric(vertical: 10.h), |
|
// margin: EdgeInsets.only(bottom: 30.h), |
|
// decoration: BoxDecoration( |
|
// color: Color(0xFF32A060), |
|
// borderRadius: BorderRadius.circular(23), |
|
// ), |
|
// child: Text( |
|
// "到这去", |
|
// style: TextStyle( |
|
// fontSize: 20.sp, |
|
// color: Colors.white, |
|
// fontWeight: MyFontWeight.medium, |
|
// ), |
|
// ), |
|
// ), |
|
// ) |
|
// ], |
|
// ), |
|
// ) |
|
// : navigationDistance(), |
|
// ], |
|
// ), |
|
// navigationState == 0 |
|
// ? GestureDetector( |
|
// behavior: HitTestBehavior.opaque, |
|
// onTap: () { |
|
// Navigator.of(context).pop(); |
|
// }, |
|
// child: Container( |
|
// height: 56.h, |
|
// margin: EdgeInsets.only( |
|
// top: MediaQuery.of(context).padding.top + 16.h, |
|
// left: 14.w, |
|
// right: 14.w), |
|
// padding: EdgeInsets.only(left: 12.w, right: 21.w), |
|
// decoration: BoxDecoration( |
|
// color: Colors.white, |
|
// boxShadow: [ |
|
// BoxShadow( |
|
// color: Color(0x08213303), |
|
// offset: Offset(0, 2), |
|
// blurRadius: 4, |
|
// spreadRadius: 0, |
|
// ), |
|
// ], |
|
// borderRadius: BorderRadius.circular(6), |
|
// ), |
|
// child: Row( |
|
// children: [ |
|
// Icon( |
|
// Icons.arrow_back_ios, |
|
// color: Color(0xFF353535), |
|
// size: 24, |
|
// ), |
|
// Expanded( |
|
// child: Text( |
|
// storeInfo?.storeName ?? "", |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// color: Color(0xFF0D0D0D), |
|
// fontSize: 18.sp, |
|
// fontWeight: MyFontWeight.regular, |
|
// ), |
|
// )) |
|
// ], |
|
// ), |
|
// ), |
|
// ) |
|
// : navigationBox(), |
|
// ], |
|
// ), |
|
// if (_isShowLocalTips) |
|
// Padding( |
|
// padding: EdgeInsets.only(top: MediaQuery.of(context).padding.top), |
|
// child: LocationTips(() { |
|
// setState(() { |
|
// _isShowLocalTips = false; |
|
// }); |
|
// }), |
|
// ) |
|
// ], |
|
// ), |
|
// ); |
|
// } |
|
// |
|
// void onOpenBaiduMap() async { |
|
// launch( |
|
// "baidumap://map/marker?location=${storeInfo.latitude},${storeInfo.longitude}&title=${storeInfo.storeName}&content=${storeInfo.storeName}&traffic=on&src=andr.baidu.openAPIdemo&coord_type=gcj02"); |
|
// } |
|
// |
|
// //調取百度地圖APP |
|
// void onOpenBaiduMapRoute() async { |
|
// // 我的位置 |
|
// Latlng startCoord = Latlng( |
|
// positionSorta == false |
|
// ? myLatLng.latitude |
|
// : latLng.latitude, |
|
// positionSorta == false |
|
// ? myLatLng.longitude |
|
// : latLng.longitude); |
|
// String startName = ((positionSorta == false) ? "我的位置" : "终点"); |
|
// // 去的位置 |
|
// String endName = ((positionSorta == false) ? "终点" : "我的位置"); |
|
// Latlng endCoord = Latlng( |
|
// positionSorta == false |
|
// ? latLng.latitude |
|
// : myLatLng.latitude, |
|
// positionSorta == false |
|
// ? latLng.longitude |
|
// : myLatLng.longitude); |
|
// BMFOpenRouteOption routeOption = BMFOpenRouteOption( |
|
// startCoord: startCoord, |
|
// startName: startName, |
|
// endCoord: endCoord, |
|
// endName: endName, |
|
// routeType: navigationType == 1 |
|
// ? BMFOpenRouteType.WalkingRoute |
|
// : navigationType == 2 |
|
// ? BMFOpenRouteType.WalkingRoute |
|
// : navigationType == 3 |
|
// ? BMFOpenRouteType.TransitRoute |
|
// : BMFOpenRouteType.DrivingRoute, |
|
// appScheme: 'baidumapsdk_flutter://mapsdk.baidu.com', |
|
// // 指定返回自定义scheme |
|
// isSupportWeb: true); |
|
// BMFOpenErrorCode flag = |
|
// await BMFOpenMapUtils.openBaiduMapRoute(routeOption); |
|
// print('open - route - errorCode = $flag'); |
|
// } |
|
// |
|
// updateMapLine(List<Latlng> coordinates, int needHours, int needMinutes, |
|
// double needDistance) { |
|
// try { |
|
// //刪除之前的創建的點和綫 |
|
// _mapController.cleanAllMarkers(); |
|
// if (polylineId != null) _mapController.removeOverlay(polylineId); |
|
// |
|
// /// 创建polyline |
|
// BMFPolyline colorsPolyline = BMFPolyline( |
|
// // id: polylineOptions.hashCode.toString(), |
|
// coordinates: coordinates, |
|
// indexs: [0], |
|
// textures: [ |
|
// navigationType != 4 |
|
// ? 'assets/image/traffic_texture_unknown.png' |
|
// : 'assets/image/traffic_texture_smooth.png' |
|
// ], |
|
// width: Platform.isAndroid ? 16 : 10, |
|
// lineDashType: BMFLineDashType.LineDashTypeNone, |
|
// lineCapType: BMFLineCapType.LineCapButt, |
|
// lineJoinType: BMFLineJoinType.LineJoinRound); |
|
// polylineId = colorsPolyline.id; |
|
// |
|
// /// 添加polyline |
|
// _mapController.addPolyline(colorsPolyline); |
|
// var startBmfMarker = BMFMarker.icon( |
|
// position: Latlng( |
|
// coordinates.first.latitude, coordinates.first.longitude), |
|
// centerOffset: BMFPoint(0.5, 0.7), |
|
// enabled: false, |
|
// icon: "assets/image/icon_start.png", |
|
// draggable: false, |
|
// ); |
|
// _mapController.addMarker(startBmfMarker); |
|
// |
|
// var terminalBmfMarker = BMFMarker.icon( |
|
// position: Latlng( |
|
// coordinates.last.latitude, coordinates.last.longitude), |
|
// centerOffset: BMFPoint(0.5, 0.7), |
|
// enabled: false, |
|
// icon: "assets/image/icon_end.png", |
|
// draggable: false, |
|
// ); |
|
// _mapController.addMarker(terminalBmfMarker); |
|
// |
|
// double maxLatitude = 0, |
|
// minLatitude = 0, |
|
// maxLongitude = 0, |
|
// minLongitude = 0; |
|
// coordinates.forEach((element) { |
|
// if (element.latitude > maxLatitude) maxLatitude = element.latitude; |
|
// if (minLatitude == 0) |
|
// minLatitude = element.latitude; |
|
// else if (element.latitude < minLatitude) minLatitude = element.latitude; |
|
// |
|
// if (element.longitude > maxLongitude) maxLongitude = element.longitude; |
|
// if (minLongitude == 0) |
|
// minLongitude = element.longitude; |
|
// else if (element.longitude < minLongitude) |
|
// minLongitude = element.longitude; |
|
// }); |
|
// _mapController.setVisibleMapBounds( |
|
// BMFCoordinateBounds( |
|
// northeast: Latlng( |
|
// maxLatitude + ((maxLatitude - minLatitude) * 0.8), |
|
// maxLongitude + ((maxLongitude - minLongitude) / 2)), |
|
// southwest: Latlng( |
|
// minLatitude - ((maxLatitude - minLatitude) * 0.2), |
|
// minLongitude - ((maxLongitude - minLongitude) / 2))), |
|
// true); |
|
// |
|
// hours = needHours == 0 ? "" : "$needHours小时"; |
|
// minutes = needMinutes == 0 ? "" : "$needMinutes分钟"; |
|
// distance = needDistance; |
|
// } finally { |
|
// setState(() {}); |
|
// SmartDialog.dismiss(); |
|
// } |
|
// } |
|
// |
|
// navigationPosition() async { |
|
// EasyLoading.show( |
|
// status: S.current.zhengzaijiazai, ); |
|
// BMFPlanNode from = BMFPlanNode( |
|
// cityName: positionSorta == false ? myCity : (storeInfo?.city ?? ""), |
|
// name: positionSorta == false ? myAddress : storeInfo?.address ?? "", |
|
// pt: positionSorta == false |
|
// ? Latlng(myLatLng?.latitude ?? 0, myLatLng?.longitude ?? 0) |
|
// : latLng); |
|
// BMFPlanNode to = BMFPlanNode( |
|
// // cityName: positionSorta == false ? (storeInfo?.city ?? "") : myCity, |
|
// // name: positionSorta == false ? (storeInfo?.address ?? "") : myAddress, |
|
// pt: positionSorta == false |
|
// ? latLng |
|
// : Latlng(myLatLng?.latitude ?? 0, myLatLng?.longitude ?? 0)); |
|
// if (navigationType == 1) { |
|
// //步行 |
|
// BMFWalkingRoutePlanOption walkingRoutePlanOption = |
|
// BMFWalkingRoutePlanOption(from: from, to: to); |
|
// // 检索实例 |
|
// BMFWalkingRouteSearch walkingRouteSearch = BMFWalkingRouteSearch(); |
|
// // 检索回调 |
|
// walkingRouteSearch.onGetWalkingRouteSearchResult(callback: |
|
// (BMFWalkingRouteResult result, BMFSearchErrorCode errorCode) async { |
|
// if (errorCode == BMFSearchErrorCode.RESULT_NOT_FOUND) { |
|
// SmartDialog.showToast("该方案暂无可用的规划路线", alignment: Alignment.center); |
|
// SmartDialog.dismiss(); |
|
// return; |
|
// } else if (errorCode != BMFSearchErrorCode.NO_ERROR) { |
|
// SmartDialog.showToast("获取路线规划失败,请稍后再试", alignment: Alignment.center); |
|
// SmartDialog.dismiss(); |
|
// return; |
|
// } |
|
// print( |
|
// '`步行检索回调 errorCode = ${errorCode} \n result = ${result?.toMap()}'); |
|
// |
|
// /// 坐标点 |
|
// List<Latlng> coordinates = []; |
|
// result.routes.first.steps.forEach((e1) { |
|
// e1.points.forEach((e2) { |
|
// coordinates.add(Latlng(e2.latitude, e2.longitude)); |
|
// }); |
|
// }); |
|
// updateMapLine( |
|
// coordinates, |
|
// result.routes.first.duration.hours, |
|
// result.routes.first.duration.minutes, |
|
// result.routes.first.distance.toDouble()); |
|
// }); |
|
// bool flag = |
|
// await walkingRouteSearch.walkingRouteSearch(walkingRoutePlanOption); |
|
// } else if (navigationType == 2) { |
|
// //骑行 |
|
// BMFRidingRoutePlanOption ridingRoutePlanOption = |
|
// BMFRidingRoutePlanOption(from: from, to: to); |
|
// BMFRidingRouteSearch ridingRouteSearch = BMFRidingRouteSearch(); |
|
// ridingRouteSearch.onGetRidingRouteSearchResult(callback: |
|
// (BMFRidingRouteResult result, BMFSearchErrorCode errorCode) { |
|
// if (errorCode == BMFSearchErrorCode.RESULT_NOT_FOUND) { |
|
// SmartDialog.showToast("该方案暂无可用的规划路线", alignment: Alignment.center); |
|
// SmartDialog.dismiss(); |
|
// return; |
|
// } else if (errorCode != BMFSearchErrorCode.NO_ERROR) { |
|
// SmartDialog.showToast("获取路线规划失败,请稍后再试", alignment: Alignment.center); |
|
// SmartDialog.dismiss(); |
|
// return; |
|
// } |
|
// print( |
|
// '`骑行检索回调 errorCode = ${errorCode} \n result = ${result?.toMap()}'); |
|
// |
|
// /// 坐标点 |
|
// List<Latlng> coordinates = []; |
|
// result.routes.first.steps.forEach((e1) { |
|
// e1.points.forEach((e2) { |
|
// coordinates.add(Latlng(e2.latitude, e2.longitude)); |
|
// }); |
|
// }); |
|
// updateMapLine( |
|
// coordinates, |
|
// result.routes.first.duration.hours, |
|
// result.routes.first.duration.minutes, |
|
// result.routes.first.distance.toDouble()); |
|
// }); |
|
// // 发起检索 |
|
// bool flag = |
|
// await ridingRouteSearch.ridingRouteSearch(ridingRoutePlanOption); |
|
// } else if (navigationType == 3) { |
|
// //公交 |
|
// BMFTransitRoutePlanOption transitRoutePlanOption = |
|
// BMFTransitRoutePlanOption(from: from, to: to, city: '武汉市'); |
|
// BMFTransitRouteSearch transitRouteSearch = BMFTransitRouteSearch(); |
|
// transitRouteSearch.onGetTransitRouteSearchResult(callback: |
|
// (BMFTransitRouteResult result, BMFSearchErrorCode errorCode) { |
|
// if (errorCode == BMFSearchErrorCode.RESULT_NOT_FOUND) { |
|
// SmartDialog.showToast("该方案暂无可用的规划路线", alignment: Alignment.center); |
|
// SmartDialog.dismiss(); |
|
// return; |
|
// } else if (errorCode != BMFSearchErrorCode.NO_ERROR) { |
|
// SmartDialog.showToast("获取路线规划失败,请稍后再试", alignment: Alignment.center); |
|
// SmartDialog.dismiss(); |
|
// return; |
|
// } |
|
// print( |
|
// '`市内公交检索回调 errorCode = ${errorCode} \n result = ${result?.toMap()}'); |
|
// |
|
// /// 坐标点 |
|
// List<Latlng> coordinates = []; |
|
// result.routes.first.steps.forEach((e1) { |
|
// e1.points.forEach((e2) { |
|
// coordinates.add(Latlng(e2.latitude, e2.longitude)); |
|
// }); |
|
// }); |
|
// updateMapLine( |
|
// coordinates, |
|
// result.routes.first.duration.hours, |
|
// result.routes.first.duration.minutes, |
|
// result.routes.first.distance.toDouble()); |
|
// }); |
|
// // 发起检索 |
|
// bool flag = |
|
// await transitRouteSearch.transitRouteSearch(transitRoutePlanOption); |
|
// } else { |
|
// //驾车 |
|
// BMFDrivingRoutePlanOption drivingRoutePlanOption = |
|
// BMFDrivingRoutePlanOption(from: from, to: to); |
|
// BMFDrivingRouteSearch drivingRouteSearch = BMFDrivingRouteSearch(); |
|
// drivingRouteSearch.onGetDrivingRouteSearchResult(callback: |
|
// (BMFDrivingRouteResult result, BMFSearchErrorCode errorCode) { |
|
// if (errorCode == BMFSearchErrorCode.RESULT_NOT_FOUND) { |
|
// SmartDialog.showToast("该方案暂无可用的规划路线", alignment: Alignment.center); |
|
// SmartDialog.dismiss(); |
|
// return; |
|
// } else if (errorCode != BMFSearchErrorCode.NO_ERROR) { |
|
// SmartDialog.showToast("获取路线规划失败,请稍后再试", alignment: Alignment.center); |
|
// SmartDialog.dismiss(); |
|
// return; |
|
// } |
|
// print( |
|
// '驾车检索回调 errorCode = ${errorCode} \n result = ${result?.toMap()}'); |
|
// |
|
// /// 坐标点 |
|
// List<Latlng> coordinates = []; |
|
// result.routes.first.steps.forEach((e1) { |
|
// e1.points.forEach((e2) { |
|
// coordinates.add(Latlng(e2.latitude, e2.longitude)); |
|
// }); |
|
// }); |
|
// updateMapLine( |
|
// coordinates, |
|
// result.routes.first.duration.hours, |
|
// result.routes.first.duration.minutes, |
|
// result.routes.first.distance.toDouble()); |
|
// }); |
|
// // 发起检索 |
|
// bool flag = |
|
// await drivingRouteSearch.dringRouteSearch(drivingRoutePlanOption); |
|
// } |
|
// } |
|
// |
|
// Widget navigationBox() { |
|
// return Container( |
|
// height: 132.h, |
|
// margin: EdgeInsets.only( |
|
// top: MediaQuery.of(context).padding.top + 16.h, |
|
// left: 14.w, |
|
// right: 14.w), |
|
// padding: EdgeInsets.only(left: 12.w, right: 18.w, top: 8.h), |
|
// decoration: BoxDecoration( |
|
// color: Colors.white, |
|
// boxShadow: [ |
|
// BoxShadow( |
|
// color: Color(0x08213303), |
|
// offset: Offset(0, 2), |
|
// blurRadius: 4, |
|
// spreadRadius: 0, |
|
// ), |
|
// ], |
|
// borderRadius: BorderRadius.circular(6), |
|
// ), |
|
// child: Row( |
|
// crossAxisAlignment: CrossAxisAlignment.start, |
|
// children: [ |
|
// GestureDetector( |
|
// behavior: HitTestBehavior.opaque, |
|
// onTap: () { |
|
// setState(() { |
|
// navigationState = 0; |
|
// }); |
|
// }, |
|
// child: Padding( |
|
// padding: EdgeInsets.only(top: 10.h, right: 10.w), |
|
// child: Icon( |
|
// Icons.arrow_back_ios, |
|
// color: Color(0xFF353535), |
|
// size: 24, |
|
// ), |
|
// ), |
|
// ), |
|
// Expanded( |
|
// child: Column( |
|
// children: [ |
|
// Container( |
|
// width: double.infinity, |
|
// decoration: BoxDecoration( |
|
// color: Color(0xFFF5F5F5), |
|
// borderRadius: BorderRadius.circular(6), |
|
// ), |
|
// padding: EdgeInsets.only( |
|
// top: 12.h, |
|
// bottom: 12.h, |
|
// left: 15.w, |
|
// ), |
|
// child: Row( |
|
// mainAxisAlignment: MainAxisAlignment.center, |
|
// children: [ |
|
// Expanded( |
|
// child: Column( |
|
// crossAxisAlignment: CrossAxisAlignment.start, |
|
// children: [ |
|
// Padding( |
|
// padding: EdgeInsets.only( |
|
// bottom: 14.h, |
|
// ), |
|
// child: Row( |
|
// children: [ |
|
// Container( |
|
// width: 4.h, |
|
// height: 4.h, |
|
// margin: EdgeInsets.only(right: 20.w), |
|
// decoration: BoxDecoration( |
|
// color: Color(0xFF32A060), |
|
// borderRadius: BorderRadius.circular(6), |
|
// ), |
|
// ), |
|
// Expanded( |
|
// child: Text( |
|
// positionSorta == false |
|
// ? "我的位置" |
|
// : (storeInfo?.storeName ?? ""), |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// color: Color(0xFF0D0D0D), |
|
// fontSize: 14.sp, |
|
// fontWeight: MyFontWeight.semi_bold, |
|
// ), |
|
// )) |
|
// ], |
|
// ), |
|
// ), |
|
// Row( |
|
// children: [ |
|
// Container( |
|
// width: 4.h, |
|
// height: 4.h, |
|
// margin: EdgeInsets.only(right: 20.w), |
|
// decoration: BoxDecoration( |
|
// color: Color(0xFFFA5151), |
|
// borderRadius: BorderRadius.circular(6), |
|
// ), |
|
// ), |
|
// Expanded( |
|
// child: Text( |
|
// positionSorta == false |
|
// ? (storeInfo?.storeName ?? "") |
|
// : "我的位置", |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// color: Color(0xFF0D0D0D), |
|
// fontSize: 14.sp, |
|
// fontWeight: MyFontWeight.semi_bold, |
|
// ), |
|
// )) |
|
// ], |
|
// ) |
|
// ], |
|
// )), |
|
// GestureDetector( |
|
// behavior: HitTestBehavior.opaque, |
|
// onTap: () { |
|
// positionSorta = !positionSorta; |
|
// navigationPosition(); |
|
// }, |
|
// child: Container( |
|
// padding: EdgeInsets.only(right: 24.w), |
|
// child: Image.asset( |
|
// "assets/image/position_sort.webp", |
|
// fit: BoxFit.fill, |
|
// height: 16.h, |
|
// width: 14.w, |
|
// ), |
|
// ), |
|
// ) |
|
// ], |
|
// ), |
|
// ), |
|
// SizedBox( |
|
// height: 12.h, |
|
// ), |
|
// Row( |
|
// children: [ |
|
// Expanded( |
|
// child: GestureDetector( |
|
// behavior: HitTestBehavior.opaque, |
|
// onTap: () { |
|
// navigationType = 4; |
|
// navigationPosition(); |
|
// }, |
|
// child: Container( |
|
// decoration: BoxDecoration( |
|
// color: navigationType == 4 |
|
// ? Color(0xFFE8FFF2) |
|
// : Colors.transparent, |
|
// borderRadius: BorderRadius.circular(23), |
|
// ), |
|
// padding: |
|
// EdgeInsets.symmetric(vertical: 5.h, horizontal: 13.w), |
|
// child: Row( |
|
// children: [ |
|
// if (navigationType == 4) |
|
// Image.asset( |
|
// "assets/image/icon_drive.webp", |
|
// fit: BoxFit.fill, |
|
// height: 16.h, |
|
// width: 14.w, |
|
// ), |
|
// Padding( |
|
// padding: EdgeInsets.only(left: 2.w), |
|
// child: Text( |
|
// "驾车", |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// color: navigationType == 4 |
|
// ? Color(0xFF32A060) |
|
// : Colors.black, |
|
// fontSize: 12.sp, |
|
// fontWeight: MyFontWeight.medium, |
|
// ), |
|
// ), |
|
// ) |
|
// ], |
|
// ), |
|
// ), |
|
// )), |
|
// Expanded( |
|
// child: GestureDetector( |
|
// behavior: HitTestBehavior.opaque, |
|
// onTap: () { |
|
// navigationType = 3; |
|
// navigationPosition(); |
|
// }, |
|
// child: Container( |
|
// decoration: BoxDecoration( |
|
// color: navigationType == 3 |
|
// ? Color(0xFFE8FFF2) |
|
// : Colors.transparent, |
|
// borderRadius: BorderRadius.circular(23), |
|
// ), |
|
// padding: EdgeInsets.symmetric( |
|
// vertical: 5.h, horizontal: 13.w), |
|
// child: Row( |
|
// children: [ |
|
// if (navigationType == 3) |
|
// Image.asset( |
|
// "assets/image/icon_transit.webp", |
|
// fit: BoxFit.fill, |
|
// height: 16.h, |
|
// width: 14.w, |
|
// ), |
|
// Padding( |
|
// padding: EdgeInsets.only(left: 2.w), |
|
// child: Text( |
|
// "公交", |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// color: navigationType == 3 |
|
// ? Color(0xFF32A060) |
|
// : Colors.black, |
|
// fontSize: 12.sp, |
|
// fontWeight: MyFontWeight.medium, |
|
// ), |
|
// ), |
|
// ) |
|
// ], |
|
// ), |
|
// ))), |
|
// Expanded( |
|
// child: GestureDetector( |
|
// behavior: HitTestBehavior.opaque, |
|
// onTap: () { |
|
// navigationType = 2; |
|
// navigationPosition(); |
|
// }, |
|
// child: Container( |
|
// decoration: BoxDecoration( |
|
// color: navigationType == 2 |
|
// ? Color(0xFFE8FFF2) |
|
// : Colors.transparent, |
|
// borderRadius: BorderRadius.circular(23), |
|
// ), |
|
// padding: EdgeInsets.symmetric( |
|
// vertical: 5.h, horizontal: 13.w), |
|
// child: Row( |
|
// children: [ |
|
// if (navigationType == 2) |
|
// Image.asset( |
|
// "assets/image/icon_by_bike.webp", |
|
// fit: BoxFit.fill, |
|
// height: 16.h, |
|
// width: 14.w, |
|
// ), |
|
// Padding( |
|
// padding: EdgeInsets.only(left: 2.w), |
|
// child: Text( |
|
// "骑行", |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// color: navigationType == 2 |
|
// ? Color(0xFF32A060) |
|
// : Colors.black, |
|
// fontSize: 12.sp, |
|
// fontWeight: MyFontWeight.medium, |
|
// ), |
|
// ), |
|
// ) |
|
// ], |
|
// ), |
|
// ))), |
|
// Expanded( |
|
// child: GestureDetector( |
|
// behavior: HitTestBehavior.opaque, |
|
// onTap: () { |
|
// navigationType = 1; |
|
// navigationPosition(); |
|
// }, |
|
// child: Container( |
|
// decoration: BoxDecoration( |
|
// color: navigationType == 1 |
|
// ? Color(0xFFE8FFF2) |
|
// : Colors.transparent, |
|
// borderRadius: BorderRadius.circular(23), |
|
// ), |
|
// padding: EdgeInsets.symmetric( |
|
// vertical: 5.h, horizontal: 13.w), |
|
// child: Row( |
|
// children: [ |
|
// if (navigationType == 1) |
|
// Image.asset( |
|
// "assets/image/icon_walk.webp", |
|
// fit: BoxFit.fill, |
|
// height: 16.h, |
|
// width: 14.w, |
|
// ), |
|
// Padding( |
|
// padding: EdgeInsets.only(left: 2.w), |
|
// child: Text( |
|
// "步行", |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// color: navigationType == 1 |
|
// ? Color(0xFF32A060) |
|
// : Colors.black, |
|
// fontSize: 12.sp, |
|
// fontWeight: MyFontWeight.medium, |
|
// ), |
|
// ), |
|
// ) |
|
// ], |
|
// ), |
|
// ))), |
|
// ], |
|
// ) |
|
// ], |
|
// )) |
|
// ], |
|
// ), |
|
// ); |
|
// } |
|
// |
|
// Widget navigationDistance() { |
|
// return Container( |
|
// height: 173.h, |
|
// padding: EdgeInsets.only(top: 16.h, left: 16.w, right: 16.w), |
|
// decoration: BoxDecoration( |
|
// color: Colors.white, |
|
// boxShadow: [ |
|
// BoxShadow( |
|
// color: Color(0x08213303), |
|
// offset: Offset(0, 2), |
|
// blurRadius: 4, |
|
// spreadRadius: 0, |
|
// ), |
|
// ], |
|
// borderRadius: BorderRadius.vertical( |
|
// top: Radius.circular(8), |
|
// ), |
|
// ), |
|
// child: Column( |
|
// // mainAxisAlignment: MainAxisAlignment.start, |
|
// crossAxisAlignment: CrossAxisAlignment.start, |
|
// children: [ |
|
// Expanded( |
|
// child: Row( |
|
// crossAxisAlignment: CrossAxisAlignment.start, |
|
// children: [ |
|
// Text( |
|
// "${navigationType == 1 ? "步行" : navigationType == 2 ? "骑行" : navigationType == 3 ? "公交" : "驾车"}${(hours ?? "") + (minutes ?? "")}", |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// fontSize: 20.sp, |
|
// color: Color(0xFF0D0D0D), |
|
// fontWeight: MyFontWeight.bold, |
|
// ), |
|
// ), |
|
// Padding( |
|
// padding: EdgeInsets.only(left: 40.w), |
|
// child: Text( |
|
// (distance ?? 0) > 1000 |
|
// ? S.of(context).gongli( |
|
// ((distance ?? 0) / 1000 * 100).toInt() / 100.0) |
|
// : S |
|
// .of(context) |
|
// .mi(((distance ?? 0) * 100).toInt() / 100.0), |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// fontSize: 20.sp, |
|
// color: Color(0xFF0D0D0D), |
|
// fontWeight: MyFontWeight.bold, |
|
// ), |
|
// ), |
|
// ), |
|
// ], |
|
// ), |
|
// ), |
|
// GestureDetector( |
|
// behavior: HitTestBehavior.opaque, |
|
// onTap: () { |
|
// setState(() { |
|
// navigationState = 1; |
|
// showMapSelect(); |
|
// }); |
|
// }, |
|
// child: Container( |
|
// alignment: Alignment.center, |
|
// width: double.infinity, |
|
// padding: EdgeInsets.symmetric(vertical: 10.h), |
|
// margin: EdgeInsets.only(bottom: 30.h), |
|
// decoration: BoxDecoration( |
|
// color: Color(0xFF32A060), |
|
// borderRadius: BorderRadius.circular(23), |
|
// ), |
|
// child: Text( |
|
// navigationType == 1 |
|
// ? "步行导航" |
|
// : navigationType == 2 |
|
// ? "骑行导航" |
|
// : navigationType == 3 |
|
// ? "公交导航" |
|
// : "驾车导航", |
|
// style: TextStyle( |
|
// fontSize: 20.sp, |
|
// color: Colors.white, |
|
// fontWeight: MyFontWeight.medium, |
|
// ), |
|
// ), |
|
// ), |
|
// ) |
|
// ], |
|
// ), |
|
// ); |
|
// } |
|
// |
|
// showMapSelect() { |
|
// showCupertinoModalPopup( |
|
// context: context, |
|
// builder: (context) { |
|
// return CupertinoActionSheet( |
|
// actions: [ |
|
// CupertinoActionSheetAction( |
|
// child: Text( |
|
// "百度地图", |
|
// style: TextStyle( |
|
// fontWeight: MyFontWeight.regular, |
|
// ), |
|
// ), |
|
// onPressed: () { |
|
// onOpenBaiduMapRoute(); |
|
// Navigator.of(context).pop(); |
|
// }, |
|
// isDefaultAction: true, |
|
// isDestructiveAction: false, |
|
// ), |
|
// ], |
|
// cancelButton: CupertinoActionSheetAction( |
|
// onPressed: () { |
|
// Navigator.of(context).pop(); |
|
// }, |
|
// child: Text(S.of(context).quxiao, |
|
// style: TextStyle( |
|
// color: Colors.blue, |
|
// ),), |
|
// isDestructiveAction: true, |
|
// ), |
|
// ); |
|
// }); |
|
// } |
|
// |
|
// List<Widget> itemServer(String businessService) { |
|
// if (businessService == null || businessService == "") return []; |
|
// var list = businessService.split(","); |
|
// return list |
|
// .map((e) => Container( |
|
// margin: EdgeInsets.only(right: 8.w), |
|
// child: RoundButton( |
|
// height: 17.h * AppUtils.textScale(context), |
|
// text: "$e", |
|
// backgroup: Color(0xFFFF7A1A), |
|
// padding: EdgeInsets.only( |
|
// left: 2.w, |
|
// right: 2.w, |
|
// ), |
|
// fontSize: 10.sp, |
|
// textColor: Colors.white, |
|
// ), |
|
// )) |
|
// .toList(); |
|
// } |
|
// |
|
// BMFMapController _mapController; |
|
// Latlng latLng; |
|
// Latlng myLatLng; |
|
// BMFMarker bmfMarker; |
|
// |
|
// onMapCreated(BMFMapController controller) { |
|
// _mapController = controller; |
|
// setState(() { |
|
// _mapController.showUserLocation(true); |
|
// _mapController.setCustomMapStyle('assets/map_style/chatian.sty', 0); |
|
// BMFUserLocationDisplayParam displayParam = BMFUserLocationDisplayParam( |
|
// locationViewOffsetX: 0, |
|
// locationViewOffsetY: 0, |
|
// accuracyCircleFillColor: Colors.red, |
|
// accuracyCircleStrokeColor: Colors.blue, |
|
// isAccuracyCircleShow: true, |
|
// locationViewImage: 'assets/image/icon_my_location.webp', |
|
// locationViewHierarchy: |
|
// BMFLocationViewHierarchy.LOCATION_VIEW_HIERARCHY_BOTTOM, |
|
// ); |
|
// _mapController.updateLocationViewWithParam(displayParam); |
|
// addMarker(); |
|
// }); |
|
// } |
|
// |
|
// addMarker() async { |
|
// latLng = await AppUtils.coordConvert(Latlng(double.tryParse(widget.arguments["lat"]), |
|
// double.tryParse(widget.arguments["lng"]))); |
|
// // latLng = Latlng(double.tryParse(widget.arguments["lat"]), |
|
// // double.tryParse(widget.arguments["lng"])); |
|
// |
|
// if (bmfMarker == null && _mapController != null) { |
|
// bmfMarker = BMFMarker.icon( |
|
// position: latLng, |
|
// centerOffset: BMFPoint(0.5, 0.7), |
|
// enabled: false, |
|
// icon: "assets/image/icon_map_marker.webp", |
|
// draggable: false, |
|
// ); |
|
// _mapController.addMarker(bmfMarker); |
|
// } |
|
// _mapController.setCenterCoordinate(latLng, true); |
|
// } |
|
// }
|
|
|