小程序开发之获取周围IBeacon设备

该功能实现需要使用以下API:

wx.startBeaconDiscovery(OBJECT):开始搜索附近的iBeacon设备

wx.stopBeaconDiscovery(OBJECT):停止搜索附近的iBeacon设备

wx.onBeaconUpdate(CALLBACK):监听 iBeacon 设备的更新事件

wx.openBluetoothAdapter(OBJECT):监听蓝牙状态

wx.onBluetoothDeviceFound(CALLBACK):监听蓝牙状态切换

具体参数以及回调函数请参考官方API


实现逻辑



实现代码 index.js:

onShow : function(){
    var that = this;
    //监测蓝牙状态的改变
    wx.onBluetoothAdapterStateChange(function (res) {
      if (res.available) {//如果用户打开蓝牙,开始搜索IBeacon
        searchBeacon();
      }
    })

    //搜索beacons
    searchBeacon();
    //搜索函数
    function searchBeacon() {
      //检测蓝牙状态
      wx.openBluetoothAdapter({
        success: function (res) {//蓝牙状态:打开
          wx.startBeaconDiscovery({//开始搜索附近的iBeacon设备
            uuids: ['FDA50693-A4E2-4FB1-AFCF-C6EB07647825'],//参数uuid
            success: function (res) {
              wx.onBeaconUpdate(function (res) {//监听 iBeacon 设备的更新事件  
                //封装请求数据 
                var beacons = res.beacons;
                var reqContent = {};
                var bleArray = [];
                for (var i = 0; i < beacons.length; i++) {
                  var bleObj = {};
                  bleObj.distance = beacons[i].accuracy;
                  bleObj.rssi = beacons[i].rssi;
                  bleObj.mac = beacons[i].major + ":" + beacons[i].minor;
                  bleArray.push(bleObj);
                }
                reqContent.ble = bleArray;
                //请求后台向redis插入数据
                redisSave(reqContent);
              });
            },
            fail: function (res) {
              //先关闭搜索再重新开启搜索,这一步操作是防止重复wx.startBeaconDiscovery导致失败
              stopSearchBeacom();
            }
          })
        },
        fail: function (res) {//蓝牙状态:关闭
          wx.showToast({ title: "请打开蓝牙", icon: "none", duration: 2000 })
        }
      })
    }

    function redisSave(reqContent) {
      wx.request({
        url: "https://map.intmote.com/LocateServer/location.action",
        data: JSON.stringify(reqContent),
        method: 'POST',
        header: {
          'Content-type': 'application/json'
        },
        success: function (res) {
         // wx.showToast({ title: "seccess" })
        },
        fail: function (res) {
         // wx.showToast({ title: "1" })
        }
      });
    }

    //关闭成功后开启搜索
    function stopSearchBeacom() {
      wx.stopBeaconDiscovery({
        success: function () {
          searchBeacon();
        }
      })
    }   
  },


介绍小程序的页面生命周期函数之一:onShow

监听页面显示:即每次打开页面都会调用一次。

  • 4
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Ibeacon 算法是一种基于蓝牙技术的室内定位算法,可以通过检测蓝牙信号的强度来确定设备的位置。在微信小程序中使用 Ibeacon 算法需要用到微信开发者工具中提供的蓝牙 API。 以下是一个简单的 Ibeacon 算法示例代码,可以实现扫描周围Ibeacon 设备获取其信号强度。 ``` // 开启蓝牙模块 wx.openBluetoothAdapter({ success: function (res) { // 开始扫描 Ibeacon 设备 wx.startBeaconDiscovery({ // 配置扫描参数 uuids: ['FDA50693-A4E2-4FB1-AFCF-C6EB07647825'], success: function (res) { // 监听扫描到的设备信号变化 wx.onBeaconUpdate(function (res) { // 遍历所有扫描到的设备 for (var i = 0; i < res.beacons.length; i++) { // 获取设备的信号强度 var rssi = res.beacons[i].rssi; // 根据信号强度计算设备距离 var distance = calculateDistance(rssi); // 输出设备距离 console.log("设备距离: " + distance); } }); } }); } }); // 计算设备距离的函数 function calculateDistance(rssi) { // 根据 Ibeacon 设备的信号强度计算设备距离 var txPower = -59; // 设备发射功率 if (rssi == 0) { return -1.0; // 无效距离 } var ratio = rssi * 1.0 / txPower; if (ratio < 1.0) { return Math.pow(ratio, 10); } else { var distance = (0.89976) * Math.pow(ratio, 7.7095) + 0.111; return distance; } } ``` 在以上示例代码中,我们首先开启了蓝牙模块,然后使用 `wx.startBeaconDiscovery()` 函数开始扫描 Ibeacon 设备。在扫描到设备信号变化时,我们使用 `wx.onBeaconUpdate()` 监听设备信号变化,并根据设备信号强度计算设备距离。最后,我们通过 `console.log()` 输出设备距离信息。 需要注意的是,以上示例代码中的 `uuids` 参数表示要扫描的 Ibeacon 设备的 UUID,需要根据实际情况进行设置。同时,计算设备距离的函数 `calculateDistance()` 中的设备发射功率参数 `txPower` 也需要根据实际情况进行设置。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值