提交 bba3c53a 编写于 作者: C codexu

feat: 更新定位增加坐标转换

上级 bac58ddf
import { getJSONP } from './get-jsonp'
import { loadMaps } from '../view/components/map/maps'
export const ICON_PATH_ORIGIN =
''
export const ICON_PATH_TARGET =
......@@ -38,3 +41,74 @@ export function getMapInfo () {
}
export const IS_AMAP = getMapInfo().type === MapType.AMAP
export function translateGeo (type, coords, skip) {
const mapInfo = getMapInfo()
const wgs84Map = [MapType.GOOGLE]
if (
type.toUpperCase() === 'WGS84' ||
wgs84Map.includes(mapInfo.type) ||
skip
) {
return Promise.resolve(coords)
}
if (mapInfo.type === MapType.QQ) {
return new Promise((resolve, reject) => {
getJSONP(
`https://apis.map.qq.com/jsapi?qt=translate&type=1&points=${coords.longitude},${coords.latitude}&key=${mapInfo.key}&output=jsonp&pf=jsapi&ref=jsapi`,
{
callback: 'cb'
},
res => {
if (
'detail' in res &&
'points' in res.detail &&
res.detail.points.length
) {
const location = res.detail.points[0]
resolve({
longitude: location.lng,
latitude: location.lat,
altitude: coords.altitude,
accuracy: coords.accuracy,
altitudeAccuracy: coords.altitudeAccuracy,
heading: coords.heading,
speed: coords.speed
})
} else {
reject(new Error('translate geo fail'))
}
},
() => reject(new Error('translate geo fail'))
)
})
}
if (mapInfo.type === MapType.AMAP) {
return new Promise((resolve, reject) => {
loadMaps([], () => {
window.AMap.convertFrom(
[coords.longitude, coords.latitude],
'gps',
(_, res) => {
if (res.info === 'ok' && res.locations.length) {
const { lat, lng } = res.locations[0]
resolve({
longitude: lng,
latitude: lat,
altitude: coords.altitude,
accuracy: coords.accuracy,
altitudeAccuracy: coords.altitudeAccuracy,
heading: coords.heading,
speed: coords.speed
})
} else {
reject(new Error('translate geo fail'))
}
}
)
})
})
}
}
......@@ -3,9 +3,9 @@ import {
} from '../../../helpers/get-jsonp'
import {
MapType,
getMapInfo
getMapInfo,
translateGeo
} from '../../../helpers/location'
import { loadMaps } from '../../../view/components/map/maps'
/**
* 获取定位信息
......@@ -73,62 +73,22 @@ export function getLocation ({
}
})
}).then((coords, skip) => {
const wgs84Map = [MapType.GOOGLE]
if (type.toUpperCase() === 'WGS84' || wgs84Map.includes(mapInfo.type) || skip) {
return coords
}
if (mapInfo.type === MapType.QQ) {
return new Promise((resolve) => {
getJSONP(`https://apis.map.qq.com/jsapi?qt=translate&type=1&points=${coords.longitude},${coords.latitude}&key=${mapInfo.key}&output=jsonp&pf=jsapi&ref=jsapi`, {
callback: 'cb'
}, (res) => {
if ('detail' in res && 'points' in res.detail && res.detail.points.length) {
const location = res.detail.points[0]
resolve(Object.assign({}, coords, {
longitude: location.lng,
latitude: location.lat
}))
} else {
resolve(coords)
}
}, () => resolve(coords))
translateGeo(type, coords, skip)
.then(coords => {
invoke(
callbackId,
Object.assign(coords, {
errMsg: 'getLocation:ok',
verticalAccuracy: coords.altitudeAccuracy || 0,
// 无专门水平精度,使用位置精度替代
horizontalAccuracy: coords.accuracy
})
)
})
}
if (mapInfo.type === MapType.AMAP) {
return new Promise((resolve) => {
loadMaps([], () => {
window.AMap.convertFrom(
[coords.longitude, coords.latitude],
'gps',
(_, res) => {
if (res.info === 'ok' && res.locations.length) {
const { lat, lng } = res.locations[0]
resolve(
Object.assign({}, coords, {
longitude: lng,
latitude: lat
})
)
} else {
resolve(coords)
}
}
)
.catch(error => {
invoke(callbackId, {
errMsg: 'getLocation:fail ' + error.message
})
})
}
}).then(coords => {
invoke(callbackId, Object.assign(coords, {
errMsg: 'getLocation:ok',
verticalAccuracy: coords.altitudeAccuracy || 0,
// 无专门水平精度,使用位置精度替代
horizontalAccuracy: coords.accuracy
}))
}).catch(error => {
invoke(callbackId, {
errMsg: 'getLocation:fail ' + error.message
})
})
}
import { translateGeo } from '../../../helpers/location'
const { invokeCallbackHandler: invoke } = UniServiceJSBridge
const callbackIds = []
const callbackOnErrorIds = []
......@@ -7,18 +9,27 @@ let watchId
/**
* 开始更新定位
*/
export function startLocationUpdate () {
export function startLocationUpdate ({ type = 'wgs84' }) {
if (navigator.geolocation) {
watchId = navigator.geolocation.watchPosition(
res => {
callbackIds.forEach(callbackId => {
invoke(callbackId, res.coords)
})
translateGeo(type, res.coords)
.then((coords) => {
callbackIds.forEach(callbackId => {
invoke(callbackId, coords)
})
}).catch(error => {
callbackOnErrorIds.forEach(callbackId => {
invoke(callbackId, {
errMsg: 'onLocationChange:fail' + error.message
})
})
})
},
error => {
callbackOnErrorIds.forEach(callbackId => {
invoke(callbackId, {
errMsg: 'getLocation:fail' + error.message
errMsg: 'onLocationChange:fail' + error.message
})
})
}
......@@ -26,7 +37,7 @@ export function startLocationUpdate () {
} else {
callbackOnErrorIds.forEach(callbackId => {
invoke(callbackId, {
errMsg: 'getLocation:fail device nonsupport geolocation'
errMsg: 'onLocationChange:fail device nonsupport geolocation'
})
})
}
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册