欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序使用map組件實現(xiàn)檢索(定位位置)周邊的POI功能示例

 更新時間:2019年01月23日 08:41:50   作者:Rattenking  
這篇文章主要介紹了微信小程序使用map組件實現(xiàn)檢索(定位位置)周邊的POI功能,涉及微信小程序基于map組件與高德地圖PAI接口的定位操作相關(guān)使用技巧,需要的朋友可以參考下

本文實例講述了微信小程序使用map組件實現(xiàn)檢索(定位位置)周邊的POI功能。分享給大家供大家參考,具體如下:

聲明

bug: 頁面頂部分類【汽車服務(wù)、汽車銷售等】列表和頁腳的詳細(xì)地址在真機測試是會出現(xiàn)不顯示問題?

造成原因:在小程序map組件的同一區(qū)域,map組件的視圖層比普通的文本視圖層要高,所以在真機會遮擋!

解決辦法:將該文本視圖采用cover-view,放在map中。

感謝: 感謝Lrj_estranged指出問題!

效果圖

實現(xiàn)方法

1. 地圖采用微信小程序提供的map組件;

2. 周邊的數(shù)據(jù)坐標(biāo)點通過高德地圖提供的API接口,獲取定位位置的周邊或者指定位置周邊的數(shù)據(jù)。

WXML

<view class="map_container">
 <map class="map" longitude="{{longitude}}" latitude="{{latitude}}" include-points="{{points}}" markers='{{markers}}'>
   <cover-view class="map-tab-bar">
    <cover-viewclass="map-tab-li {{item.id == status ? 'active' : ''}}" bindtap="getType" data-type="{{item.id}}" wx:key="aroundListId" wx:for="{{aroundList}}">{{item.name}}</cover-view>
   </cover-view>
   <cover-viewclass="map-tab-bar map-foot {{isShow ? '' : 'map-hide'}}">
    <cover-viewclass="map-name">{{name}}</cover-view>
    <cover-viewclass="map-address">{{address}}</cover-view>
   </cover-view>
 </map>
</view>

WXSS

.map_container{
 width: 100%;
 height: 100%;
 position: fixed;
 top: 0;
 bottom: 0;
 left: 0;
 right: 0;
}
.map{
 width: 100%;
 height: 100%;
}
.map-tab-bar{
 position: absolute;
 top: 0;
 left: 0;
 width: 100%;
 z-index: 1000;
 font-size: 0;
 background-color: #fff;
}
.map-hide{display: none;}
.map-foot{
 top: auto;
 bottom: 0;
 padding: 0 10px;
}
.map-name{
 height: 80rpx;
 line-height: 80rpx;
 font-size: 35rpx;
 overflow: hidden;
}
.map-address{
 height: 60rpx;
 line-height: 60rpx;
 font-size: 25rpx;
 overflow: hidden;
}
.map-tab-li{
 display: inline-block;
 width: 25%;
 overflow: hidden;
 height: 70rpx;
 line-height: 70rpx;
 text-align: center;
 font-size: 30rpx;
 color: #333;
}
.map-tab-li.active{color: #fff;background-color: lightgreen;border-radius: 5px;}

JS

var app = getApp();
var amap = app.data.amap;
var key = app.data.key;
Page({
 data: {
  aroundList: [
   {
    name: '汽車服務(wù)',
    id: '010000'
   },
   {
    name: '汽車銷售',
    id: '020000'
   },
   {
    name: '汽車維修',
    id: '030000'
   },
   {
    name: '摩托車',
    id: '040000'
   },
   {
    name: '餐飲',
    id: '050000'
   },
   {
    name: '購物',
    id: '060000'
   },
   {
    name: '生活',
    id: '070000'
   },
   {
    name: '體育休閑',
    id: '080000'
   },
   {
    name: '醫(yī)療保健',
    id: '090000'
   },
   {
    name: '住宿',
    id: '100000'
   },
   {
    name: '風(fēng)景名勝',
    id: '110000'
   },
   {
    name: '商務(wù)住宅',
    id: '120000'
   }
  ],
  status:null,
  latitude: null,
  longitude: null,
  isShow: false,
  markers: [],
  points: [],
  location: '',
  name:'',
  address: ''
 },
 onLoad: function () {
  // 頁面加載獲取當(dāng)前定位位置為地圖的中心坐標(biāo)
  var _this = this;
  wx.getLocation({
   success(data) {
    if (data) {
     _this.setData({
      latitude: data.latitude,
      longitude: data.longitude,
      markers:[{
       id:0,
       latitude: data.latitude,
       longitude: data.longitude,
       iconPath: '../../src/images/ding.png',
       width: 32,
       height: 32
      }]
     });
    }
   }
  });
 },
 getType(e) {//獲取選擇的附近關(guān)鍵詞,同時更新狀態(tài)
  this.setData({ status: e.currentTarget.dataset.type})
  this.getAround(e.currentTarget.dataset.keywords,e.currentTarget.dataset.type);
 },
 getAround(keywords,types) {//通過關(guān)鍵詞獲取附近的點,只取前十個,同時保證十個點在地圖中顯示
  var _this = this;
  var myAmap = new amap.AMapWX({ key: key });
  myAmap.getPoiAround({
   iconPath: '../../src/images/blue.png',
   iconPathSelected: '../../src/images/ding.png',
   querykeywords: keywords,
   querytypes: types,
   location: _this.data.location,
   success(data) {
    if (data.markers) {
     var markers = [], points = [];
     for (var value of data.markers) {
      if (value.id > 9) break;
      if(value.id == 0){
       _this.setData({
        name: value.name,
        address: value.address,
        isShow: true
       })
      }
      markers.push({
       id: value.id,
       latitude: value.latitude,
       longitude: value.longitude,
       title: value.name,
       iconPath: value.iconPath,
       width: 32,
       height: 32,
       anchor: { x: .5, y: 1 },
       label: {
        content: value.name,
        color: 'green',
        fontSize: 12,
        borderRadius: 5,
        bgColor: '#fff',
        padding: 3,
        x: 0,
        y: -50,
        textAlign: 'center'
       }
      });
      points.push({
       latitude: value.latitude,
       longitude: value.longitude
      })
     }
     _this.setData({
      markers: markers,
      points: points
     })
    }
   },
   fail: function (info) {
    wx.showToast({title: info})
   }
  })
 }
});

總結(jié)

1. 由于是移動端,所以人為限制只顯示了9條周邊數(shù)據(jù),防止重疊部分太多。

2. 添加指定位置的周邊的方法—-添加一個input,將給的關(guān)鍵字進行搜索,然后返回坐標(biāo),改變地圖中心坐標(biāo)。

3. 改變中心坐標(biāo)還有采用微信小程序自己的API(wx.chooseLocation),改變地圖中心坐標(biāo)。參考:微信小程序?qū)崿F(xiàn)map路線規(guī)劃

4. 高德地圖提供API和微信小程序提供API的優(yōu)劣:①、目前高德提供的API返回數(shù)據(jù)很快,最少目前比微信小程序自己的快很多;②、缺點也很明顯就是由于是外部提供的,所以需要進行對應(yīng)配置,麻煩;③、微信小程序提供的API優(yōu)勢就是屬于本身,不用額外配置,如果以后優(yōu)化了,更好。

實例:

用高德地圖提供的 getInputtips 接口,搜索關(guān)鍵字和城市,返回的坐標(biāo),然后改變地圖中心坐標(biāo)。

// 頁面加載以輸入地址為地圖的中心坐標(biāo)
// 假如輸入的是:成都 歐尚庭院
myAmap.getInputtips({
 keywords: '歐尚庭院',
 city: '成都',
 success(res) {
  var tip = res.tips[0];
  var lo = tip.location.split(',')[0];
  var la = tip.location.split(',')[1];
  _this.setData({
   latitude: la,
   longitude: lo,
   location: tip.location,
   markers: [{
    id: 0,
    latitude: la,
    longitude: lo,
    iconPath: '../../src/images/ding.png',
    width: 32,
    height: 32
   }]
  })
 }
})

希望本文所述對大家微信小程序開發(fā)有所幫助。

相關(guān)文章

  • 原生JS實現(xiàn)簡單放大鏡效果

    原生JS實現(xiàn)簡單放大鏡效果

    這篇文章主要為大家詳細(xì)介紹了原生JS實現(xiàn)簡單放大鏡效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • JavaScript利用fetch實現(xiàn)異步請求的方法實例

    JavaScript利用fetch實現(xiàn)異步請求的方法實例

    傳遞信息到服務(wù)器,從服務(wù)器獲取信息,是前端發(fā)展的重中之重,尤其是現(xiàn)在前后端分離的大前提下,前后端的數(shù)據(jù)交互是前端的必修科目了,下面這篇文章主要給大家介紹了關(guān)于JavaScript利用fetch實現(xiàn)異步請求的相關(guān)資料,需要的朋友可以參考借鑒。
    2017-07-07
  • js定時器的使用(實例講解)

    js定時器的使用(實例講解)

    本篇文章主要介紹了js中定時器的使用方法。需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • 如何利用unicloud生成微信小程序分享碼

    如何利用unicloud生成微信小程序分享碼

    這篇文章主要給大家介紹了關(guān)于如何利用unicloud生成微信小程序分享碼的相關(guān)資料,這是最近工作中遇到的一個需求,文中通過圖文以及示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • 微信小程序?qū)崿F(xiàn)翻牌抽獎動畫

    微信小程序?qū)崿F(xiàn)翻牌抽獎動畫

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)翻牌抽獎動畫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • 12個非常實用的JavaScript小技巧【推薦】

    12個非常實用的JavaScript小技巧【推薦】

    下面小編就為大家?guī)硪黄?2個非常實用的JavaScript小技巧【推薦】。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • JavaScript各類型的關(guān)系圖解

    JavaScript各類型的關(guān)系圖解

    這篇文章主要通過一張圖讓你看懂JavaScript各類型的關(guān)系,需要的朋友可以參考下
    2015-10-10
  • layui form表單提交之后重新加載數(shù)據(jù)表格的方法

    layui form表單提交之后重新加載數(shù)據(jù)表格的方法

    今天小編就為大家分享一篇layui form表單提交之后重新加載數(shù)據(jù)表格的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • JS長整型精度問題實例分析

    JS長整型精度問題實例分析

    這篇文章主要介紹了JS長整型精度問題,實例分析了Java項目結(jié)合前臺js腳本出現(xiàn)的長整型精度問題與相應(yīng)的解決方案,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • 關(guān)于UTF-8的客戶端用AJAX方式獲取GB2312的服務(wù)器端亂碼問題的解決辦法

    關(guān)于UTF-8的客戶端用AJAX方式獲取GB2312的服務(wù)器端亂碼問題的解決辦法

    客戶端是UTF-8編碼,這也是現(xiàn)在大家公認(rèn)的標(biāo)準(zhǔn)編碼在這種情況下,實用AJAX異步獲取GB2312編碼的服務(wù)器端信息時,不可避免的要遇到漢字亂碼問題
    2010-11-11

最新評論