expo-gaode-map-navigation 1.1.0 → 1.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/ExpoGaodeMapNaviView.js +0 -10
- package/build/map/ExpoGaodeMapModule.js +5 -5
- package/build/map/components/overlays/Cluster.js +0 -10
- package/build/map/components/overlays/HeatMap.js +0 -10
- package/build/map/components/overlays/MultiPoint.js +0 -10
- package/build/map/index.d.ts +1 -1
- package/build/map/index.js +3 -1
- package/package.json +15 -6
- package/package.json.backup +0 -47
- package/plugin/README.md +0 -52
- package/plugin/src/withGaodeMap.ts +0 -231
- package/plugin/tsconfig.tsbuildinfo +0 -1
- package/src/ExpoGaodeMapNaviView.tsx +0 -94
- package/src/ExpoGaodeMapNavigation.types.ts +0 -3
- package/src/ExpoGaodeMapNavigationModule.ts +0 -11
- package/src/index.ts +0 -262
- package/src/map/ExpoGaodeMap.types.ts +0 -46
- package/src/map/ExpoGaodeMapModule.ts +0 -315
- package/src/map/ExpoGaodeMapView.tsx +0 -120
- package/src/map/components/overlays/Circle.tsx +0 -20
- package/src/map/components/overlays/Cluster.tsx +0 -26
- package/src/map/components/overlays/HeatMap.tsx +0 -27
- package/src/map/components/overlays/Marker.tsx +0 -88
- package/src/map/components/overlays/MultiPoint.tsx +0 -27
- package/src/map/components/overlays/Polygon.tsx +0 -19
- package/src/map/components/overlays/Polyline.tsx +0 -19
- package/src/map/components/overlays/index.ts +0 -7
- package/src/map/index.ts +0 -37
- package/src/map/types/common.types.ts +0 -126
- package/src/map/types/index.ts +0 -55
- package/src/map/types/location.types.ts +0 -368
- package/src/map/types/map-view.types.ts +0 -281
- package/src/map/types/overlays.types.ts +0 -404
- package/src/map/utils/EventManager.ts +0 -23
- package/src/map/utils/ModuleLoader.ts +0 -115
- package/src/types/coordinates.types.ts +0 -25
- package/src/types/independent.types.ts +0 -288
- package/src/types/index.ts +0 -5
- package/src/types/naviview.types.ts +0 -330
- package/src/types/route.types.ts +0 -305
package/src/index.ts
DELETED
|
@@ -1,262 +0,0 @@
|
|
|
1
|
-
import ExpoGaodeMapNavigationModule from './ExpoGaodeMapNavigationModule';
|
|
2
|
-
|
|
3
|
-
// 重新导出地图模块的所有内容
|
|
4
|
-
export * from './map';
|
|
5
|
-
import {
|
|
6
|
-
RouteType,
|
|
7
|
-
DriveStrategy,
|
|
8
|
-
WalkStrategy,
|
|
9
|
-
RideStrategy,
|
|
10
|
-
TruckSize,
|
|
11
|
-
TravelStrategy,
|
|
12
|
-
} from './types';
|
|
13
|
-
import type {
|
|
14
|
-
NaviPoint,
|
|
15
|
-
RouteOptions,
|
|
16
|
-
DriveRouteOptions,
|
|
17
|
-
WalkRouteOptions,
|
|
18
|
-
RideRouteOptions,
|
|
19
|
-
EBikeRouteOptions,
|
|
20
|
-
TruckRouteOptions,
|
|
21
|
-
RouteResult,
|
|
22
|
-
DriveRouteResult,
|
|
23
|
-
IndependentRouteResult,
|
|
24
|
-
IndependentDriveRouteOptions,
|
|
25
|
-
IndependentTruckRouteOptions,
|
|
26
|
-
IndependentWalkRouteOptions,
|
|
27
|
-
IndependentRideRouteOptions,
|
|
28
|
-
SelectIndependentRouteOptions,
|
|
29
|
-
StartNaviWithIndependentPathOptions,
|
|
30
|
-
ClearIndependentRouteOptions,
|
|
31
|
-
MotorcycleRouteOptions,
|
|
32
|
-
IndependentMotorcycleRouteOptions,
|
|
33
|
-
} from './types';
|
|
34
|
-
|
|
35
|
-
// 导出官方导航界面组件
|
|
36
|
-
export { NaviView, type NaviViewRef } from './ExpoGaodeMapNaviView';
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* 初始化导航模块(可选)
|
|
42
|
-
*/
|
|
43
|
-
export function initNavigation(): void {
|
|
44
|
-
ExpoGaodeMapNavigationModule.initNavigation();
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* 销毁所有路径计算器实例
|
|
49
|
-
* 用于页面切换时释放资源,避免"Another route calculation is in progress"错误
|
|
50
|
-
*/
|
|
51
|
-
export function destroyAllCalculators(): void {
|
|
52
|
-
ExpoGaodeMapNavigationModule.destroyAllCalculators();
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* 路径规划(通用方法)
|
|
57
|
-
* 注意:公交路径规划暂未实现
|
|
58
|
-
*/
|
|
59
|
-
export async function calculateRoute(
|
|
60
|
-
options: RouteOptions
|
|
61
|
-
): Promise<RouteResult | DriveRouteResult> {
|
|
62
|
-
// 根据传入的选项类型调用对应的方法
|
|
63
|
-
if ('carNumber' in options || 'avoidPolygons' in options) {
|
|
64
|
-
// 驾车或摩托车
|
|
65
|
-
return await calculateDriveRoute(options as DriveRouteOptions);
|
|
66
|
-
} else if ('size' in options) {
|
|
67
|
-
// 货车
|
|
68
|
-
return await calculateTruckRoute(options as TruckRouteOptions);
|
|
69
|
-
} else if ('multiple' in options || 'travelStrategy' in options) {
|
|
70
|
-
// 步行或骑行
|
|
71
|
-
if ('usePoi' in options) {
|
|
72
|
-
// 电动车
|
|
73
|
-
return await calculateEBikeRoute(options as EBikeRouteOptions);
|
|
74
|
-
} else if ((options as any).strategy === 0 || (options as any).strategy === 1) {
|
|
75
|
-
// 骑行
|
|
76
|
-
return await calculateRideRoute(options as RideRouteOptions);
|
|
77
|
-
} else {
|
|
78
|
-
// 步行
|
|
79
|
-
return await calculateWalkRoute(options as WalkRouteOptions);
|
|
80
|
-
}
|
|
81
|
-
} else {
|
|
82
|
-
// 默认当作驾车处理
|
|
83
|
-
return await calculateDriveRoute(options as DriveRouteOptions);
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
/**
|
|
88
|
-
* 驾车路径规划
|
|
89
|
-
*/
|
|
90
|
-
export async function calculateDriveRoute(
|
|
91
|
-
options: DriveRouteOptions
|
|
92
|
-
): Promise<DriveRouteResult> {
|
|
93
|
-
return await ExpoGaodeMapNavigationModule.calculateDriveRoute(options);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
/**
|
|
97
|
-
* 步行路径规划
|
|
98
|
-
*/
|
|
99
|
-
export async function calculateWalkRoute(
|
|
100
|
-
options: WalkRouteOptions
|
|
101
|
-
): Promise<RouteResult> {
|
|
102
|
-
return await ExpoGaodeMapNavigationModule.calculateWalkRoute(options);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
/**
|
|
106
|
-
* 骑行路径规划
|
|
107
|
-
*/
|
|
108
|
-
export async function calculateRideRoute(
|
|
109
|
-
options: RideRouteOptions
|
|
110
|
-
): Promise<RouteResult> {
|
|
111
|
-
return await ExpoGaodeMapNavigationModule.calculateRideRoute(options);
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
/**
|
|
115
|
-
* 骑行电动车路径规划
|
|
116
|
-
*/
|
|
117
|
-
export async function calculateEBikeRoute(
|
|
118
|
-
options: EBikeRouteOptions
|
|
119
|
-
): Promise<RouteResult> {
|
|
120
|
-
return await (ExpoGaodeMapNavigationModule as any).calculateEBikeRoute(options);
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
/**
|
|
124
|
-
* 货车路径规划
|
|
125
|
-
*/
|
|
126
|
-
export async function calculateTruckRoute(
|
|
127
|
-
options: TruckRouteOptions
|
|
128
|
-
): Promise<DriveRouteResult> {
|
|
129
|
-
return await ExpoGaodeMapNavigationModule.calculateTruckRoute(options);
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
/**
|
|
133
|
-
* 摩托车路径规划(车类型为 11,支持传入排量)
|
|
134
|
-
*/
|
|
135
|
-
export async function calculateMotorcycleRoute(
|
|
136
|
-
options: MotorcycleRouteOptions
|
|
137
|
-
): Promise<DriveRouteResult> {
|
|
138
|
-
return await ExpoGaodeMapNavigationModule.calculateMotorcycleRoute(options as any);
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
/**
|
|
142
|
-
* 独立路径规划(不会影响当前导航;适合路线预览/行前选路)
|
|
143
|
-
*/
|
|
144
|
-
export async function independentDriveRoute(
|
|
145
|
-
options: IndependentDriveRouteOptions
|
|
146
|
-
): Promise<IndependentRouteResult> {
|
|
147
|
-
return await ExpoGaodeMapNavigationModule.independentDriveRoute(options);
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
export async function independentTruckRoute(
|
|
151
|
-
options: IndependentTruckRouteOptions
|
|
152
|
-
): Promise<IndependentRouteResult> {
|
|
153
|
-
return await ExpoGaodeMapNavigationModule.independentTruckRoute(options);
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
export async function independentWalkRoute(
|
|
157
|
-
options: IndependentWalkRouteOptions
|
|
158
|
-
): Promise<IndependentRouteResult> {
|
|
159
|
-
return await ExpoGaodeMapNavigationModule.independentWalkRoute(options);
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
export async function independentRideRoute(
|
|
163
|
-
options: IndependentRideRouteOptions
|
|
164
|
-
): Promise<IndependentRouteResult> {
|
|
165
|
-
return await ExpoGaodeMapNavigationModule.independentRideRoute(options);
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
/**
|
|
169
|
-
* 独立摩托车路径规划(不干扰当前导航)
|
|
170
|
-
*/
|
|
171
|
-
export async function independentMotorcycleRoute(
|
|
172
|
-
options: IndependentMotorcycleRouteOptions
|
|
173
|
-
): Promise<IndependentRouteResult> {
|
|
174
|
-
return await ExpoGaodeMapNavigationModule.independentMotorcycleRoute(options as any);
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
/**
|
|
178
|
-
* 独立路径组:选主路线
|
|
179
|
-
*/
|
|
180
|
-
export async function selectIndependentRoute(
|
|
181
|
-
options: SelectIndependentRouteOptions
|
|
182
|
-
): Promise<boolean> {
|
|
183
|
-
return await ExpoGaodeMapNavigationModule.selectIndependentRoute(options);
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
/**
|
|
187
|
-
* 独立路径组:使用指定路线启动导航
|
|
188
|
-
*/
|
|
189
|
-
export async function startNaviWithIndependentPath(
|
|
190
|
-
options: StartNaviWithIndependentPathOptions
|
|
191
|
-
): Promise<boolean> {
|
|
192
|
-
return await ExpoGaodeMapNavigationModule.startNaviWithIndependentPath(options);
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
/**
|
|
196
|
-
* 独立路径组:清理
|
|
197
|
-
*/
|
|
198
|
-
export async function clearIndependentRoute(
|
|
199
|
-
options: ClearIndependentRouteOptions
|
|
200
|
-
): Promise<boolean> {
|
|
201
|
-
return await ExpoGaodeMapNavigationModule.clearIndependentRoute(options);
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
// 导出导航相关类型与枚举(Coordinates 从 map 模块导出)
|
|
205
|
-
export type {
|
|
206
|
-
NaviPoint,
|
|
207
|
-
RouteOptions,
|
|
208
|
-
DriveRouteOptions,
|
|
209
|
-
WalkRouteOptions,
|
|
210
|
-
RideRouteOptions,
|
|
211
|
-
EBikeRouteOptions,
|
|
212
|
-
TruckRouteOptions,
|
|
213
|
-
RouteResult,
|
|
214
|
-
DriveRouteResult,
|
|
215
|
-
IndependentRouteResult,
|
|
216
|
-
IndependentDriveRouteOptions,
|
|
217
|
-
IndependentTruckRouteOptions,
|
|
218
|
-
IndependentWalkRouteOptions,
|
|
219
|
-
IndependentRideRouteOptions,
|
|
220
|
-
SelectIndependentRouteOptions,
|
|
221
|
-
StartNaviWithIndependentPathOptions,
|
|
222
|
-
ClearIndependentRouteOptions,
|
|
223
|
-
MotorcycleRouteOptions,
|
|
224
|
-
IndependentMotorcycleRouteOptions,
|
|
225
|
-
};
|
|
226
|
-
|
|
227
|
-
export {
|
|
228
|
-
RouteType,
|
|
229
|
-
DriveStrategy,
|
|
230
|
-
WalkStrategy,
|
|
231
|
-
RideStrategy,
|
|
232
|
-
TruckSize,
|
|
233
|
-
TravelStrategy,
|
|
234
|
-
};
|
|
235
|
-
|
|
236
|
-
// 精简后的默认导出
|
|
237
|
-
export default {
|
|
238
|
-
// 初始化
|
|
239
|
-
initNavigation,
|
|
240
|
-
destroyAllCalculators,
|
|
241
|
-
|
|
242
|
-
// 路径规划
|
|
243
|
-
calculateRoute,
|
|
244
|
-
calculateDriveRoute,
|
|
245
|
-
calculateWalkRoute,
|
|
246
|
-
calculateRideRoute,
|
|
247
|
-
calculateEBikeRoute,
|
|
248
|
-
calculateTruckRoute,
|
|
249
|
-
calculateMotorcycleRoute,
|
|
250
|
-
|
|
251
|
-
// 独立路径规划
|
|
252
|
-
independentDriveRoute,
|
|
253
|
-
independentTruckRoute,
|
|
254
|
-
independentWalkRoute,
|
|
255
|
-
independentRideRoute,
|
|
256
|
-
independentMotorcycleRoute,
|
|
257
|
-
|
|
258
|
-
// 独立路径组操作
|
|
259
|
-
selectIndependentRoute,
|
|
260
|
-
startNaviWithIndependentPath,
|
|
261
|
-
clearIndependentRoute,
|
|
262
|
-
};
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 高德地图 Expo 模块类型定义
|
|
3
|
-
*
|
|
4
|
-
* 此文件定义了 Expo 模块专用的类型,包括事件类型等
|
|
5
|
-
* 其他通用类型请从 './types' 导入
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import type { Coordinates, ReGeocode } from './types';
|
|
9
|
-
|
|
10
|
-
// 重新导出所有通用类型,方便使用
|
|
11
|
-
export * from './types';
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Expo 模块事件类型
|
|
15
|
-
* 定义了原生模块可以触发的事件
|
|
16
|
-
*/
|
|
17
|
-
export type ExpoGaodeMapModuleEvents = {
|
|
18
|
-
/**
|
|
19
|
-
* 定位更新事件
|
|
20
|
-
* 当位置发生变化时触发
|
|
21
|
-
* @param location 位置信息,包含坐标和可选的逆地理编码信息
|
|
22
|
-
*/
|
|
23
|
-
onLocationUpdate: (location: Coordinates | ReGeocode) => void;
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* 方向更新事件(iOS)
|
|
27
|
-
* 当设备方向发生变化时触发
|
|
28
|
-
* @param heading 方向信息
|
|
29
|
-
*/
|
|
30
|
-
onHeadingUpdate: (heading: {
|
|
31
|
-
/** 磁北方向角度 (0-359.9) */
|
|
32
|
-
magneticHeading: number;
|
|
33
|
-
/** 真北方向角度 (0-359.9) */
|
|
34
|
-
trueHeading: number;
|
|
35
|
-
/** 方向精度 */
|
|
36
|
-
headingAccuracy: number;
|
|
37
|
-
/** X 轴原始数据 */
|
|
38
|
-
x: number;
|
|
39
|
-
/** Y 轴原始数据 */
|
|
40
|
-
y: number;
|
|
41
|
-
/** Z 轴原始数据 */
|
|
42
|
-
z: number;
|
|
43
|
-
/** 时间戳 */
|
|
44
|
-
timestamp: number;
|
|
45
|
-
}) => void;
|
|
46
|
-
};
|
|
@@ -1,315 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 高德地图原生模块
|
|
3
|
-
* 提供 SDK 初始化、定位、权限管理等功能
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import { NativeModule, requireNativeModule } from 'expo';
|
|
7
|
-
import type { ExpoGaodeMapModuleEvents } from './ExpoGaodeMap.types';
|
|
8
|
-
import type {
|
|
9
|
-
LatLng,
|
|
10
|
-
CoordinateType,
|
|
11
|
-
Coordinates,
|
|
12
|
-
ReGeocode,
|
|
13
|
-
LocationMode,
|
|
14
|
-
LocationAccuracy,
|
|
15
|
-
LocationListener,
|
|
16
|
-
} from './types';
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* SDK 配置参数
|
|
20
|
-
*/
|
|
21
|
-
export interface SDKConfig {
|
|
22
|
-
/** Android 平台的高德地图 API Key */
|
|
23
|
-
androidKey?: string;
|
|
24
|
-
/** iOS 平台的高德地图 API Key */
|
|
25
|
-
iosKey?: string;
|
|
26
|
-
/** web api key:若要使用 web-api 相关功能,建议在初始化时提供 */
|
|
27
|
-
webKey?: string;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* 权限状态
|
|
32
|
-
*/
|
|
33
|
-
export interface PermissionStatus {
|
|
34
|
-
/** 是否已授权 */
|
|
35
|
-
granted: boolean;
|
|
36
|
-
/** iOS 权限状态字符串 */
|
|
37
|
-
status?: 'notDetermined' | 'restricted' | 'denied' | 'authorizedAlways' | 'authorizedWhenInUse' | 'unknown';
|
|
38
|
-
/** Android 精确位置权限 */
|
|
39
|
-
fineLocation?: boolean;
|
|
40
|
-
/** Android 粗略位置权限 */
|
|
41
|
-
coarseLocation?: boolean;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
/**
|
|
45
|
-
* 高德地图原生模块类声明
|
|
46
|
-
*/
|
|
47
|
-
declare class ExpoGaodeMapModule extends NativeModule<ExpoGaodeMapModuleEvents> {
|
|
48
|
-
// ==================== 隐私合规管理 ====================
|
|
49
|
-
|
|
50
|
-
/**
|
|
51
|
-
* 更新隐私合规状态
|
|
52
|
-
* 必须在用户同意隐私协议后调用
|
|
53
|
-
* @param hasAgreed 用户是否已同意隐私协议
|
|
54
|
-
*/
|
|
55
|
-
updatePrivacyCompliance(hasAgreed: boolean): void;
|
|
56
|
-
|
|
57
|
-
// ==================== SDK 初始化 ====================
|
|
58
|
-
|
|
59
|
-
/**
|
|
60
|
-
* 初始化高德地图 SDK
|
|
61
|
-
* @param config SDK 配置参数,包含 Android 和 iOS 的 API Key
|
|
62
|
-
*/
|
|
63
|
-
initSDK(config: SDKConfig): void;
|
|
64
|
-
|
|
65
|
-
/**
|
|
66
|
-
* 获取高德地图 SDK 版本号
|
|
67
|
-
* @returns SDK 版本字符串
|
|
68
|
-
*/
|
|
69
|
-
getVersion(): string;
|
|
70
|
-
|
|
71
|
-
// ==================== 定位控制 ====================
|
|
72
|
-
|
|
73
|
-
/**
|
|
74
|
-
* 开始连续定位
|
|
75
|
-
* 启动后会持续接收位置更新,通过 onLocationUpdate 事件回调
|
|
76
|
-
*/
|
|
77
|
-
start(): void;
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* 停止定位
|
|
81
|
-
* 停止接收位置更新
|
|
82
|
-
*/
|
|
83
|
-
stop(): void;
|
|
84
|
-
|
|
85
|
-
/**
|
|
86
|
-
* 检查是否正在定位
|
|
87
|
-
* @returns Promise<boolean> 是否正在定位
|
|
88
|
-
*/
|
|
89
|
-
isStarted(): Promise<boolean>;
|
|
90
|
-
|
|
91
|
-
/**
|
|
92
|
-
* 获取当前位置(单次定位)
|
|
93
|
-
* @returns Promise<Coordinates | ReGeocode> 位置信息,包含坐标和可选的逆地理编码信息
|
|
94
|
-
*/
|
|
95
|
-
getCurrentLocation(): Promise<Coordinates | ReGeocode>;
|
|
96
|
-
|
|
97
|
-
/**
|
|
98
|
-
* 坐标转换
|
|
99
|
-
* 将其他坐标系的坐标转换为高德地图使用的 GCJ-02 坐标系
|
|
100
|
-
* @param coordinate 需要转换的坐标
|
|
101
|
-
* @param type 原坐标系类型
|
|
102
|
-
* @returns Promise<LatLng> 转换后的 GCJ-02 坐标
|
|
103
|
-
*/
|
|
104
|
-
coordinateConvert(coordinate: LatLng, type: CoordinateType): Promise<LatLng>;
|
|
105
|
-
|
|
106
|
-
// ==================== 定位配置 ====================
|
|
107
|
-
|
|
108
|
-
/**
|
|
109
|
-
* 设置是否返回逆地理编码信息
|
|
110
|
-
* @param isReGeocode true: 返回地址信息; false: 只返回坐标
|
|
111
|
-
*/
|
|
112
|
-
setLocatingWithReGeocode(isReGeocode: boolean): void;
|
|
113
|
-
|
|
114
|
-
/**
|
|
115
|
-
* 设置定位模式(Android)
|
|
116
|
-
* @param mode 定位模式:0-低功耗, 1-仅设备, 2-高精度
|
|
117
|
-
*/
|
|
118
|
-
setLocationMode(mode: LocationMode): void;
|
|
119
|
-
|
|
120
|
-
/**
|
|
121
|
-
* 设置定位间隔(毫秒)
|
|
122
|
-
* @param interval 定位间隔时间,单位毫秒,默认 2000ms
|
|
123
|
-
*/
|
|
124
|
-
setInterval(interval: number): void;
|
|
125
|
-
|
|
126
|
-
/**
|
|
127
|
-
* 设置是否单次定位(Android)
|
|
128
|
-
* @param isOnceLocation true: 单次定位; false: 连续定位
|
|
129
|
-
*/
|
|
130
|
-
setOnceLocation(isOnceLocation: boolean): void;
|
|
131
|
-
|
|
132
|
-
/**
|
|
133
|
-
* 设置是否使用设备传感器(Android)
|
|
134
|
-
* @param sensorEnable true: 使用传感器; false: 不使用
|
|
135
|
-
*/
|
|
136
|
-
setSensorEnable(sensorEnable: boolean): void;
|
|
137
|
-
|
|
138
|
-
/**
|
|
139
|
-
* 设置是否允许 WiFi 扫描(Android)
|
|
140
|
-
* @param wifiScan true: 允许; false: 不允许
|
|
141
|
-
*/
|
|
142
|
-
setWifiScan(wifiScan: boolean): void;
|
|
143
|
-
|
|
144
|
-
/**
|
|
145
|
-
* 设置是否 GPS 优先(Android)
|
|
146
|
-
* @param gpsFirst true: GPS 优先; false: 网络优先
|
|
147
|
-
*/
|
|
148
|
-
setGpsFirst(gpsFirst: boolean): void;
|
|
149
|
-
|
|
150
|
-
/**
|
|
151
|
-
* 设置是否等待 WiFi 列表刷新(Android)
|
|
152
|
-
* @param onceLocationLatest true: 等待; false: 不等待
|
|
153
|
-
*/
|
|
154
|
-
setOnceLocationLatest(onceLocationLatest: boolean): void;
|
|
155
|
-
|
|
156
|
-
/**
|
|
157
|
-
* 设置逆地理编码语言
|
|
158
|
-
* @param language 语言代码,如 "zh-CN", "en"
|
|
159
|
-
*/
|
|
160
|
-
setGeoLanguage(language: string): void;
|
|
161
|
-
|
|
162
|
-
/**
|
|
163
|
-
* 设置是否使用缓存策略(Android)
|
|
164
|
-
* @param locationCacheEnable true: 使用缓存; false: 不使用
|
|
165
|
-
*/
|
|
166
|
-
setLocationCacheEnable(locationCacheEnable: boolean): void;
|
|
167
|
-
|
|
168
|
-
/**
|
|
169
|
-
* 设置网络请求超时时间(Android)
|
|
170
|
-
* @param httpTimeOut 超时时间,单位毫秒
|
|
171
|
-
*/
|
|
172
|
-
setHttpTimeOut(httpTimeOut: number): void;
|
|
173
|
-
|
|
174
|
-
/**
|
|
175
|
-
* 设置期望的定位精度(iOS)
|
|
176
|
-
* @param accuracy 精度级别:0-最佳, 1-10米, 2-100米, 3-1公里, 4-3公里
|
|
177
|
-
*/
|
|
178
|
-
setDesiredAccuracy(accuracy: LocationAccuracy): void;
|
|
179
|
-
|
|
180
|
-
/**
|
|
181
|
-
* 设置定位超时时间(秒)
|
|
182
|
-
* @param timeout 超时时间,单位秒,默认 10 秒
|
|
183
|
-
*/
|
|
184
|
-
setLocationTimeout(timeout: number): void;
|
|
185
|
-
|
|
186
|
-
/**
|
|
187
|
-
* 设置逆地理编码超时时间(秒)
|
|
188
|
-
* @param timeout 超时时间,单位秒,默认 5 秒
|
|
189
|
-
*/
|
|
190
|
-
setReGeocodeTimeout(timeout: number): void;
|
|
191
|
-
|
|
192
|
-
/**
|
|
193
|
-
* 设置距离过滤器(米)(iOS)
|
|
194
|
-
* 只有移动超过指定距离才会更新位置
|
|
195
|
-
* @param distance 距离阈值,单位米
|
|
196
|
-
*/
|
|
197
|
-
setDistanceFilter(distance: number): void;
|
|
198
|
-
|
|
199
|
-
/**
|
|
200
|
-
* 设置是否自动暂停位置更新(iOS)
|
|
201
|
-
* @param pauses true: 自动暂停; false: 不暂停
|
|
202
|
-
*/
|
|
203
|
-
setPausesLocationUpdatesAutomatically(pauses: boolean): void;
|
|
204
|
-
|
|
205
|
-
/**
|
|
206
|
-
* 设置是否允许后台定位(iOS)
|
|
207
|
-
* @param allows true: 允许; false: 不允许
|
|
208
|
-
*/
|
|
209
|
-
setAllowsBackgroundLocationUpdates(allows: boolean): void;
|
|
210
|
-
|
|
211
|
-
/**
|
|
212
|
-
* 设置定位协议
|
|
213
|
-
* @param protocol 协议类型
|
|
214
|
-
*/
|
|
215
|
-
setLocationProtocol(protocol: string): void;
|
|
216
|
-
|
|
217
|
-
// ==================== 方向更新 (iOS) ====================
|
|
218
|
-
|
|
219
|
-
/**
|
|
220
|
-
* 开始更新设备方向(罗盘朝向)
|
|
221
|
-
* 通过 onHeadingUpdate 事件接收方向更新
|
|
222
|
-
* @platform ios
|
|
223
|
-
*/
|
|
224
|
-
startUpdatingHeading(): void;
|
|
225
|
-
|
|
226
|
-
/**
|
|
227
|
-
* 停止更新设备方向
|
|
228
|
-
* @platform ios
|
|
229
|
-
*/
|
|
230
|
-
stopUpdatingHeading(): void;
|
|
231
|
-
|
|
232
|
-
// ==================== 权限管理 ====================
|
|
233
|
-
|
|
234
|
-
/**
|
|
235
|
-
* 检查位置权限状态
|
|
236
|
-
* @returns Promise<PermissionStatus> 权限状态
|
|
237
|
-
*/
|
|
238
|
-
checkLocationPermission(): Promise<PermissionStatus>;
|
|
239
|
-
|
|
240
|
-
/**
|
|
241
|
-
* 请求位置权限
|
|
242
|
-
* @returns Promise<PermissionStatus> 请求后的权限状态
|
|
243
|
-
*/
|
|
244
|
-
requestLocationPermission(): Promise<PermissionStatus>;
|
|
245
|
-
|
|
246
|
-
// ==================== 便捷方法 ====================
|
|
247
|
-
|
|
248
|
-
/**
|
|
249
|
-
* 添加定位监听器(便捷方法)
|
|
250
|
-
* 封装了 addListener,提供更简洁的 API
|
|
251
|
-
* @param listener 定位回调函数
|
|
252
|
-
* @returns 订阅对象,调用 remove() 取消监听
|
|
253
|
-
*/
|
|
254
|
-
addLocationListener(listener: LocationListener): { remove: () => void };
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
// 获取原生模块实例 - 添加容错处理
|
|
258
|
-
let nativeModule: ExpoGaodeMapModule | null = null;
|
|
259
|
-
|
|
260
|
-
try {
|
|
261
|
-
nativeModule = requireNativeModule<ExpoGaodeMapModule>('NaviMap');
|
|
262
|
-
} catch (error) {
|
|
263
|
-
console.warn('NaviMap 原生模块加载失败:', error);
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
// 如果模块加载失败,创建一个空的代理对象防止崩溃
|
|
267
|
-
if (!nativeModule) {
|
|
268
|
-
console.error('NaviMap: 原生模块不可用,请检查配置');
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
// 记录最近一次 initSDK 的配置(含 webKey)
|
|
272
|
-
let _sdkConfig: SDKConfig | null = null;
|
|
273
|
-
|
|
274
|
-
// 扩展原生模块,添加便捷方法
|
|
275
|
-
const ExpoGaodeMapModuleWithHelpers = {
|
|
276
|
-
...(nativeModule || {}),
|
|
277
|
-
|
|
278
|
-
/**
|
|
279
|
-
* 初始化 SDK,并缓存配置(包含 webKey)
|
|
280
|
-
*/
|
|
281
|
-
initSDK(config: SDKConfig): void {
|
|
282
|
-
_sdkConfig = config ?? null;
|
|
283
|
-
nativeModule?.initSDK?.(config);
|
|
284
|
-
},
|
|
285
|
-
|
|
286
|
-
/**
|
|
287
|
-
* 添加定位监听器(便捷方法)
|
|
288
|
-
* 自动订阅 onLocationUpdate 事件,提供容错处理
|
|
289
|
-
* @param listener 定位回调函数
|
|
290
|
-
* @returns 订阅对象,调用 remove() 取消监听
|
|
291
|
-
* @throws 如果底层模块不可用,返回一个空操作的订阅对象
|
|
292
|
-
*/
|
|
293
|
-
addLocationListener(listener: LocationListener): { remove: () => void } {
|
|
294
|
-
// 使用可选链和空值合并,确保即使模块不可用也不会崩溃
|
|
295
|
-
return nativeModule?.addListener?.('onLocationUpdate', listener) || {
|
|
296
|
-
remove: () => {},
|
|
297
|
-
};
|
|
298
|
-
},
|
|
299
|
-
};
|
|
300
|
-
|
|
301
|
-
/**
|
|
302
|
-
* 获取最近一次 initSDK 的配置
|
|
303
|
-
*/
|
|
304
|
-
export function getSDKConfig(): SDKConfig | null {
|
|
305
|
-
return _sdkConfig;
|
|
306
|
-
}
|
|
307
|
-
|
|
308
|
-
/**
|
|
309
|
-
* 获取用于 Web API 的 webKey(若未初始化或未提供则返回 undefined)
|
|
310
|
-
*/
|
|
311
|
-
export function getWebKey(): string | undefined {
|
|
312
|
-
return _sdkConfig?.webKey;
|
|
313
|
-
}
|
|
314
|
-
|
|
315
|
-
export default ExpoGaodeMapModuleWithHelpers as ExpoGaodeMapModule;
|