提交 de761f65 authored 作者: 史晓晨's avatar 史晓晨

feat:①调试web定位功能②重构定位插件

上级 d57fa9f4
......@@ -8,7 +8,7 @@ buildscript {
}
dependencies {
classpath 'com.android.tools.build:gradle:3.5.1'
classpath 'com.android.tools.build:gradle:7.3.0'
}
}
......@@ -25,7 +25,7 @@ android {
compileSdkVersion 31
defaultConfig {
minSdkVersion 16
minSdkVersion 23
}
lintOptions {
disable 'InvalidPackage'
......
......@@ -39,7 +39,7 @@ android {
defaultConfig {
// TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
applicationId "com.amap.flutter.amap_flutter_location_example"
minSdkVersion 16
minSdkVersion 23
targetSdkVersion 31
versionCode flutterVersionCode.toInteger()
versionName flutterVersionName
......
......@@ -20,6 +20,7 @@
<service android:name="com.amap.api.location.APSService"/>
<activity
android:name=".MainActivity"
android:exported="true"
android:launchMode="singleTop"
android:theme="@style/LaunchTheme"
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
......
......@@ -5,7 +5,7 @@ buildscript {
}
dependencies {
classpath 'com.android.tools.build:gradle:3.5.0'
classpath 'com.android.tools.build:gradle:7.3.0'
}
}
......@@ -24,6 +24,6 @@ subprojects {
project.evaluationDependsOn(':app')
}
task clean(type: Delete) {
tasks.register("clean", Delete) {
delete rootProject.buildDir
}
......@@ -3,4 +3,4 @@ distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.2-all.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-7.5-bin.zip
\ No newline at end of file
......@@ -21,6 +21,6 @@
<key>CFBundleVersion</key>
<string>1.0</string>
<key>MinimumOSVersion</key>
<string>9.0</string>
<string>12.0</string>
</dict>
</plist>
# Uncomment this line to define a global platform for your project
# platform :ios, '9.0'
# platform :ios, '12.0'
# CocoaPods analytics sends network stats synchronously affecting flutter build latency.
ENV['COCOAPODS_DISABLE_STATS'] = 'true'
......
......@@ -31,9 +31,9 @@ SPEC CHECKSUMS:
amap_flutter_location: 44ff5beb64f42e0bf5feb402fe299dac0013af6f
AMapFoundation: 8d8ecbb0b2e9ce5487995360d26c885d94642bfd
AMapLocation: 5ef44a1117be7dc541cb7a7d43d03c5ee91e4387
Flutter: 434fef37c0980e73bb6479ef766c45957d4b510c
Flutter: e0871f40cf51350855a761d2e70bf5af5b9b5de7
permission_handler: ccb20a9fad0ee9b1314a52b70b76b473c5f8dab0
PODFILE CHECKSUM: 8e679eca47255a8ca8067c4c67aab20e64cb974d
PODFILE CHECKSUM: 1a782344d33c12ced0182eeab11e8668d253eb48
COCOAPODS: 1.10.0
COCOAPODS: 1.15.2
......@@ -3,7 +3,7 @@
archiveVersion = 1;
classes = {
};
objectVersion = 50;
objectVersion = 54;
objects = {
/* Begin PBXBuildFile section */
......@@ -165,7 +165,7 @@
97C146E61CF9000F007C117D /* Project object */ = {
isa = PBXProject;
attributes = {
LastUpgradeCheck = 1020;
LastUpgradeCheck = 1510;
ORGANIZATIONNAME = "";
TargetAttributes = {
97C146ED1CF9000F007C117D = {
......@@ -208,10 +208,12 @@
/* Begin PBXShellScriptBuildPhase section */
3B06AD1E1E4923F5004D2608 /* Thin Binary */ = {
isa = PBXShellScriptBuildPhase;
alwaysOutOfDate = 1;
buildActionMask = 2147483647;
files = (
);
inputPaths = (
"${TARGET_BUILD_DIR}/${INFOPLIST_PATH}",
);
name = "Thin Binary";
outputPaths = (
......@@ -244,6 +246,7 @@
};
9740EEB61CF901F6004384FC /* Run Script */ = {
isa = PBXShellScriptBuildPhase;
alwaysOutOfDate = 1;
buildActionMask = 2147483647;
files = (
);
......@@ -332,7 +335,7 @@
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
IPHONEOS_DEPLOYMENT_TARGET = 9.0;
IPHONEOS_DEPLOYMENT_TARGET = 12.0;
MTL_ENABLE_DEBUG_INFO = NO;
SDKROOT = iphoneos;
SUPPORTED_PLATFORMS = iphoneos;
......@@ -346,9 +349,10 @@
baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_STYLE = Manual;
CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Automatic;
CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
DEVELOPMENT_TEAM = YMJ372W38W;
DEVELOPMENT_TEAM = "";
ENABLE_BITCODE = NO;
FRAMEWORK_SEARCH_PATHS = (
"$(inherited)",
......@@ -363,9 +367,9 @@
"$(inherited)",
"$(PROJECT_DIR)/Flutter",
);
PRODUCT_BUNDLE_IDENTIFIER = com.amap.location.amaplocationflutterpluginexample;
PRODUCT_BUNDLE_IDENTIFIER = com.clx.carrierDriver;
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE_SPECIFIER = OpenPlatform_Dev;
PROVISIONING_PROFILE_SPECIFIER = "";
VERSIONING_SYSTEM = "apple-generic";
};
name = Profile;
......@@ -417,7 +421,7 @@
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
IPHONEOS_DEPLOYMENT_TARGET = 9.0;
IPHONEOS_DEPLOYMENT_TARGET = 12.0;
MTL_ENABLE_DEBUG_INFO = YES;
ONLY_ACTIVE_ARCH = YES;
SDKROOT = iphoneos;
......@@ -466,7 +470,7 @@
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
IPHONEOS_DEPLOYMENT_TARGET = 9.0;
IPHONEOS_DEPLOYMENT_TARGET = 12.0;
MTL_ENABLE_DEBUG_INFO = NO;
SDKROOT = iphoneos;
SUPPORTED_PLATFORMS = iphoneos;
......@@ -480,9 +484,10 @@
baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */;
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_STYLE = Manual;
CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Automatic;
CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
DEVELOPMENT_TEAM = YMJ372W38W;
DEVELOPMENT_TEAM = "";
ENABLE_BITCODE = NO;
FRAMEWORK_SEARCH_PATHS = (
"$(inherited)",
......@@ -497,9 +502,9 @@
"$(inherited)",
"$(PROJECT_DIR)/Flutter",
);
PRODUCT_BUNDLE_IDENTIFIER = com.amap.location.amaplocationflutterpluginexample;
PRODUCT_BUNDLE_IDENTIFIER = com.clx.carrierDriver;
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE_SPECIFIER = OpenPlatform_Dev;
PROVISIONING_PROFILE_SPECIFIER = "";
VERSIONING_SYSTEM = "apple-generic";
};
name = Debug;
......@@ -509,9 +514,10 @@
baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_STYLE = Manual;
CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Automatic;
CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
DEVELOPMENT_TEAM = YMJ372W38W;
DEVELOPMENT_TEAM = "";
ENABLE_BITCODE = NO;
FRAMEWORK_SEARCH_PATHS = (
"$(inherited)",
......@@ -526,9 +532,9 @@
"$(inherited)",
"$(PROJECT_DIR)/Flutter",
);
PRODUCT_BUNDLE_IDENTIFIER = com.amap.location.amaplocationflutterpluginexample;
PRODUCT_BUNDLE_IDENTIFIER = com.clx.carrierDriver;
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE_SPECIFIER = OpenPlatform_Dev;
PROVISIONING_PROFILE_SPECIFIER = "";
VERSIONING_SYSTEM = "apple-generic";
};
name = Release;
......
<?xml version="1.0" encoding="UTF-8"?>
<Scheme
LastUpgradeVersion = "1020"
LastUpgradeVersion = "1510"
version = "1.3">
<BuildAction
parallelizeBuildables = "YES"
......
......@@ -2,6 +2,8 @@
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>CADisableMinimumFrameDurationOnPhone</key>
<true/>
<key>CFBundleDevelopmentRegion</key>
<string>$(DEVELOPMENT_LANGUAGE)</string>
<key>CFBundleExecutable</key>
......@@ -26,6 +28,8 @@
<string>权限说明,展示给用户的文案,需要您自行填写相关内容</string>
<key>NSLocationWhenInUseUsageDescription</key>
<string>aaaa</string>
<key>UIApplicationSupportsIndirectInputEvents</key>
<true/>
<key>UIBackgroundModes</key>
<array>
<string>fetch</string>
......
......@@ -52,12 +52,13 @@ class _MyAppState extends State<MyApp> {
///key的申请请参考高德开放平台官网说明<br>
///Android: https://lbs.amap.com/api/android-location-sdk/guide/create-project/get-key
///iOS: https://lbs.amap.com/api/ios-location-sdk/guide/create-project/get-key
AMapFlutterLocation.setApiKey("1dbf56e2e8a4d0e4cdc2df9efd36bc71", "dfb64c0463cb53927914364b5c09aba0");
/// ios key使用的是承运司机iOS
AMapFlutterLocation.setApiKey("1dbf56e2e8a4d0e4cdc2df9efd36bc71", "125a8a531a3a740654c9e75bbefa7beb");
///iOS 获取native精度类型
if (Platform.isIOS) {
requestAccuracyAuthorization();
}
// if (Platform.isIOS) {
// requestAccuracyAuthorization();
// }
///注册定位结果监听
_locationListener = _locationPlugin.onLocationChanged().listen((Map<String, Object> result) {
......
<!DOCTYPE html>
<html>
<head>
<!--
If you are serving your web app in a path other than the root, change the
href value below to reflect the base path you are serving from.
The path provided below has to start and end with a slash "/" in order for
it to work correctly.
For more details:
* https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base
This is a placeholder for base href that will be replaced by the value of
the `--base-href` argument provided to `flutter build`.
-->
<base href="$FLUTTER_BASE_HREF">
<meta charset="UTF-8">
<meta content="IE=Edge" http-equiv="X-UA-Compatible">
<meta name="description" content="Demonstrates how to use the test_web_plugin plugin.">
<!-- iOS meta tags & icons -->
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<meta name="apple-mobile-web-app-title" content="test_web_plugin_example">
<link rel="apple-touch-icon" href="icons/Icon-192.png">
<!-- Favicon -->
<link rel="icon" type="image/png" href="favicon.png"/>
<title>test_web_plugin_example</title>
<link rel="manifest" href="manifest.json">
<script>
// The value below is injected by flutter build, do not touch.
const serviceWorkerVersion = null;
</script>
<!-- This script adds the flutter initialization JS code -->
<script src="flutter.js" defer></script>
</head>
<body>
<script>
window.addEventListener('load', function(ev) {
// Download main.dart.js
_flutter.loader.loadEntrypoint({
serviceWorker: {
serviceWorkerVersion: serviceWorkerVersion,
},
onEntrypointLoaded: function(engineInitializer) {
engineInitializer.initializeEngine().then(function(appRunner) {
appRunner.runApp();
});
}
});
});
</script>
</body>
</html>
{
"name": "test_web_plugin_example",
"short_name": "test_web_plugin_example",
"start_url": ".",
"display": "standalone",
"background_color": "#0175C2",
"theme_color": "#0175C2",
"description": "Demonstrates how to use the test_web_plugin plugin.",
"orientation": "portrait-primary",
"prefer_related_applications": false,
"icons": [
{
"src": "icons/Icon-192.png",
"sizes": "192x192",
"type": "image/png"
},
{
"src": "icons/Icon-512.png",
"sizes": "512x512",
"type": "image/png"
},
{
"src": "icons/Icon-maskable-192.png",
"sizes": "192x192",
"type": "image/png",
"purpose": "maskable"
},
{
"src": "icons/Icon-maskable-512.png",
"sizes": "512x512",
"type": "image/png",
"purpose": "maskable"
}
]
}
import 'dart:async';
import 'dart:io';
import 'package:flutter/services.dart';
import 'amap_location_option.dart';
import 'amap_location_plugin_platform_interface.dart';
///高德定位Flutter插件入口类
class AMapFlutterLocation {
static const String _CHANNEL_METHOD_LOCATION = "amap_flutter_location";
static const String _CHANNEL_STREAM_LOCATION = "amap_flutter_location_stream";
static const MethodChannel _methodChannel =
const MethodChannel(_CHANNEL_METHOD_LOCATION);
static const EventChannel _eventChannel =
const EventChannel(_CHANNEL_STREAM_LOCATION);
static Stream<Map<String, Object>> _onLocationChanged = _eventChannel
.receiveBroadcastStream()
.asBroadcastStream()
.map<Map<String, Object>>((element) => element.cast<String, Object>());
StreamController<Map<String, Object>>? _receiveStream;
StreamSubscription<Map<String, Object>>? _subscription;
String? _pluginKey;
/// 适配iOS 14定位新特性,只在iOS平台有效
Future<AMapAccuracyAuthorization> getSystemAccuracyAuthorization() async {
int result = -1;
if (Platform.isIOS) {
result = await _methodChannel.invokeMethod(
"getSystemAccuracyAuthorization", {'pluginKey': _pluginKey});
}
if (result == 0) {
return AMapAccuracyAuthorization.AMapAccuracyAuthorizationFullAccuracy;
} else if (result == 1) {
return AMapAccuracyAuthorization.AMapAccuracyAuthorizationReducedAccuracy;
}
return AMapAccuracyAuthorization.AMapAccuracyAuthorizationInvalid;
final result = await AmapLocationPluginPlatform.instance
.getSystemAccuracyAuthorization();
return result;
}
///初始化
/// 初始化
AMapFlutterLocation() {
_pluginKey = DateTime.now().millisecondsSinceEpoch.toString();
AmapLocationPluginPlatform.instance.initKey();
}
///开始定位
/// 开始定位
void startLocation() {
_methodChannel.invokeMethod('startLocation', {'pluginKey': _pluginKey});
return;
AmapLocationPluginPlatform.instance.startLocation();
}
///停止定位
/// 停止定位
void stopLocation() {
_methodChannel.invokeMethod('stopLocation', {'pluginKey': _pluginKey});
AmapLocationPluginPlatform.instance.stopLocation();
return;
}
///计算2点之间的距离
Future<double> calculateDistance(double lat1, double lon1, double lat2, double lon2) async {
var result = await _methodChannel.invokeMethod<double>('calculateDistance', {'lat1': lat1, 'lng1': lon1, 'lat2': lat2, 'lng2': lon2});
return result!;
/// 计算2点之间的距离
Future<double> calculateDistance(
double lat1, double lon1, double lat2, double lon2) async {
var result = await AmapLocationPluginPlatform.instance
.calculateDistance(lat1, lon1, lat2, lon2);
return result;
}
///设置Android和iOS的apikey,建议在weigdet初始化时设置<br>
///apiKey的申请请参考高德开放平台官网<br>
///Android端: https://lbs.amap.com/api/android-location-sdk/guide/create-project/get-key<br>
///iOS端: https://lbs.amap.com/api/ios-location-sdk/guide/create-project/get-key<br>
///[androidKey] Android平台的key<br>
///[iosKey] ios平台的key<br>
/// 设置Android和iOS的apikey,建议在weigdet初始化时设置<br>
/// apiKey的申请请参考高德开放平台官网<br>
/// Android端: https://lbs.amap.com/api/android-location-sdk/guide/create-project/get-key<br>
/// iOS端: https://lbs.amap.com/api/ios-location-sdk/guide/create-project/get-key<br>
/// [androidKey] Android平台的key<br>
/// [iosKey] ios平台的key<br>
static void setApiKey(String androidKey, String iosKey) {
_methodChannel
.invokeMethod('setApiKey', {'android': androidKey, 'ios': iosKey});
AmapLocationPluginPlatform.instance.setApiKey(androidKey, iosKey);
}
/// 设置定位参数
void setLocationOption(AMapLocationOption locationOption) {
Map option = locationOption.getOptionsMap();
option['pluginKey'] = _pluginKey;
_methodChannel.invokeMethod('setLocationOption', option);
// Map option = locationOption.getOptionsMap();
// option['pluginKey'] = _pluginKey;
AmapLocationPluginPlatform.instance.setLocationOption(locationOption);
}
///销毁定位
/// 销毁定位
void destroy() {
_methodChannel.invokeListMethod('destroy', {'pluginKey': _pluginKey});
if (_subscription != null) {
_receiveStream?.close();
_subscription?.cancel();
_receiveStream = null;
_subscription = null;
}
AmapLocationPluginPlatform.instance.destroy();
}
///定位结果回调
///
///定位结果以map的形式透出,其中包含的key已经含义如下:
///
/// `callbackTime`:回调时间,格式为"yyyy-MM-dd HH:mm:ss"
///
/// `locationTime`:定位时间, 格式为"yyyy-MM-dd HH:mm:ss"
///
/// `locationType`: 定位类型, 具体类型可以参考https://lbs.amap.com/api/android-location-sdk/guide/utilities/location-type
///
/// `latitude`:纬度
///
/// `longitude`:精度
///
/// `accuracy`:精确度
///
/// `altitude`:海拔, android上只有locationType==1时才会有值
///
/// `bearing`: 角度,android上只有locationType==1时才会有值
///
/// `speed`:速度, android上只有locationType==1时才会有值
///
/// `country`: 国家,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `province`: 省,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `city`: 城市,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `district`: 城镇(区),android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `street`: 街道,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `streetNumber`: 门牌号,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `cityCode`: 城市编码,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `adCode`: 区域编码, android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `address`: 地址信息, android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `description`: 位置语义, android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `errorCode`: 错误码,当定位失败时才会返回对应的错误码, 具体错误请参考:https://lbs.amap.com/api/android-location-sdk/guide/utilities/errorcode
///
/// `errorInfo`: 错误信息, 当定位失败时才会返回
/// 定位结果回调
Stream<Map<String, Object>> onLocationChanged() {
if (_receiveStream == null) {
_receiveStream = StreamController();
_subscription = _onLocationChanged.listen((Map<String, Object> event) {
if (event['pluginKey'] == _pluginKey) {
Map<String, Object> newEvent = Map<String, Object>.of(event);
newEvent.remove('pluginKey');
_receiveStream?.add(newEvent);
}
},onError: (Object error) {
print('onLocationChanged error: $error');
_receiveStream?.addError(error);
},onDone: () {
print('onLocationChanged done');
_receiveStream?.close();
});
}
return _receiveStream!.stream;
final result = AmapLocationPluginPlatform.instance.onLocationChanged();
return result;
}
/// 设置是否已经包含高德隐私政策并弹窗展示显示用户查看,如果未包含或者没有弹窗展示,高德定位SDK将不会工作<br>
......@@ -161,8 +71,7 @@ class AMapFlutterLocation {
/// [hasContains] 隐私声明中是否包含高德隐私政策说明<br>
/// [hasShow] 隐私权政策是否弹窗展示告知用户<br>
static void updatePrivacyShow(bool hasContains, bool hasShow) {
_methodChannel
.invokeMethod('updatePrivacyStatement', {'hasContains': hasContains, 'hasShow': hasShow});
AmapLocationPluginPlatform.instance.updatePrivacyShow(hasContains, hasShow);
}
/// 设置是否已经取得用户同意,如果未取得用户同意,高德定位SDK将不会工作<br>
......@@ -170,7 +79,6 @@ class AMapFlutterLocation {
/// <b>必须保证在调用定位功能之前调用, 建议首次启动App时弹出《隐私政策》并取得用户同意</b><br>
/// [hasAgree] 隐私权政策是否已经取得用户同意<br>
static void updatePrivacyAgree(bool hasAgree) {
_methodChannel
.invokeMethod('updatePrivacyStatement', {'hasAgree': hasAgree});
AmapLocationPluginPlatform.instance.updatePrivacyAgree(hasAgree);
}
}
import 'dart:async';
import 'dart:io';
import 'package:flutter/services.dart';
import 'amap_location_option.dart';
import 'amap_location_plugin_platform_interface.dart';
/// 通道方法
class AmapLocationPluginMethodChannel extends AmapLocationPluginPlatform {
static const String _CHANNEL_METHOD_LOCATION = "amap_flutter_location";
static const String _CHANNEL_STREAM_LOCATION = "amap_flutter_location_stream";
static const MethodChannel _methodChannel =
const MethodChannel(_CHANNEL_METHOD_LOCATION);
static const EventChannel _eventChannel =
const EventChannel(_CHANNEL_STREAM_LOCATION);
static Stream<Map<String, Object>> _onLocationChanged = _eventChannel
.receiveBroadcastStream()
.asBroadcastStream()
.map<Map<String, Object>>((element) => element.cast<String, Object>());
StreamController<Map<String, Object>>? _receiveStream;
StreamSubscription<Map<String, Object>>? _subscription;
String? _pluginKey;
/// 初始化key
void initKey() {
_pluginKey = DateTime.now().millisecondsSinceEpoch.toString();
}
/// 适配iOS 14定位新特性,只在iOS平台有效
@override
Future<AMapAccuracyAuthorization> getSystemAccuracyAuthorization() async {
int result = -1;
if (Platform.isIOS) {
result = await _methodChannel.invokeMethod(
"getSystemAccuracyAuthorization", {'pluginKey': _pluginKey});
}
if (result == 0) {
return AMapAccuracyAuthorization.AMapAccuracyAuthorizationFullAccuracy;
} else if (result == 1) {
return AMapAccuracyAuthorization.AMapAccuracyAuthorizationReducedAccuracy;
}
return AMapAccuracyAuthorization.AMapAccuracyAuthorizationInvalid;
}
/// 开始定位
void startLocation() {
_methodChannel.invokeMethod('startLocation', {'pluginKey': _pluginKey});
}
/// 停止定位
void stopLocation() {
_methodChannel.invokeMethod('stopLocation', {'pluginKey': _pluginKey});
return;
}
///计算2点之间的距离
Future<double> calculateDistance(
double lat1, double lon1, double lat2, double lon2) async {
var result = await _methodChannel.invokeMethod<double>('calculateDistance',
{'lat1': lat1, 'lng1': lon1, 'lat2': lat2, 'lng2': lon2});
return result ?? 0.0;
}
///设置Android和iOS的apikey,建议在weigdet初始化时设置<br>
///apiKey的申请请参考高德开放平台官网<br>
///Android端: https://lbs.amap.com/api/android-location-sdk/guide/create-project/get-key<br>
///iOS端: https://lbs.amap.com/api/ios-location-sdk/guide/create-project/get-key<br>
///[androidKey] Android平台的key<br>
///[iosKey] ios平台的key<br>
void setApiKey(String androidKey, String iosKey) {
_methodChannel
.invokeMethod('setApiKey', {'android': androidKey, 'ios': iosKey});
}
/// 设置定位参数
void setLocationOption(AMapLocationOption locationOption) {
Map option = locationOption.getOptionsMap();
option['pluginKey'] = _pluginKey;
_methodChannel.invokeMethod('setLocationOption', option);
}
/// 销毁定位
void destroy() {
_methodChannel.invokeListMethod('destroy', {'pluginKey': _pluginKey});
if (_subscription != null) {
_receiveStream?.close();
_subscription?.cancel();
_receiveStream = null;
_subscription = null;
}
}
///定位结果回调
///
///定位结果以map的形式透出,其中包含的key已经含义如下:
///
/// `callbackTime`:回调时间,格式为"yyyy-MM-dd HH:mm:ss"
///
/// `locationTime`:定位时间, 格式为"yyyy-MM-dd HH:mm:ss"
///
/// `locationType`: 定位类型, 具体类型可以参考https://lbs.amap.com/api/android-location-sdk/guide/utilities/location-type
///
/// `latitude`:纬度
///
/// `longitude`:精度
///
/// `accuracy`:精确度
///
/// `altitude`:海拔, android上只有locationType==1时才会有值
///
/// `bearing`: 角度,android上只有locationType==1时才会有值
///
/// `speed`:速度, android上只有locationType==1时才会有值
///
/// `country`: 国家,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `province`: 省,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `city`: 城市,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `district`: 城镇(区),android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `street`: 街道,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `streetNumber`: 门牌号,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `cityCode`: 城市编码,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `adCode`: 区域编码, android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `address`: 地址信息, android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `description`: 位置语义, android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `errorCode`: 错误码,当定位失败时才会返回对应的错误码, 具体错误请参考:https://lbs.amap.com/api/android-location-sdk/guide/utilities/errorcode
///
/// `errorInfo`: 错误信息, 当定位失败时才会返回
Stream<Map<String, Object>> onLocationChanged() {
if (_receiveStream == null) {
_receiveStream = StreamController();
_subscription = _onLocationChanged.listen((Map<String, Object> event) {
if (event['pluginKey'] == _pluginKey) {
Map<String, Object> newEvent = Map<String, Object>.of(event);
newEvent.remove('pluginKey');
_receiveStream?.add(newEvent);
}
}, onError: (Object error) {
print('onLocationChanged error: $error');
_receiveStream?.addError(error);
}, onDone: () {
print('onLocationChanged done');
_receiveStream?.close();
});
}
return _receiveStream!.stream;
}
/// 设置是否已经包含高德隐私政策并弹窗展示显示用户查看,如果未包含或者没有弹窗展示,高德定位SDK将不会工作<br>
/// 高德SDK合规使用方案请参考官网地址:https://lbs.amap.com/news/sdkhgsy<br>
/// <b>必须保证在调用定位功能之前调用, 建议首次启动App时弹出《隐私政策》并取得用户同意</b><br>
/// 高德SDK合规使用方案请参考官网地址:https://lbs.amap.com/news/sdkhgsy
/// [hasContains] 隐私声明中是否包含高德隐私政策说明<br>
/// [hasShow] 隐私权政策是否弹窗展示告知用户<br>
void updatePrivacyShow(bool hasContains, bool hasShow) {
_methodChannel.invokeMethod('updatePrivacyStatement',
{'hasContains': hasContains, 'hasShow': hasShow});
}
/// 设置是否已经取得用户同意,如果未取得用户同意,高德定位SDK将不会工作<br>
/// 高德SDK合规使用方案请参考官网地址:https://lbs.amap.com/news/sdkhgsy<br>
/// <b>必须保证在调用定位功能之前调用, 建议首次启动App时弹出《隐私政策》并取得用户同意</b><br>
/// [hasAgree] 隐私权政策是否已经取得用户同意<br>
void updatePrivacyAgree(bool hasAgree) {
_methodChannel
.invokeMethod('updatePrivacyStatement', {'hasAgree': hasAgree});
}
}
import 'package:plugin_platform_interface/plugin_platform_interface.dart';
import 'amap_location_option.dart';
import 'amap_location_plugin_method_channel.dart';
abstract class AmapLocationPluginPlatform extends PlatformInterface {
/// Constructs
AmapLocationPluginPlatform() : super(token: _token);
static final Object _token = Object();
static AmapLocationPluginPlatform _instance =
AmapLocationPluginMethodChannel();
static AmapLocationPluginPlatform get instance => _instance;
static set instance(AmapLocationPluginPlatform instance) {
PlatformInterface.verifyToken(instance, _token);
_instance = instance;
}
/// 初始化key
void initKey() {
throw UnimplementedError('initKey() has not been implemented.');
}
/// iOS 14中系统的定位类型信息
Future<AMapAccuracyAuthorization> getSystemAccuracyAuthorization() {
throw UnimplementedError(
'getSystemAccuracyAuthorization() has not been implemented.');
}
/// 开始定位
void startLocation() {
throw UnimplementedError('startLocation() has not been implemented.');
}
/// 停止定位
void stopLocation() {
throw UnimplementedError('stopLocation() has not been implemented.');
}
/// 计算2点之间的距离
Future<double> calculateDistance(
double lat1, double lon1, double lat2, double lon2) {
throw UnimplementedError('calculateDistance() has not been implemented.');
}
///设置Android和iOS的apikey,建议在weigdet初始化时设置<br>
///apiKey的申请请参考高德开放平台官网<br>
///Android端: https://lbs.amap.com/api/android-location-sdk/guide/create-project/get-key<br>
///iOS端: https://lbs.amap.com/api/ios-location-sdk/guide/create-project/get-key<br>
///[androidKey] Android平台的key<br>
///[iosKey] ios平台的key<br>
void setApiKey(String androidKey, String iosKey) {
throw UnimplementedError('setApiKey() has not been implemented.');
}
/// 设置定位参数
void setLocationOption(AMapLocationOption locationOption) {
throw UnimplementedError('setLocationOption() has not been implemented.');
}
/// 销毁定位
void destroy() {
throw UnimplementedError('destroy() has not been implemented.');
}
///定位结果回调
///
///定位结果以map的形式透出,其中包含的key已经含义如下:
///
/// `callbackTime`:回调时间,格式为"yyyy-MM-dd HH:mm:ss"
///
/// `locationTime`:定位时间, 格式为"yyyy-MM-dd HH:mm:ss"
///
/// `locationType`: 定位类型, 具体类型可以参考https://lbs.amap.com/api/android-location-sdk/guide/utilities/location-type
///
/// `latitude`:纬度
///
/// `longitude`:精度
///
/// `accuracy`:精确度
///
/// `altitude`:海拔, android上只有locationType==1时才会有值
///
/// `bearing`: 角度,android上只有locationType==1时才会有值
///
/// `speed`:速度, android上只有locationType==1时才会有值
///
/// `country`: 国家,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `province`: 省,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `city`: 城市,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `district`: 城镇(区),android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `street`: 街道,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `streetNumber`: 门牌号,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `cityCode`: 城市编码,android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `adCode`: 区域编码, android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `address`: 地址信息, android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `description`: 位置语义, android上只有通过[AMapLocationOption.needAddress]为true时才有可能返回值
///
/// `errorCode`: 错误码,当定位失败时才会返回对应的错误码, 具体错误请参考:https://lbs.amap.com/api/android-location-sdk/guide/utilities/errorcode
///
/// `errorInfo`: 错误信息, 当定位失败时才会返回
Stream<Map<String, Object>> onLocationChanged() {
throw UnimplementedError('onLocationChanged() has not been implemented.');
}
/// 设置是否已经包含高德隐私政策并弹窗展示显示用户查看,如果未包含或者没有弹窗展示,高德定位SDK将不会工作<br>
/// 高德SDK合规使用方案请参考官网地址:https://lbs.amap.com/news/sdkhgsy<br>
/// <b>必须保证在调用定位功能之前调用, 建议首次启动App时弹出《隐私政策》并取得用户同意</b><br>
/// 高德SDK合规使用方案请参考官网地址:https://lbs.amap.com/news/sdkhgsy
/// [hasContains] 隐私声明中是否包含高德隐私政策说明<br>
/// [hasShow] 隐私权政策是否弹窗展示告知用户<br>
void updatePrivacyShow(bool hasContains, bool hasShow) {
throw UnimplementedError('updatePrivacyShow() has not been implemented.');
}
/// 设置是否已经取得用户同意,如果未取得用户同意,高德定位SDK将不会工作<br>
/// 高德SDK合规使用方案请参考官网地址:https://lbs.amap.com/news/sdkhgsy<br>
/// <b>必须保证在调用定位功能之前调用, 建议首次启动App时弹出《隐私政策》并取得用户同意</b><br>
/// [hasAgree] 隐私权政策是否已经取得用户同意<br>
void updatePrivacyAgree(bool hasAgree) {
throw UnimplementedError('updatePrivacyAgree() has not been implemented.');
}
}
// In order to *not* need this ignore, consider extracting the "web" version
// of your plugin as a separate package, instead of inlining it in the same
// package as the core of your plugin.
// ignore: avoid_web_libraries_in_flutter
import 'dart:html' as html show window;
import 'package:amap_flutter_location/amap_location_plugin_platform_interface.dart';
import 'package:flutter_web_plugins/flutter_web_plugins.dart';
/// A web implementation of the TestWebPluginPlatform of the TestWebPlugin plugin.
class AmapLocationPluginWeb extends AmapLocationPluginPlatform {
/// Constructs a AmapLocationPluginWeb
AmapLocationPluginWeb();
static void registerWith(Registrar registrar) {
AmapLocationPluginPlatform.instance = AmapLocationPluginWeb();
}
}
import 'dart:io';
import 'package:flutter/foundation.dart';
/// 平台信息
class PlatformUtils {
static bool _isWeb() {
return kIsWeb == true;
}
static bool _isAndroid() {
return _isWeb() ? false : Platform.isAndroid;
}
static bool _isIOS() {
return _isWeb() ? false : Platform.isIOS;
}
static bool get isWeb => _isWeb();
static bool get isAndroid => _isAndroid();
static bool get isIOS => _isIOS();
}
......@@ -10,6 +10,9 @@ environment:
dependencies:
flutter:
sdk: flutter
flutter_web_plugins:
sdk: flutter
plugin_platform_interface: ^2.0.2
dev_dependencies:
flutter_test:
......@@ -31,6 +34,9 @@ flutter:
pluginClass: AMapFlutterLocationPlugin
ios:
pluginClass: AMapFlutterLocationPlugin
web:
pluginClass: AmapLocationPluginWeb
fileName: amap_location_plugin_web.dart
# To add assets to your plugin package, add an assets section, like this:
# assets:
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论