deviceConnect3.js 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. // pages/deviceConnect3/deviceConnect3.ts
  2. const app = getApp();
  3. let xBlufi = require("../../utils/blufi/xBlufi.js");
  4. let percentIn = null;
  5. let _this = null;
  6. let errTi = null;
  7. Page({
  8. /**
  9. * 页面的初始数据
  10. */
  11. data: {
  12. scopeBluetooth: app.globalData.scopeBluetooth,
  13. ssid: app.globalData.ssid,
  14. password: app.globalData.pwdData,
  15. nvabarData: {
  16. showCapsule: 1, //是否显示左上角图标 1表示显示 0表示不显示
  17. title: '连接配网', //导航栏 中间的标题
  18. },
  19. version: '2.0',
  20. name: '',
  21. connectedDeviceId: '',
  22. connected: true,
  23. deviceInfo: null,
  24. isInitOK: false,
  25. customData: '',
  26. percent: 0,
  27. ruterStatus: 0, // 0 连接中 // 1 成功 // 2失败
  28. },
  29. onShow: function(options) {
  30. },
  31. onLoad: function(options) {
  32. _this = this;
  33. _this.setData({
  34. name: options.name,
  35. connectedDeviceId: options.deviceId,
  36. })
  37. xBlufi.listenDeviceMsgEvent(true, this.funListenDeviceMsgEvent);
  38. xBlufi.notifyInitBleEsp32({
  39. deviceId: options.deviceId,
  40. });
  41. percentIn = setInterval(()=> {
  42. if(_this.data.percent === 100) {
  43. clearInterval(percentIn);
  44. _this.setData({
  45. ruterStatus: 2
  46. });
  47. return;
  48. };
  49. _this.data.percent++;
  50. _this.setData({
  51. percent: _this.data.percent
  52. });
  53. }, 600);
  54. },
  55. onUnload: function() {
  56. // 关闭蓝牙连接
  57. let _this = this
  58. xBlufi.notifyConnectBle({
  59. isStart: false,
  60. deviceId: _this.data.connectedDeviceId,
  61. name: _this.data.name,
  62. });
  63. xBlufi.listenDeviceMsgEvent(false, this.funListenDeviceMsgEvent);
  64. clearTimeout(errTi);
  65. clearInterval(percentIn);
  66. },
  67. funListenDeviceMsgEvent: function(options) {
  68. let _this = this;
  69. switch (options.type) {
  70. case xBlufi.XBLUFI_TYPE.TYPE_STATUS_CONNECTED:
  71. _this.setData({
  72. connected: options.result
  73. });
  74. if (!options.result) {
  75. wx.showModal({
  76. title: '很抱歉提醒你!',
  77. content: '小程序与设备异常断开',
  78. showCancel: false, //是否显示取消按钮
  79. success: function(res) {
  80. wx.navigateBack({
  81. delta: 1
  82. });
  83. },
  84. })
  85. }
  86. break;
  87. case xBlufi.XBLUFI_TYPE.TYPE_CONNECT_ROUTER_RESULT:
  88. wx.hideLoading();
  89. if (!options.result)
  90. errTi = setTimeout(()=> {
  91. _this.setData({
  92. ruterStatus: 2
  93. });
  94. clearTimeout(errTi);
  95. clearInterval(percentIn);
  96. }, 5000);
  97. else {
  98. // 配网成功
  99. if (options.data.progress == 100) {
  100. clearTimeout(errTi);
  101. clearInterval(percentIn);
  102. // 更新数据
  103. wx.getStorage({
  104. key: 'devicelist',
  105. success (res) {
  106. if(res.data) {
  107. let arr = JSON.parse(res.data);
  108. // 同一个设备
  109. const devicelist = arr.filter((v)=> v.deviceId === _this.data.name);
  110. if(devicelist.length > 0) {
  111. arr = arr.filter((v)=> v.deviceId !== _this.data.name);
  112. };
  113. arr.unshift({
  114. deviceId: _this.data.name,
  115. name: _this.data.name,
  116. state: "online"
  117. });
  118. wx.setStorage({
  119. key:"devicelist",
  120. data: JSON.stringify(arr),
  121. success() {
  122. _this.setData({
  123. percent: 100,
  124. ruterStatus: 1
  125. });
  126. }
  127. })
  128. }
  129. },
  130. fail() {
  131. wx.setStorage({
  132. key:"devicelist",
  133. data: JSON.stringify([{
  134. name: _this.data.name,
  135. deviceId: _this.data.name,
  136. state: "online"
  137. }]),
  138. success() {
  139. _this.setData({
  140. percent: 100,
  141. ruterStatus: 1
  142. });
  143. }
  144. })
  145. }
  146. })
  147. // 记住密码
  148. wx.setStorage({
  149. key:"wifiInfo",
  150. data: JSON.stringify({"password": app.globalData.pwdData, "ssid": app.globalData.ssid})
  151. });
  152. }
  153. }
  154. break;
  155. case xBlufi.XBLUFI_TYPE.TYPE_INIT_ESP32_RESULT:
  156. wx.hideLoading();
  157. // console.log("初始化结果:", JSON.stringify(options))
  158. if (options.result) {
  159. console.log('初始化成功');
  160. _this.OnClickStart();
  161. } else {
  162. console.log('初始化失败')
  163. _this.setData({
  164. connected: false
  165. })
  166. _this.setData({
  167. ruterStatus: 2
  168. });
  169. }
  170. break;
  171. }
  172. },
  173. OnClickStart: function() {
  174. if (!app.globalData.ssid) {
  175. wx.showToast({
  176. title: 'SSID不能为空',
  177. icon: 'none'
  178. })
  179. return
  180. }
  181. if (!app.globalData.pwdData) {
  182. wx.showToast({
  183. title: '密码不能为空',
  184. icon: 'none'
  185. })
  186. return;
  187. }
  188. xBlufi.notifySendRouterSsidAndPassword({
  189. ssid: app.globalData.ssid,
  190. password: app.globalData.pwdData
  191. });
  192. },
  193. bindPasswordInput: function(e) {
  194. this.setData({
  195. password: e.detail.value
  196. })
  197. },
  198. bindCustomDataInput: function(e) {
  199. this.setData({
  200. customData: e.detail.value
  201. })
  202. },
  203. egen(){
  204. wx.navigateBack({
  205. delta: 1
  206. })
  207. },
  208. goIndex(){
  209. // BLUFI_7cdfa1fd3cfc
  210. app.globalData.newDeviceId = this.data.name;
  211. wx.redirectTo({
  212. url: '/pages/index/index'
  213. });
  214. }
  215. })