微信小程序实现附近吃喝玩乐功能-基于百度地图服务搜索附近POI

利用百度地图API实现一个简单的小程序附近POI定位。

map.js
bmap-wx.min.js文件下载网址
下载
这里基本是基于官方demo,下载地址压缩包里也有几个demo可以参考学习。
图片资源也在压缩包里。

// 引用百度地图微信小程序JSAPI模块
var bmap = require('../../utils/bmap-wx.min.js');
var wxMarkerData = [];
Page({
    data: {
        markers: [],
        latitude: '',
        longitude: '',
        placeData: {},
        query:'酒店'
    },
    makertap: function (e) {
        var that = this;
        var id = e.markerId;
        that.showSearchInfo(wxMarkerData, id);
        that.changeMarkerColor(wxMarkerData, id);
    },
    button:function (e) {
        this.data.query = e.currentTarget.dataset['index'];
        console.log(this.data.query);
        this.onLoad();
    },
    onLoad: function () {
        var that = this;
        var query = this.data.query;
        // 新建百度地图对象
        var BMap = new bmap.BMapWX({
            ak: 'SHhILCwBcfqiCqwEL1MpqeRS5qwS5uoW'
        });
        var fail = function (data) {
            console.log(data)
        };
        var success = function (data) {
            wxMarkerData = data.wxMarkerData;
            that.setData({
                markers: wxMarkerData
            });
            that.setData({
                latitude: wxMarkerData[0].latitude
            });
            that.setData({
                longitude: wxMarkerData[0].longitude
            });
        }
        // 发起POI检索请求
        BMap.search({
            "query": query,
            fail: fail,
            success: success,
            // 此处需要在相应路径放置图片文件
            iconPath: '../../img/marker_red.png',
            // 此处需要在相应路径放置图片文件
            iconTapPath: '../../img/marker_red.png'
        });
    },
    showSearchInfo: function (data, i) {
        console.log(data)
        var that = this;
        that.setData({
            placeData: {
                title: '名称:' + data[i].title + '\n',
                address: '地址:' + data[i].address + '\n',
                telephone: '电话:' + data[i].telephone
            }
        });
    },
    changeMarkerColor: function (data, i) {
        var that = this;
        var markers = [];
        for (var j = 0; j < data.length; j++) {
            if (j == i) {
                // 此处需要在相应路径放置图片文件
                data[j].iconPath = "../../img/marker_yellow.png";
            } else {
                // 此处需要在相应路径放置图片文件
                data[j].iconPath = "../../img/marker_red.png";
            }
            markers[j](data[j]);
        }
        that.setData({
            markers: markers
        });
    }
})

map.wxml
静态页面,利用data-index简单的传一个值,再从js里把这个值赋给“query”,从而实现查询条件变更。

<view class="map_container">
    <map class="map" id="map" longitude="{{longitude}}" latitude="{{latitude}}" scale="14" show-location="true" markers="{{markers}}" bindmarkertap="makertap"></map>
</view>
<button bindtap="button" type="default" plain="true" data-index="美食">美食</button>
<button bindtap="button" type="default" plain="true" data-index="酒店">酒店</button>
<button bindtap="button" type="default" plain="true" data-index="购物">购物</button>
<button bindtap="button" type="default" plain="true" data-index="生活服务">生活服务</button>
<view class="place_info">
    <text>{{placeData.title}}</text>
    <text>{{placeData.address}}</text>
    <text>{{placeData.telephone}}</text>
</view>

map.wxss
简单写个样式,能出效果就可以了。

.map_container{
    height: 450px;
    width: 100%;
}

.map {
    height: 100%;
    width: 100%;
}

.place_info {
    padding: 0 5px;
}

说一下这里踩的坑,如果你的小程序提示你百度地图的地址不在合法域名列表中)。
在这里插入图片描述
上线情况下:你需要在https://mp.weixin.qq.com/wxamp/wadevelopcode/的服务端域名里配置https://api.map.baidu.com;使他成为合法域名。
本地情况下:在本地情况下localhost不应该也不能配置在服务端域名上,那么你就需要开启这一项,跳过校验。
在这里插入图片描述
如果在电脑可以运行,手机地图却出现蓝屏的情况,有可能是因为手机端的调试基础库问题。把运行环境的调试基础库推送即可解决。
在这里插入图片描述

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

01_Carrortwhisker

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值