提交 07468b76 编写于 作者: Q qiang

feat(h5): chooseLocation add google maps

上级 a8b8b06e
...@@ -28,5 +28,7 @@ ...@@ -28,5 +28,7 @@
"uni.video.danmu": "Danmu", "uni.video.danmu": "Danmu",
"uni.video.volume": "Volume", "uni.video.volume": "Volume",
"uni.button.feedback.title": "feedback", "uni.button.feedback.title": "feedback",
"uni.button.feedback.send": "send" "uni.button.feedback.send": "send",
"uni.chooseLocation.search": "Find Place",
"uni.chooseLocation.cancel": "Cancel"
} }
...@@ -28,5 +28,7 @@ ...@@ -28,5 +28,7 @@
"uni.video.danmu": "Danmu", "uni.video.danmu": "Danmu",
"uni.video.volume": "Volumen", "uni.video.volume": "Volumen",
"uni.button.feedback.title": "realimentación", "uni.button.feedback.title": "realimentación",
"uni.button.feedback.send": "enviar" "uni.button.feedback.send": "enviar",
"uni.chooseLocation.search": "Encontrar",
"uni.chooseLocation.cancel": "Cancelar"
} }
...@@ -28,5 +28,7 @@ ...@@ -28,5 +28,7 @@
"uni.video.danmu": "Danmu", "uni.video.danmu": "Danmu",
"uni.video.volume": "Le Volume", "uni.video.volume": "Le Volume",
"uni.button.feedback.title": "retour d'information", "uni.button.feedback.title": "retour d'information",
"uni.button.feedback.send": "envoyer" "uni.button.feedback.send": "envoyer",
"uni.chooseLocation.search": "Trouve",
"uni.chooseLocation.cancel": "Annuler"
} }
...@@ -28,5 +28,7 @@ ...@@ -28,5 +28,7 @@
"uni.video.danmu": "弹幕", "uni.video.danmu": "弹幕",
"uni.video.volume": "音量", "uni.video.volume": "音量",
"uni.button.feedback.title": "问题反馈", "uni.button.feedback.title": "问题反馈",
"uni.button.feedback.send": "发送" "uni.button.feedback.send": "发送",
"uni.chooseLocation.search": "搜索地点",
"uni.chooseLocation.cancel": "取消"
} }
...@@ -28,5 +28,7 @@ ...@@ -28,5 +28,7 @@
"uni.video.danmu": "彈幕", "uni.video.danmu": "彈幕",
"uni.video.volume": "音量", "uni.video.volume": "音量",
"uni.button.feedback.title": "問題反饋", "uni.button.feedback.title": "問題反饋",
"uni.button.feedback.send": "發送" "uni.button.feedback.send": "發送",
"uni.chooseLocation.search": "搜索地點",
"uni.chooseLocation.cancel": "取消"
} }
<template> <template>
<div class="uni-system-choose-location"> <div class="uni-system-choose-location">
<v-uni-map <v-uni-map
v-if="latitude"
:latitude="latitude" :latitude="latitude"
:longitude="longitude" :longitude="longitude"
class="map" class="map"
show-location show-location
@regionchange="_regionchange" :libraries="['places']"
@updated="getList"
@regionchange="onRegionChange"
> >
<div class="map-location" /> <div
class="map-location"
:style="locationStyle"
/>
<div <div
class="map-move" class="map-move"
@click="_moveToLocation" @click="moveToLocation"
> >
<i>&#xec32;</i> <i>&#xec32;</i>
</div> </div>
...@@ -19,14 +23,14 @@ ...@@ -19,14 +23,14 @@
<div class="nav"> <div class="nav">
<div <div
class="nav-btn back" class="nav-btn back"
@click="_back" @click="back"
> >
<i class="uni-btn-icon">&#xe650;</i> <i class="uni-btn-icon">&#xe650;</i>
</div> </div>
<div <div
class="nav-btn confirm" class="nav-btn confirm"
:class="{ disable: !selected }" :class="{ disable: !selected }"
@click="_choose" @click="choose"
> >
<i class="uni-btn-icon">&#xe651;</i> <i class="uni-btn-icon">&#xe651;</i>
</div> </div>
...@@ -36,9 +40,9 @@ ...@@ -36,9 +40,9 @@
<v-uni-input <v-uni-input
v-model="keyword" v-model="keyword"
class="search-input" class="search-input"
placeholder="搜索地点" :placeholder="$$t('uni.chooseLocation.search')"
@focus="searching = true" @focus="searching = true"
@input="_input" @input="input"
/> />
<div <div
v-if="searching" v-if="searching"
...@@ -48,13 +52,13 @@ ...@@ -48,13 +52,13 @@
keyword = ''; keyword = '';
" "
> >
取消 {{ $$t("uni.chooseLocation.cancel") }}
</div> </div>
</div> </div>
<v-uni-scroll-view <v-uni-scroll-view
scroll-y scroll-y
class="list" class="list"
@scrolltolower="_scrolltolower" @scrolltolower="loadMore"
> >
<div <div
v-if="loading" v-if="loading"
...@@ -90,8 +94,15 @@ import { ...@@ -90,8 +94,15 @@ import {
} from 'uni-shared' } from 'uni-shared'
import { import {
getJSONP getJSONP
} from 'uni-platform/helpers/get-jsonp' } from '../../../helpers/get-jsonp'
const key = __uniConfig.qqMapKey import {
i18nMixin
} from 'uni-core/helpers/i18n'
import {
ICON_PATH_TARGET,
MapType,
getMapInfo
} from '../../../helpers/location'
export default { export default {
name: 'SystemChooseLocation', name: 'SystemChooseLocation',
...@@ -100,24 +111,32 @@ export default { ...@@ -100,24 +111,32 @@ export default {
if (distance > 100) { if (distance > 100) {
return `${distance > 1000 ? (distance / 1000).toFixed(1) + 'k' : distance.toFixed(0)}m | ` return `${distance > 1000 ? (distance / 1000).toFixed(1) + 'k' : distance.toFixed(0)}m | `
} else if (distance > 0) { } else if (distance > 0) {
return '100m内 | ' return '<100m | '
} else { } else {
return '' return ''
} }
} }
}, },
mixins: [i18nMixin],
data () { data () {
const {
latitude,
longitude
} = this.$route.query
return { return {
latitude: 0, latitude: latitude,
longitude: 0, longitude: longitude,
pageSize: 15, pageSize: 20,
pageIndex: 1, pageIndex: 1,
hasNextPage: true,
nextPage: null,
selectedIndex: -1, selectedIndex: -1,
list: [], list: [],
keyword: '', keyword: '',
searching: false, searching: false,
loading: true, loading: true,
adcode: '' adcode: '',
locationStyle: `background-image: url("${ICON_PATH_TARGET}")`
} }
}, },
computed: { computed: {
...@@ -129,50 +148,52 @@ export default { ...@@ -129,50 +148,52 @@ export default {
} }
}, },
created () { created () {
this._moveToLocation() if (!this.latitude || !this.longitude) {
this._search = debounce(() => { this.moveToLocation()
this._reset() }
this.search = debounce(() => {
this.reset()
if (this.keyword) { if (this.keyword) {
this._getList() this.getList()
} }
}, 1000) }, 1000)
this.$watch('searching', val => { this.$watch('searching', val => {
this._reset() this.reset()
if (!val) { if (!val) {
this._getList() this.getList()
} }
}) })
}, },
methods: { methods: {
_choose () { choose () {
if (this.selected) { if (this.selected) {
UniViewJSBridge.publishHandler('onChooseLocation', Object.assign({}, this.selected)) UniViewJSBridge.publishHandler('onChooseLocation', Object.assign({}, this.selected))
getApp().$router.back() getApp().$router.back()
} }
}, },
_back () { back () {
UniViewJSBridge.publishHandler('onChooseLocation', null) UniViewJSBridge.publishHandler('onChooseLocation', null)
getApp().$router.back() getApp().$router.back()
}, },
_moveToLocation () { moveToLocation () {
uni.getLocation({ uni.getLocation({
type: 'gcj02', type: 'gcj02',
success: this._move.bind(this), success: this.move.bind(this),
fail: () => { fail: () => {
this._move({ // this.move({
latitude: 39.90960456049752, // latitude: 39.90960456049752,
longitude: 116.3972282409668 // longitude: 116.3972282409668
}) // })
} }
}) })
}, },
_regionchange ({ detail: { centerLocation } }) { onRegionChange ({ detail: { centerLocation } }) {
if (centerLocation) { if (centerLocation) {
// TODO 图钉 icon 动画 // TODO 图钉 icon 动画
this._move(centerLocation) this.move(centerLocation)
} }
}, },
_pushData (array) { pushData (array) {
array.forEach(item => { array.forEach(item => {
this.list.push({ this.list.push({
name: item.title, name: item.title,
...@@ -183,48 +204,92 @@ export default { ...@@ -183,48 +204,92 @@ export default {
}) })
}) })
}, },
_getList () { getList () {
this.loading = true this.loading = true
const url = this.searching ? `https://apis.map.qq.com/ws/place/v1/search?output=jsonp&key=${key}&boundary=${this.boundary}&keyword=${this.keyword}&page_size=${this.pageSize}&page_index=${this.pageIndex}` : `https://apis.map.qq.com/ws/geocoder/v1/?output=jsonp&key=${key}&location=${this.latitude},${this.longitude}&get_poi=1&poi_options=page_size=${this.pageSize};page_index=${this.pageIndex}` const mapInfo = getMapInfo()
// TODO 列表加载失败提示 if (mapInfo.type === MapType.GOOGLE) {
getJSONP(url, { if (this.pageIndex > 1 && this.nextPage) {
callback: 'callback' this.nextPage()
}, (res) => { return
this.loading = false
if (this.searching && 'data' in res && res.data.length) {
this._pushData(res.data)
} else if ('result' in res) {
const result = res.result
this.adcode = result.ad_info ? result.ad_info.adcode : ''
if (result.pois) {
this._pushData(result.pois)
}
} }
}, () => { const service = new window.google.maps.places.PlacesService(document.createElement('div'))
this.loading = false service[this.searching ? 'textSearch' : 'nearbySearch']({
}) location: {
lat: this.latitude,
lng: this.longitude
},
query: this.keyword,
radius: 5000
}, (results, state, page) => {
this.loading = false
if (results && results.length) {
results.forEach((item) => {
this.list.push({
name: item.name || '',
address: item.vicinity || item.formatted_address || '',
distance: 0,
latitude: item.geometry.location.lat(),
longitude: item.geometry.location.lng()
})
})
}
if (page) {
if (!page.hasNextPage) {
this.hasNextPage = false
} else {
this.nextPage = () => {
page.nextPage()
}
}
}
})
} else if (mapInfo.type === MapType.QQ) {
const url = this.searching ? `https://apis.map.qq.com/ws/place/v1/search?output=jsonp&key=${mapInfo.key}&boundary=${this.boundary}&keyword=${this.keyword}&page_size=${this.pageSize}&page_index=${this.pageIndex}` : `https://apis.map.qq.com/ws/geocoder/v1/?output=jsonp&key=${mapInfo.key}&location=${this.latitude},${this.longitude}&get_poi=1&poi_options=page_size=${this.pageSize};page_index=${this.pageIndex}`
// TODO 列表加载失败提示
getJSONP(url, {
callback: 'callback'
}, (res) => {
this.loading = false
if (this.searching && 'data' in res && res.data.length) {
this.pushData(res.data)
} else if ('result' in res) {
const result = res.result
this.adcode = result.ad_info ? result.ad_info.adcode : ''
if (result.pois) {
this.pushData(result.pois)
}
if (this.list.length === this.pageSize * this.pageIndex) {
this.hasNextPage = false
}
}
}, () => {
this.loading = false
})
}
}, },
_scrolltolower () { loadMore () {
if (!this.loading && this.list.length === this.pageSize * this.pageIndex) { if (!this.loading && this.hasNextPage) {
this.pageIndex++ this.pageIndex++
this._getList() this.getList()
} }
}, },
_reset () { reset () {
this.selectedIndex = -1 this.selectedIndex = -1
this.pageIndex = 1 this.pageIndex = 1
this.hasNextPage = true
this.nextPage = null
this.list = [] this.list = []
}, },
_move ({ latitude, longitude }) { move ({ latitude, longitude }) {
this.latitude = latitude this.latitude = latitude
this.longitude = longitude this.longitude = longitude
if (!this.searching) { if (!this.searching) {
this._reset() this.reset()
this._getList() this.getList()
} }
}, },
_input () { input () {
this._search() this.search()
} }
} }
} }
...@@ -264,7 +329,6 @@ export default { ...@@ -264,7 +329,6 @@ export default {
height: 52px; height: 52px;
margin-left: -16px; margin-left: -16px;
cursor: pointer; cursor: pointer;
background-image: url("");
background-size: 100%; background-size: 100%;
} }
...@@ -373,7 +437,7 @@ export default { ...@@ -373,7 +437,7 @@ export default {
} }
.uni-system-choose-location .search-btn { .uni-system-choose-location .search-btn {
width: 2.8em; margin-left: 5px;
color: #007aff; color: #007aff;
font-size: 17px; font-size: 17px;
text-align: center; text-align: center;
......
...@@ -38,6 +38,8 @@ import { ...@@ -38,6 +38,8 @@ import {
import mapMarker from './map-marker' import mapMarker from './map-marker'
import { ICON_PATH_ORIGIN } from '../../../helpers/location'
function getLat (latLng) { function getLat (latLng) {
if ('getLat' in latLng) { if ('getLat' in latLng) {
return latLng.getLat() return latLng.getLat()
...@@ -578,9 +580,7 @@ export default { ...@@ -578,9 +580,7 @@ export default {
location = new maps.Marker({ location = new maps.Marker({
position, position,
map, map,
icon: new maps.MarkerImage( icon: new maps.MarkerImage(ICON_PATH_ORIGIN, null, null, new maps.Point(22, 22), new maps.Size(44, 44)),
'',
null, null, new maps.Point(22, 22), new maps.Size(44, 44)),
flat: true, flat: true,
rotation: 0 rotation: 0
}) })
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册