码迷,mamicode.com
首页 > 微信 > 详细

# IT明星不是梦 # WIFI模块开发教程之W600连云篇1:onenet三色灯项目小程序篇②

时间:2020-03-27 23:33:38      阅读:203      评论:0      收藏:0      [点我收藏+]

标签:onload   pen   编辑框   start   view   教程   设备id   控制   wxs   

前言

本文研究如何使用小程序连接云平台,进而控制上一节中连接到onenet云平台的RGB三色灯设备。

一、理论基础

1.先睹为快

视频地址:https://www.ixigua.com/i6806304062091297292/

2.功能点简述

小程序开机页面

小程序界面布局

小程序访问onenet接口

小程序3秒刷新数据状态

小程序控制弹出编辑框设置房间号

小程序调用storage接口存取数据

二、使用实例

1.云端创建产品

接下来咱们进入正题,首先需要在云端创建一个产品,步骤如下:

创建产品

登录onenet官网,注册一个账号,地址:https://open.iot.10086.cn, 点进开发者中心,创建产品,产品配置信息如下:

技术图片

注意;操作系统这里使用RT_Thread,没有此选项,选用linux即可

创建数据点

数据流模板->添加数据流模板

技术图片

创建产品数据点,此处创建power和color两个数据点,power表示总开关,power为0时候,灯关闭;power不为0的时候,color数值起作用,用以选择不同模式。

创建后台显示数据面板

应用管理->独立应用->添加应用

技术图片

注意:红色、绿色、蓝色按钮和颜色显示图片均链接color数据点,颜色显示图片仅显示左右,按钮可以下发选择不同的灯颜色,其中红色按钮开状态数值为2,关数值为0,绿色按钮开状态数值为3,关数值为0,蓝色按钮开状态数值为4,关数值为0;颜色显示图片中白色状态数值为1,红色为2,绿色为3,蓝色为4,数据流同样选择color,具体如下图所示

技术图片

到此为止,我们已经完成了产品的创建工作,接下来将要处理设备接入问题。

2.小程序开机页面

start.wxml文件:

<view>
      <image src="../../image/start/start.png" class=‘welcome-img‘></image>
      <button class=‘welcome-btn‘ bindtap=‘goToIndex‘>点击开启</button>
</view>

start.wxss文件:

.hahahh {
  height: 1198rpx;
}

image {
  height: 1198rpx;
  width: 100%;
}

.welcome-img {
  position: absolute;
  z-index: 1;
}

.welcome-btn {
  background-color: #27e4b5;
  color: white;
  font-size: 38rpx;
  width: 330rpx;
  height: 90rpx;
  text-align: center;
  line-height: 90rpx;
  border-radius: 10px;
  position: absolute;
  bottom: 120rpx;
  left: 20px;
  right:20px;
  z-index: 2;
}

start.js文件:

var app = getApp();
Page({
  data: {
    remind: ‘加载中‘,
    angle: 0
  },
  goToIndex: function () {
    wx.switchTab({
      url: ‘/pages/index/index‘,
    });
  },
  onLoad: function () {
    var that = this
  },
  onShow: function () {

  },
  onReady: function () {
    var that = this;
    setTimeout(function () {
      that.setData({
        remind: ‘‘
      });
    }, 1000);
    wx.onAccelerometerChange(function (res) {
      var angle = -(res.x * 30).toFixed(1);
      if (angle > 14) { angle = 14; }
      else if (angle < -14) { angle = -14; }
      if (that.data.angle !== angle) {
        that.setData({
          angle: angle
        });
      }
    });
  },
})

3.小程序主页布局

.js文件调用https接口访问onenet提供的接口获取所有绑定的设备信息,然后小程序通过 wx:for 遍历设备,逐个显示在主页,主要程序如下:

index.wxml

  <view  wx:for="{{devices}}" wx:key="id" wx:for-item="item" data-id="{{item.id}}" bindtap="toDetailsTap">
    <view class="device">
      <view class="single_image_wrap">
        <image src="../../image/led/led.jpg" class="device_image"></image>
      </view>
      <view class="device_info">
        <navigator url="../led/led?id={{item.id}}">
          <view class="device_name">
            <text>LED</text>
          </view>
          <view class="device_d">
            <view class="room">
              <text>{{room_name}}</text>
            </view>
            <view class="device_status">
              <text>{{item.online === true ? ‘ 在线‘ : ‘离线‘}}</text>
            </view>
          </view>

        </navigator>
      </view>
    </view>

采用flex布局,具体内容参考index.wxss实现:

.device {
  position: relative;
  height: 120rpx;
  background-color: #FFF;
  padding-left: 80rpx;
  border-bottom: 1rpx solid #E7E7EB;
}
.single_image_wrap {
  position: absolute;
  left: 10rpx;
}
.device_image {
  width: 100rpx;
  height: 100rpx;
}
.device_info {
  position: relative;
  height: 100rpx;
  margin-left: 40rpx;
}
.device_name {
  font-size: 14px;
  margin-top: 20rpx;
}
.device_d{
  display: flex;
  flex-direction: row;
  justify-content: space-between
}
.room {
  color: #929292;
  font-size: 12px;
}
.device_status {
  font-size: 14px;
  color: #FF1493;
  margin-right: 40rpx;
}

4.小程序访问onenet接口

首先打开Onenet文档:https://open.iot.10086.cn/doc/

由于上一篇中设备是通过mqtt协议连接onenet,因此本篇小程序访问onenet接口也需要访问MQTT相关接口,如下所示:

技术图片

由上图可知查询数据需要调用URL:

http(s)://api.heclouds.com/devices/device_id/datastreams/datastream_id

device_id:需要替换为设备ID
datastream_id:需要替换为数据流ID
小程序调用实例:

//查看设备连接状态,并刷新按钮状态
wx.request({
    url: "http://api.heclouds.com/devices/" + id + "/datapoints?datastream_id=color",
    header: {
        ‘content-type‘: ‘application/x-www-form-urlencoded‘,
        "api-key": API_KEY
    },
    data: {

    },
    success(res) {
        console.log(res)
        deviceConnected = true

        if (that.data.switchFlag != true)
        {
            color_value = res.data.data.datastreams[0].datapoints[0].value
            switch (parseInt(color_value)) {
                case 1:
                    that.setData({
                        redSwitchChecked: false,
                        greenSwitchChecked: false,
                        blueSwitchChecked: false
                    })
                    break;
                case 2:
                    that.setData({
                        redSwitchChecked: true,
                        greenSwitchChecked: false,
                        blueSwitchChecked: false
                    })
                    break;
                case 3:
                    that.setData({
                        redSwitchChecked: false,
                        greenSwitchChecked: true,
                        blueSwitchChecked: false
                    })
                    break;
                case 4:
                    that.setData({
                        redSwitchChecked: false,
                        greenSwitchChecked: false,
                        blueSwitchChecked: true
                    })
                    console.log("color_value is ", color_value)
                    console.log("blueSwitchChecked is ", that.data.blueSwitchChecked)
                    break;
            }
            console.log("color_value is ", color_value)
        }else{
            that.setData({
                switchFlag:false
            })
        }
    },
    fail(res) {
        console.log("请求失败")
        deviceConnected = false
    }
})
},

5.小程序3秒刷新数据状态

在onLoad()中调用setInterval函数设置每隔3秒访问一次onenet设备的数据,及时更新显示页面,

that.data.myintervalid = setInterval(function () {
that.onShow()
}, 3000)

onShow()中正式调用onenet接口访问onenet设备的数据

  onShow: function (e) {
    var that = this
    that.getDataPoints(that.data.id)
  },
 getDataPoints: function (id) {
    var that = this
    var deviceConnected
    var color_value = 0
    //查看设备连接状态,并刷新按钮状态
    wx.request({
      url: "http://api.heclouds.com/devices/" + id + "/datapoints?datastream_id=color",
      header: {
        ‘content-type‘: ‘application/x-www-form-urlencoded‘,
        "api-key": API_KEY
      },
      data: {

      },
      success(res) {
        console.log(res)
        deviceConnected = true

        if (that.data.switchFlag != true)
        {
          color_value = res.data.data.datastreams[0].datapoints[0].value
          switch (parseInt(color_value)) {
            case 1:
              that.setData({
                redSwitchChecked: false,
                greenSwitchChecked: false,
                blueSwitchChecked: false
              })
              break;
            case 2:
              that.setData({
                redSwitchChecked: true,
                greenSwitchChecked: false,
                blueSwitchChecked: false
              })
              break;
            case 3:
              that.setData({
                redSwitchChecked: false,
                greenSwitchChecked: true,
                blueSwitchChecked: false
              })
              break;
            case 4:
              that.setData({
                redSwitchChecked: false,
                greenSwitchChecked: false,
                blueSwitchChecked: true
              })
              console.log("color_value is ", color_value)
              console.log("blueSwitchChecked is ", that.data.blueSwitchChecked)
              break;
          }
          console.log("color_value is ", color_value)
        }else{
          that.setData({
            switchFlag:false
          })
        }
      },
      fail(res) {
        console.log("请求失败")
        deviceConnected = false
      }
    })
  },

当页面切换到其他页面隐藏起来或者退出后,应该删除定时器,停止数据更新

 onHide: function () {
    // 页面隐藏
    clearInterval(this.data.myintervalid);
  },

  onUnload: function () {
    // 页面关闭
    clearInterval(this.data.myintervalid);
  },

6.小程序调用storage接口存取数据

存储房间号:

try {
    wx.setStorageSync(‘room_name‘, this.data.room_name)
} catch (e) {
    console.log("setStorageSync error")
 }

读取房间号:

    try {
        var value = wx.getStorageSync(‘room_name‘)
        if (value) {
            // Do something with return value
            that.setData({
                room_name:value
            })
        }
    } catch (e) {
        // Do something when catch error
        console.log("get stroage data error!")
    }

三、运行

如视频中介绍首先设备上电,onenet后台列表将会刷新出来设备状态,然后点开小程序,小程序设备主页如下图:

技术图片

点进去在线的设备:

技术图片

最后设置房间号:

技术图片

设置完成后退出到主页面,可以看到房间号已经刷新为了我们设置的。

四、结语

本节完,实际操作过程中需要注意的地方有如下几点:

(1) 设备连云

首先需要设备通过mqtt方式连接到onenet,可以参考上一篇onenet三色灯项目mqtt篇①

(2) 修改房间号

现在房间号只是存在了本地,如果本地清理数据后,房间号将会消失,这点需要注意,后期抽空做一个后台,mqtt部分还是基于onenet,增加房间号存储,权限认证等功能。

(3) 获取资料

如您在使用过程中有任何问题,请加QQ群进一步交流,也可以github提Issue。

QQ交流群:906015840 (备注:物联网项目交流)

github仓库地址:https://github.com/solitary-sand/wechat_onenet_led

一叶孤沙出品:一沙一世界,一叶一菩提

技术图片

# IT明星不是梦 # WIFI模块开发教程之W600连云篇1:onenet三色灯项目小程序篇②

标签:onload   pen   编辑框   start   view   教程   设备id   控制   wxs   

原文地址:https://blog.51cto.com/14616151/2482541

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!