1、WXML 页面代码

<!--index.wxml-->
<view class="container">
<view class="usermotto">
<text class="user-motto">{{motto}}</text>
</view>
<view class="alllightbtn">
<view class=".lightbtn" bindtap="onlightTap" data-lightnum="Light 1">灯1</view>
<view class=".lightbtn" bindtap="onlightTap" data-lightnum="Light 2">灯2</view>
<view class=".lightbtn" bindtap="onlightTap" data-lightnum="Light 3">灯3</view>
<view class=".lightbtn" bindtap="onlightTap" data-lightnum="Light 4">灯4</view>
<view class=".lightbtn" bindtap="onlightTap" data-lightnum="Light 5">灯5</view>
<view class=".lightbtn" bindtap="onlightTap" data-lightnum="Light 6">灯6</view>
<view class=".lightbtn" bindtap="onlightTap" data-lightnum="Light 7">灯7</view>
<view class=".lightbtn" bindtap="onlightTap" data-lightnum="Light 8">灯8</view>
</view>
<view class="rcvUdpContent" wx:if="{{udprcvshow>0}}">{{udpRcvdata}}</view>
</view>

2、WXSS 样式代码

/**index.wxss**/

.usermotto {
margin: 20px 0px;
background-color: #e9f2f7;
border-top: solid 1px #0093dd;
border-bottom: solid 1px #0093dd;
width: 100%;
text-align: center;
padding: 10px;
} .user-motto {
font-size: 20px;
font-weight: bold;
} .alllightbtn {
display: block;
border: 1px solid #0093dd;
text-align: center;
} .lightbtn {
border: 2px solid #0093dd;
border-radius: 10px;
padding: 30px 40px;
margin: 10px;
display: inline-block;
} .lightbtn:active {
background-color: #606060;
} .rcvUdpContent {
position: fixed;
top: 10px;
left: 0px;
right: 0px;
padding: 40px 20px;
text-align: center;
font-size: 24px;
background: #eaf5ea;
border-top: solid 1px #0093dd;
border-bottom: solid 2px #0093dd;
}

3、js代码-----注意点 接收 onMessage 收到的message是ArrayBuffer缓冲,不能直接输出,要另转String处理

//index.js
//获取应用实例
const app = getApp() Page({
data: {
motto: 'UDP通信<->8路',
udp: null,
udpRcvdata:'udp recived data',
udprcvshow:0,
},
//点击灯按钮事件处理函数
onlightTap: function (light) {
var senddata = 'click ' + light.currentTarget.dataset.lightnum
console.log(senddata) this.udp.send({
address: 'gzlema.cn',//ip:47.92.29.6
port: 60000,
message: senddata
})
},
//UDP 接收到数据的事件处理函数,参数res={message,remoteInfo}
onUdpMessage: function (res) {
if (res.remoteInfo.size > 0) {
console.log('onUdpMessage() 接收数据 ' + res.remoteInfo.size + ' 字节:' + JSON.stringify(res, null, '\t')) // 将 ArrayBuffer类型的res.message取出来
let unit8Arr = new Uint8Array(res.message)
let encodedString = String.fromCharCode.apply(null, unit8Arr)
let decodedString = decodeURIComponent(escape((encodedString)))//没有这一步中文会乱码
console.log('message:'+decodedString)
// 将 ArrayBuffer类型的res.message取出来 this.setData({ udpRcvdata: 'udp rcv: ' + decodedString}) // 更新str到UI this.setData({ udprcvshow: Number(this.data.udprcvshow)+2000})//延时统一加2秒
console.log(this.data.udprcvshow)
var pagethis = this
setTimeout(function(){
pagethis.setData({ udprcvshow: Number(pagethis.data.udprcvshow) - 2000 })//延时统一减2秒
console.log(pagethis.data.udprcvshow)
},2000) //只显示2秒后隐藏
}
},
//页面加载完成事件由系统调用
onLoad: function () {
console.log('页面 index 加载完成事件onLoad()')
this.udp = wx.createUDPSocket() //新建udp实例
this.udp.bind() //udp绑定本机
this.udp.onMessage(this.onUdpMessage) //指定接收事件处理函数
}
})

4 较果图

微信小程序UDP通信,注意点 接收 onMessage 收到的message是ArrayBuffer缓冲,不能直接输出,要另转String处理的更多相关文章

  1. 微信小程序UDP通信

    前言 UDP通信分为单播 广播 组播,基础库2.7.0之后,小程序开始支持UDP通信,目前小程序只支持单播. 小程序API 小程序UDP通信这一块可以说是很简单了就一个UDPSocket实例.然后bi ...

  2. 微信小程序页面通信

    目录 微信小程序页面通信 方式一:通过URL 方式二:通过全局变量 方式三:通过本地存储 方式四:通过路由栈 微信小程序页面通信 方式一:通过URL // A 页面 wx.navigateTo({ u ...

  3. 微信小程序组件通信

    父子通信 在子组件的对应js中 properties:{ prop名字:数据类型, prop名字:{ type:数据类型, value:默认值 } } 在父组件的wxml模板中找到子组件标签 < ...

  4. 微信小程序组件通信入门及组件生命周期函数

    组件生命周期函数链接地址:https://developers.weixin.qq.com/miniprogram/dev/framework/custom-component/lifetimes.h ...

  5. 微信小程序 组件通信相关知识整理

    1.自定义组件间通信与事件 https://developers.weixin.qq.com/miniprogram/dev/framework/custom-component/events.htm ...

  6. 微信小程序组建通信

    子组件传递父组件需要用到triggerEvent方法,当子组件(自定义组件)点击button的时候调用triggerEvent方法传递一些数据,首先第一个属性为自定义名称(myevent)对应父组件( ...

  7. 让微信小程序开发如鱼得水

      关于微信小程序开发一直想写一篇相关的文章总结和记录下,结果拖延症犯了迟迟没有下笔:这不最近天气不错,于是找一个空闲的下午将这篇文章输出下(好像跟天气没啥关系),那我们就开始吧! 注意:本文默认开发 ...

  8. 微信小程序image组件中aspectFill和widthfix模式应用详解

    aspectFill 与 widthfix 都是保持宽高比不变 aspectFill 保持纵横比缩放图片,只保证图片的短边能完全显示出来.也就是说,图片通常只在水平或垂直方向是完整的,另一个方向将会发 ...

  9. 图片的URL上传至阿里云OSS操作(微信小程序二维码返回的二进制上传到OSS)

    当我们从网络中获取一个URL的图片我们要存储到本地或者是私有的云时,我们可以这样操作  把url中的图片文件下载到本地(或者上传到私有云中)  public String uploadUrlToOss ...

随机推荐

  1. ZDialog关闭父窗口、往父窗口传值、刷新父窗口

    关闭自己 //关闭自己 top.Dialog.close(); 关闭父窗口 //关闭父窗口 parentDialog.parentWindow.close() 往父窗口传值 //在本页面,调用父页面方 ...

  2. C++ socket编程-转载

    转自:https://www.cnblogs.com/L-hq815/archive/2012/07/09/2583043.html 若有违规请联系我删除. 介绍 Socket编程让你沮丧吗?从man ...

  3. C++中多态实现的关键——虚函数

    1.多态的作用 在面向对象程序设计中,使用多态能够增强代码的可扩充性,,即程序需要增加或修改部分功能时,只需修改少量代码就能够达到目的,此外多态也能起到精简代码的作用. 而实现多态的关键点,就是虚函数 ...

  4. 理解 Oracle 多租户体系中(12c,18c,19c)创建用户作用域范围

    本篇探讨以下几个问题:你可提前猜测下面6个场景语句中,哪几个可以成功创建用户? 1. 在CDB级别中创建公共用户,不带 container 子句的效果: 2. 在CDB级别中创建公共用户,带 cont ...

  5. Windows系统对拍程序

    Windows系统对拍程序,其中包含c++11用法,请使用c++11标准编译.此对拍程序会在发现错误时显示错误行号以及对应内容,方便比对. 此对拍程序自动使用g++对源代码进行编译.如果出现找不到g+ ...

  6. struts2中的constant常量配置

    struts2中的constant配置详解 本文主要讲解一下struts2中的constant常量配置,内容主要来自于互联网的整理.<?xml version="1.0" e ...

  7. AcWing 1013. 机器分配

    //分组背包 for物品 for体积 for 决策 #include <iostream> using namespace std; ; int n, m; int w[N][N]; in ...

  8. 2020牛客竞赛 DP F 碎碎念

    作者:儒生雄才1链接:https://ac.nowcoder.com/discuss/366644来源:牛客网 题目连接:https://ac.nowcoder.com/acm/contest/300 ...

  9. pve apt-get update error 升级报错-文章未完工和验证

    pve: apt-get update error 升级报错 提示如下报错 Hit: http://security.debian.org buster/updates InRelease Hit: ...

  10. FPM 0.08不能运行破解办法……

    FPM_0.080.rar 破解办法:用UltraEdit打开FPM.exe,查找"33 C0 E9 F2"(注意中间有空格)将33改为8B,F2改为00