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.
 
 
 
 

383 lines
10 KiB

<template>
<view class='app'>
<!-- 当前选择地址 -->
<view class="current-address row b-b">
<view class="left">
<view class="row">
<text class="red">[当前]</text>
<text class="title">{{currentAddress.title}}</text>
</view>
<text class="addr clamp">{{currentAddress.address}}</text>
</view>
<!-- 搜索图标 -->
<image
class="ser-icon"
src=""
@click="navTo('search?city='+curCity)"
></image>
</view>
<!-- 补充详细地址 -->
<view class="confirm-wrap row">
<input class="input" placeholder="补充详细地址:楼号、门牌等(选填)" placeholder-class="placeholder" v-model="room" @confirm='submit'></input>
<view class="btn" @click="submit">确定</view>
</view>
<map
id="map"
class="map"
:scale="15"
:show-location="true"
:longitude="map.longitude"
:latitude="map.latitude"
@regionchange="onRegionchange"
>
<cover-image class="map-center-icon" src="https://7478-tx-cloud-mix-mall-d6944c-1302673523.tcb.qcloud.la/5bfbd58b18200d8e16f6b17a02e6ed9.png"></cover-image>
</map>
<!-- 结果集 -->
<scroll-view scroll-y class="addr-list-scroll">
<view class="addr-list">
<view class="addr-item b-b row" v-for="(item, index) in list" :key="index" @click="chooseAddress(index)">
<view class="left">
<text class="title">{{item.title}}</text>
<text class="addr">{{item.address}}</text>
</view>
<icon type="success" color="#ff536f" size="18" class="icon_circle" v-if='checked === index' />
</view>
</view>
</scroll-view>
</view>
</template>
<script>
import config from '@/config'
const QQMapWX = require('./js/qqmap-wx-jssdk.min.js')
const qqmapsdk = new QQMapWX({
key: config.qqmapWxKey
})
let _mapCtx = null;
export default {
data() {
return {
curCity: '',
mapStatus: 1,
map: {
longitude: 116.39742,
latitude: 39.909,
},
room: '', //补充地址 门牌号、房间号
list: [], //地址列表
checked: 0, //当前选择选择地址下标
tempAddress: null, //编辑或者搜索到地址时,需要手动将结果添加到poi集
}
},
computed: {
currentAddress(){
if(this.list.length === 0){
return {};
}
return this.list[this.checked];
}
},
created() {
_mapCtx = uni.createMapContext('map');
},
onNavigationBarButtonTap() {
this.submit();
},
async onLoad(options) {
//编辑地址时参数
let optionData = options.data;
let lng, lat;
if(optionData){
//编辑地址时
this.tempAddress = JSON.parse(optionData);
this.room = this.tempAddress.room;
lng = this.tempAddress.location.lng;
lat = this.tempAddress.location.lat;
}else{
//没有传坐标时获取用户当前定位
const userLocation = await this.getLocation();
lng = +userLocation.longitude;
lat = +userLocation.latitude;
}
this.map = {
longitude: lng,
latitude: lat
}
this.position = {
longitude: lng,
latitude: lat
}
this.getAddressList(1)
},
methods: {
//确定选择
submit() {
const {currentAddress, room} = this;
const {ad_info, address, location, title} = currentAddress;
/* if(!room){
this.$util.msg('请补充详细地址');
return;
} */
this.$util.prePage().setAddress(Object.assign({}, {
ad_info, address, location, title,room
}));
uni.navigateBack();
},
//获取poi列表
getAddressList(s = 0) {
//在ios下防止搜索返回时多次加载地址列表的问题
if(this.isSetTempAddress === 1){
return;
}
qqmapsdk.reverseGeocoder({
location: {
latitude: this.position.latitude,
longitude: this.position.longitude
},
get_poi: 1,
poi_options: "page_size=30;page_index=1",
success: res=> {
//有搜索结果时,手动追加到列表顶部
if(this.tempAddress){
if(this.tempAddress.title != res.result.pois[0].title){
res.result.pois.unshift(this.tempAddress);
}
this.tempAddress = null;
this.isSetTempAddress = 1;
setTimeout(()=>{
this.isSetTempAddress = 0;
}, 500)
}
if (s) {
const ad_info = res.result.pois[0].ad_info;
this.curCity = ad_info.city || '';
res.result.pois[0].select = 1
this.list = res.result.pois;
this.checked = 0;
} else {
this.list = res.result.pois;
}
},
fail: err=> {
console.log(err)
}
})
},
//地图区域改变
onRegionchange(e) {
clearTimeout(this.timer)
this.timer = setTimeout(() => {
//h5 end 安卓 regionchange
if (e.type === 'end' || e.type === 'regionchange') {
_mapCtx.getCenterLocation({
success: res => {
this.position = {
latitude: res.latitude,
longitude: res.longitude
}
if (this.mapStatus == 1) { // 防止地图点击时 进行多次加载
this.getAddressList(1)
}
},
fail: err=>{
console.log(err);
}
})
}
}, 200)
},
//地址列表点击
chooseAddress(index) {
let list = this.list
this.map = {
longitude: list[index].location.lng,
latitude: list[index].location.lat
}
this.checked = index;
this.mapStatus = 0;
//防止ios下触发多次加载列表的bug
clearTimeout(this.mapStatusTimer);
this.mapStatusTimer = setTimeout(()=>{
this.mapStatus = 1;
}, 1000)
},
//获取用户定位
getLocation (){
return new Promise(resolve=> {
// #ifndef H5
uni.getLocation({
type: 'gcj02',
success: res=> {
resolve({
longitude: res.longitude,
latitude: res.latitude
})
},
err: err=> {
console.log(err)
resolve({
longitude: 116.39742,
latitude: 39.909,
})
},
complete(res) {
console.log(res);
}
})
// #endif
// #ifdef H5
//h5的定位没有写,这里直接默认天安门,可以根据项目需求使用对应jssdk获取定位
resolve({
longitude: 116.39742,
latitude: 39.909,
})
// #endif
})
},
navTo(url){
uni.navigateTo({
url
})
}
}
}
</script>
<style>
page {
height: 100%;
background: #F6F6F6;
}
</style>
<style scoped lang="scss">
.app{
display: flex;
flex-direction: column;
height: 100%;
overflow: hidden;
}
.row{
display: flex;
align-items: center;
}
.b-b{
position: relative;
&:after{
position: absolute;
z-index: 3;
left: 0;
top: auto;
bottom: 0;
right: 0;
height: 0;
content: '';
transform: scaleY(.5);
border-bottom: 1px solid #e5e5e5;
}
}
.clamp {
/* #ifdef APP-PLUS-NVUE */
lines: 1;
/* #endif */
/* #ifndef APP-PLUS-NVUE */
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
display: block;
/* #endif */
}
.current-address{
height: 120rpx;
padding: 0 24rpx;
background-color: #fff;
.left{
width: 634rpx;
}
.red{
flex-shrink: 0;
margin-right: 6rpx;
font-size: 28rpx;
color: $base-color;
line-height: 36rpx;
}
.title{
font-size: 28rpx;
color: #333;
font-weight: bold;
line-height: 36rpx;
}
.addr{
width: 700rpx;
margin-top: 12rpx;
font-size: 24rpx;
color: #909399;
line-height: 1.4;
}
.ser-icon{
flex-shrink: 0;
width: 66rpx;
height: 66rpx;
padding: 12rpx 4rpx 12rpx 20rpx;
}
}
.confirm-wrap{
height: 88rpx;
padding: 0 24rpx;
background-color: #fff;
.input{
flex: 1;
font-size: 28rpx;
color: #303133;
}
.btn{
padding: 0 24rpx;
font-size: 26rpx;
color: #fff;
line-height: 50rpx;
background-color: $base-color;
border-radius: 100rpx;
}
}
.map{
width: 750rpx;
height: 700rpx;
.map-center-icon{
position: absolute;
left: 339rpx;
top: 264rpx;
width: 72rpx;
height: 72rpx;
}
}
.addr-list-scroll{
flex: 1;
overflow: hidden;
.addr-list{
background-color: #fff;
}
.addr-item{
padding: 24rpx;
}
.left{
flex: 1;
display: flex;
flex-direction: column;
padding-right: 50rpx;
}
.title{
font-size: 28rpx;
color: #303133;
}
.addr{
margin-top: 10rpx;
font-size: 24rpx;
color: #909399;
line-height: 1.4;
}
}
</style>