修复102时间加减异常

This commit is contained in:
liub
2026-03-24 12:00:27 +08:00
parent 5163491ea3
commit c286660a10
7 changed files with 234 additions and 48 deletions

View File

@ -56,7 +56,8 @@
"<uses-permission android:name=\"android.permission.ACCESS_COARSE_LOCATION\"/>", "<uses-permission android:name=\"android.permission.ACCESS_COARSE_LOCATION\"/>",
"<uses-permission android:name=\"android.permission.READ_EXTERNAL_STORAGE\"/>", "<uses-permission android:name=\"android.permission.READ_EXTERNAL_STORAGE\"/>",
"<uses-permission android:name=\"android.permission.a\"/>", "<uses-permission android:name=\"android.permission.a\"/>",
"<uses-permission android:name=\"android.permission.BLUETOOTH_CONNECT\"/>" "<uses-permission android:name=\"android.permission.BLUETOOTH_CONNECT\"/>",
"<uses-permission android:name=\"android.permission.BLUETOOTH_SCAN\"/>"
], ],
"minSdkVersion" : 21, "minSdkVersion" : 21,
"abiFilters" : [ "armeabi-v7a", "arm64-v8a", "x86" ], "abiFilters" : [ "armeabi-v7a", "arm64-v8a", "x86" ],

View File

@ -50,7 +50,8 @@
</view> </view>
<view class="item" @click.top="bleStatuToggle"> <view class="item" @click.top="bleStatuToggle">
<text class="lbl">蓝牙状态</text> <text class="lbl">蓝牙状态</text>
<text class="value" :class="formData.bleStatu?'green':'red'">{{device.getbleStatu}}</text> <text class="value"
:class="(!formData.bleStatu || formData.bleStatu==='err')?'red':'green'">{{getbleStatu}}</text>
</view> </view>
<view class="item"> <view class="item">
<text class="lbl">设备状态</text> <text class="lbl">设备状态</text>
@ -469,6 +470,17 @@
onLoad: function() { onLoad: function() {
const eventChannel = this.getOpenerEventChannel(); const eventChannel = this.getOpenerEventChannel();
var these = this; var these = this;
this.$watch("deviceInfo.batteryPercentage", (newVal, oldVal) => {
if (newVal <= 20) {
uni.showToast({
title: '设备电量低',
icon: 'none',
duration: 2000
});
}
});
eventChannel.on('detailData', function(data) { eventChannel.on('detailData', function(data) {
var device = data.data; var device = data.data;
these.device = device; these.device = device;
@ -609,7 +621,9 @@
} }
// 尝试连接蓝牙:需先扫描获取 BLE deviceId不能直接用 MAC延迟 500ms 确保蓝牙适配器就绪 // 尝试连接蓝牙:需先扫描获取 BLE deviceId不能直接用 MAC延迟 500ms 确保蓝牙适配器就绪
if (data.data.deviceMac) { if (data.data.deviceMac) {
setTimeout(() => { these.tryConnect100JBle(data.data.deviceMac); }, 500); setTimeout(() => {
these.tryConnect100JBle(data.data.deviceMac);
}, 500);
} }
}); });
this.createThrottledFunctions(); this.createThrottledFunctions();
@ -641,10 +655,53 @@
this.Status.pageHide = false; this.Status.pageHide = false;
}, },
computed: { computed: {
getbleStatu() {
if (this.formData.bleStatu === true) {
return '已连接';
}
if (this.formData.bleStatu === 'connecting') {
return '连接中';
}
if (this.formData.bleStatu === 'dicconnect') {
return '正在断开';
}
if (this.formData.bleStatu === 'err') {
return '连接异常';
}
return '未连接';
}
}, },
methods: { methods: {
bleStatuToggle() {
let f = bleTool.data.LinkedList.find((v) => {
return v.macAddress == this.device.deviceMac;
});
if (!f) {
this.tryConnect100JBle(this.device.deviceMac);
return;
}
if (this.formData.bleStatu === true) {
this.formData.bleStatu = 'dicconnect';
bleTool.disconnectDevice(f.deviceId).finally(r => {
this.formData.bleStatu = false;
});
return;
}
if (this.formData.bleStatu === false || this.formData.bleStatu === 'err') {
this.formData.bleStatu = 'connecting';
bleTool.LinkBlue(f.deviceId, f.writeServiceId, f.wirteCharactId, f.notifyCharactId).then(res => {
these.formData.bleStatu = true;
}).catch(ex => {
these.formData.bleStatu = 'err';
});
return;
}
},
createThrottledFunctions() { createThrottledFunctions() {
// 创建节流函数 // 创建节流函数
this.throttledBrightnessChange = this.throttle(this.handleBrightnessChange, 500); this.throttledBrightnessChange = this.throttle(this.handleBrightnessChange, 500);
@ -1014,20 +1071,31 @@
const NOTIFY = '0000AE02-0000-1000-8000-00805F9B34FB'; const NOTIFY = '0000AE02-0000-1000-8000-00805F9B34FB';
if (cached && cached.deviceId) { if (cached && cached.deviceId) {
console.log('[100J] 使用缓存设备连接', cached.deviceId); console.log('[100J] 使用缓存设备连接', cached.deviceId);
that.formData.bleStatu = 'connecting';
bleTool.LinkBlue(cached.deviceId, SVC, WRITE, NOTIFY, 2).then(() => { bleTool.LinkBlue(cached.deviceId, SVC, WRITE, NOTIFY, 2).then(() => {
console.log('100J 蓝牙连接成功(缓存)'); console.log('100J 蓝牙连接成功(缓存)');
that.bleStateRecovry({ deviceId: cached.deviceId }); that.formData.bleStatu = true;
that.bleStateRecovry({
deviceId: cached.deviceId
});
}).catch(err => { }).catch(err => {
console.log('100J 蓝牙连接失败(缓存),尝试扫描', err); console.log('100J 蓝牙连接失败(缓存),尝试扫描', err);
that.formData.bleStatu = 'err';
that.connect100JByScan(deviceMac, last6); that.connect100JByScan(deviceMac, last6);
}); });
return; return;
} }
// 2. 无缓存先尝试直连。Android 上 deviceId 多为 MAC 反序(11:22:33:44:55:02->02:55:44:33:22:11) // 2. 无缓存先尝试直连。Android 上 deviceId 多为 MAC 反序(11:22:33:44:55:02->02:55:44:33:22:11)
that.formData.bleStatu = 'connecting';
const tryDirect = (id) => bleTool.LinkBlue(id, SVC, WRITE, NOTIFY, 2).then(() => { const tryDirect = (id) => bleTool.LinkBlue(id, SVC, WRITE, NOTIFY, 2).then(() => {
console.log('100J 蓝牙连接成功(直连)', id); console.log('100J 蓝牙连接成功(直连)', id);
that.bleStateRecovry({ deviceId: id }); that.formData.bleStatu = true;
that.bleStateRecovry({
deviceId: id
});
}).catch(ex => {
that.formData.bleStatu = 'err';
}); });
const deviceIdReversed = macToDeviceId(deviceMac); const deviceIdReversed = macToDeviceId(deviceMac);
console.log('[100J] 尝试直连', deviceIdReversed, '(MAC反序)'); console.log('[100J] 尝试直连', deviceIdReversed, '(MAC反序)');
@ -1070,11 +1138,16 @@
bleTool.StopSearch(); bleTool.StopSearch();
bleTool.removeDeviceFound('HBY100J_SCAN'); bleTool.removeDeviceFound('HBY100J_SCAN');
console.log('[100J] 扫描到目标设备', match.name, match.deviceId); console.log('[100J] 扫描到目标设备', match.name, match.deviceId);
that.formData.bleStatu = 'connecting';
bleTool.LinkBlue(match.deviceId, SVC, WRITE, NOTIFY, 2).then(() => { bleTool.LinkBlue(match.deviceId, SVC, WRITE, NOTIFY, 2).then(() => {
console.log('100J 蓝牙连接成功(扫描)'); console.log('100J 蓝牙连接成功(扫描)');
that.bleStateRecovry({ deviceId: match.deviceId }); that.formData.bleStatu = true;
that.bleStateRecovry({
deviceId: match.deviceId
});
}).catch(err => { }).catch(err => {
console.log('100J 蓝牙连接失败将使用4G', err); console.log('100J 蓝牙连接失败将使用4G', err);
that.formData.bleStatu = 'err';
}); });
} }
}, 'HBY100J_SCAN'); }, 'HBY100J_SCAN');
@ -1091,6 +1164,7 @@
}); });
}, },
bleStateBreak() { bleStateBreak() {
this.formData.bleStatu = false;
updateBleStatus(false, '', this.deviceInfo.deviceId); updateBleStatus(false, '', this.deviceInfo.deviceId);
}, },
bleStateRecovry(res) { bleStateRecovry(res) {
@ -1115,7 +1189,8 @@
previewImg(img) {}, previewImg(img) {},
bleValueNotify: function(receive, device, path, recArr) { //订阅消息 bleValueNotify: function(receive, device, path, recArr) { //订阅消息
// 仅处理当前设备的数据device 为 LinkedList 中匹配 receive.deviceId 的项) // 仅处理当前设备的数据device 为 LinkedList 中匹配 receive.deviceId 的项)
if (device && device.device && this.deviceInfo.deviceId && device.device.id != this.deviceInfo.deviceId) return; if (device && device.device && this.deviceInfo.deviceId && device.device.id != this.deviceInfo
.deviceId) return;
// 解析蓝牙上报数据 (协议: FC=MAC主动上报, FB=指令响应) // 解析蓝牙上报数据 (协议: FC=MAC主动上报, FB=指令响应)
if (!receive.bytes || receive.bytes.length < 3) return; if (!receive.bytes || receive.bytes.length < 3) return;
const parsedData = parseBleData(receive.bytes); const parsedData = parseBleData(receive.bytes);
@ -1144,9 +1219,7 @@
this.$set(this.deviceInfo, 'batteryRemainingTime', parsedData.batteryRemainingTime); this.$set(this.deviceInfo, 'batteryRemainingTime', parsedData.batteryRemainingTime);
} }
if (this.deviceInfo.batteryPercentage <= 20) {
uni.showToast({ title: '设备电量低', icon: 'none', duration: 2000 });
}
// 设备物理按键切换:蓝牙响应同步到 APP 页面(与 4G MQTT 逻辑一致) // 设备物理按键切换:蓝牙响应同步到 APP 页面(与 4G MQTT 逻辑一致)
const fc = parsedData.funcCode; const fc = parsedData.funcCode;
@ -1191,13 +1264,17 @@
else if (this.formData.sta_VoiceType === '7') this.formData.sta_VoiceType = '-1'; else if (this.formData.sta_VoiceType === '7') this.formData.sta_VoiceType = '-1';
} }
if (parsedData.volume !== undefined) this.formData.volume = parsedData.volume; if (parsedData.volume !== undefined) this.formData.volume = parsedData.volume;
if (parsedData.strobeFrequency !== undefined) this.formData.strobeFrequency = parsedData.strobeFrequency; if (parsedData.strobeFrequency !== undefined) this.formData.strobeFrequency = parsedData
if (parsedData.redBrightness !== undefined) this.formData.lightBrightness = parsedData.redBrightness; .strobeFrequency;
if (parsedData.redBrightness !== undefined) this.formData.lightBrightness = parsedData
.redBrightness;
} }
// 0x09 音量、0x0D 亮度:单独响应时同步 // 0x09 音量、0x0D 亮度:单独响应时同步
if (fc === 0x09 && parsedData.volume !== undefined) this.formData.volume = parsedData.volume; if (fc === 0x09 && parsedData.volume !== undefined) this.formData.volume = parsedData.volume;
if (fc === 0x0B && parsedData.strobeFrequency !== undefined) this.formData.strobeFrequency = parsedData.strobeFrequency; if (fc === 0x0B && parsedData.strobeFrequency !== undefined) this.formData.strobeFrequency = parsedData
if (fc === 0x0D && parsedData.redBrightness !== undefined) this.formData.lightBrightness = parsedData.redBrightness; .strobeFrequency;
if (fc === 0x0D && parsedData.redBrightness !== undefined) this.formData.lightBrightness = parsedData
.redBrightness;
}, },
showBleUnConnect() {}, showBleUnConnect() {},

View File

@ -60,12 +60,12 @@
</view> </view>
<view class="item" @click.top="bleStatuToggle"> <view class="item" @click.top="bleStatuToggle">
<text class="lbl">蓝牙状态</text> <text class="lbl">蓝牙状态</text>
<text class="value" :class="formData.bleStatu?'green':'red'">{{getbleStatu}}</text> <text class="value" :class="(!formData.bleStatu || formData.bleStatu==='err')?'red':'green'">{{getbleStatu}}</text>
</view>
<view class="item">
<text class="lbl">信道:{{formData.sta_Channel}}</text>
<text class="value green" @click.stop="ShowChannelEdit()">修改</text>
</view> </view>
<!-- <view class="item">
<text class="lbl">设备状态</text>
<text class="value">{{formData.sta_charge?dic.sta_charge[formData.sta_charge]:"" }}</text>
</view> -->
</view> </view>
<view class="warnnig" v-for="item,index in warnDevices"> <view class="warnnig" v-for="item,index in warnDevices">
@ -177,7 +177,14 @@
:iconUrl="Status.Pop.iconUrl" :message="Status.Pop.message" :buttonText="Status.Pop.buttonText" :iconUrl="Status.Pop.iconUrl" :message="Status.Pop.message" :buttonText="Status.Pop.buttonText"
@buttonClick="HidePop" :visiblePrompt="Status.Pop.visiblePrompt" :promptTitle="Status.Pop.promptTitle" @buttonClick="HidePop" :visiblePrompt="Status.Pop.visiblePrompt" :promptTitle="Status.Pop.promptTitle"
v-model="Status.Pop.modelValue" @closePop="closePop" :buttonCancelText="Status.Pop.buttonCancelText" v-model="Status.Pop.modelValue" @closePop="closePop" :buttonCancelText="Status.Pop.buttonCancelText"
:showCancel="Status.Pop.showCancel" @cancelPop="closePop" /> :showCancel="Status.Pop.showCancel" @cancelPop="closePop" :showSlot="Status.Pop.showSlot">
<view v-if="Status.ShowEditChannel" class="popup-prompt">
<text class="popup-prompt-title">修改信道</text>
<input class="popup-prompt-input" type="number" placeholder="1-125的整数"
placeholder-class="popup-prompt-input-placeHolder" v-model="formData.ins_Channel" />
</view>
</MessagePopup>
<!-- 下方菜单 --> <!-- 下方菜单 -->
@ -221,6 +228,7 @@
curr: 0, curr: 0,
total: 0, total: 0,
pageHide: false, pageHide: false,
ShowEditChannel: false,
Pop: { Pop: {
showPop: false, //是否显示弹窗 showPop: false, //是否显示弹窗
popType: 'custom', popType: 'custom',
@ -325,8 +333,8 @@
warnTime: '', warnTime: '',
sta_sosadd: "", sta_sosadd: "",
sta_sosName: '', sta_sosName: '',
sta_IntrusTime: '' sta_IntrusTime: '',
ins_Channel:23
}, },
dic: { dic: {
sta_LightType: [ sta_LightType: [
@ -519,7 +527,7 @@
}); });
} }
this.getLinkedCnt(); // this.getLinkedCnt();
}, },
computed: { computed: {
Distance: function() { Distance: function() {
@ -561,6 +569,73 @@
} }
}, },
methods: { methods: {
onChannelChanging() {
let f = this.getDevice();
// #ifdef APP-PLUS
if (!f) {
this.showBleUnConnect();
return;
}
// #endif
let regex = /^([1-9]|[1-7][0-9]|80)$/;
if (!regex.test(this.formData.ins_Channel)) {
uni.showModal({
title: '提示',
content: '只能输入1-80整数'
});
return;
}
var buffer = {
ins_Channel: this.formData.ins_Channel
}
ble.sendString(f.deviceId, buffer);
},
ShowChannelEdit() {
if (!this.permissions.includes('55') && this.Status.apiType !== 'listA') {
this.showPop({
message: '无操作权限',
iconUrl: "/static/images/6155/DeviceDetail/uploadErr.png",
borderColor: "#e034344d",
buttonBgColor: "#E03434",
okCallback: null,
buttonText: "确定"
})
return;
}
this.Status.ShowEditChannel = true;
this.showPop({
showPop: true, //是否显示弹窗
popType: 'custom',
bgColor: '#383934bd',
borderColor: '#BBE600',
textColor: '#ffffffde',
buttonBgColor: '#BBE600',
buttonTextColor: '#232323DE',
iconUrl: '',
message: '',
buttonText: '确定',
clickEvt: '',
visiblePrompt: false,
promptTitle: '',
modelValue: '',
visibleClose: false,
okCallback: () => {
this.onChannelChanging();
this.Status.ShowEditChannel = false;
},
showSlot: true,
buttonCancelText: '取消',
showCancel: true,
cancelCallback: () => {
this.Status.ShowEditChannel = false;
}
});
},
getLinkedCnt() { //获取在线设备的数量 getLinkedCnt() { //获取在线设备的数量
let f = this.getDevice(); let f = this.getDevice();
@ -2266,4 +2341,30 @@
/deep/ .uni-navbar--fixed { /deep/ .uni-navbar--fixed {
top: 0px; top: 0px;
} }
.popup-prompt-input {
width: 100%;
height: 60rpx;
line-height: 60rpx;
color: rgba(255, 255, 255, 0.87);
box-sizing: border-box;
border-bottom: 2rpx solid rgba(255, 255, 255, 0.4);
font-size: 28rpx;
font-weight: 400;
letter-spacing: 0.14px;
}
.popup-prompt-input-placeHolder {
color: rgba(255, 255, 255, 0.4);
font-family: PingFang SC;
font-size: 28rpx;
font-weight: 400;
letter-spacing: 0.14px;
text-align: center;
}
</style> </style>

View File

@ -10,8 +10,8 @@
</uni-nav-bar> </uni-nav-bar>
<view class="contentBg"> <view class="contentBg">
<view class="row"> <view class="row">
<view class="typeItem fleft" :class="{'active':Status.tabType=='link'}" @click.stop="tabChange('link')"> <!-- <view class="typeItem fleft" :class="{'active':Status.tabType=='link'}" @click.stop="tabChange('link')">
连接记录</view> 连接记录</view> -->
<view class="typeItem fleft" :class="{'active':Status.tabType=='warn'}" @click.stop="tabChange('warn')"> <view class="typeItem fleft" :class="{'active':Status.tabType=='warn'}" @click.stop="tabChange('warn')">
报警记录</view> 报警记录</view>
<view class="filterIco fright" @click.stop="showFilter()"> <view class="filterIco fright" @click.stop="showFilter()">
@ -90,7 +90,7 @@
<view class="mothItem center" :class="{active:Status.filterDayType=='monthThree'}" <view class="mothItem center" :class="{active:Status.filterDayType=='monthThree'}"
@click.stop="mothItemChange('monthThree')">近三个月</view> @click.stop="mothItemChange('monthThree')">近三个月</view>
<view class="mothItem center" :class="{active:Status.filterDayType=='monthOne'}" <view class="mothItem center" :class="{active:Status.filterDayType=='monthOne'}"
@click.stop="mothItemChange('monthOne')" }>近一个月</view> @click.stop="mothItemChange('monthOne')" >近一个月</view>
<view class="mothItem center" :class="{active:Status.filterDayType=='customer'}" <view class="mothItem center" :class="{active:Status.filterDayType=='customer'}"
@click.stop="mothItemChange('customer')">自定义</view> @click.stop="mothItemChange('customer')">自定义</view>
@ -204,7 +204,7 @@
filterMode: true, //是否筛选日期 filterMode: true, //是否筛选日期
filterDayMode: 'end', //当前筛选的是开始还是结束 filterDayMode: 'end', //当前筛选的是开始还是结束
filterDayType: 'customer', //当前筛选的日期是哪种类型 filterDayType: 'customer', //当前筛选的日期是哪种类型
tabType: 'link', tabType: 'warn',
datePickValue: [999, 999, 999] //日期选择控件绑定的值 datePickValue: [999, 999, 999] //日期选择控件绑定的值
@ -251,10 +251,10 @@
let eventChannel = this.getOpenerEventChannel(); let eventChannel = this.getOpenerEventChannel();
eventChannel.on('detailData', function(data) { eventChannel.on('detailData', (data)=> {
var device = data.data; var device = data.data;
these.device = device; this.device = device;
these.tabChange('link'); this.tabChange('warn');
}); });
@ -304,7 +304,7 @@
let today = new Date(); let today = new Date();
let end = Common.DateFormat(today, 'yyyy-MM-dd'); let end = Common.DateFormat(today, 'yyyy-MM-dd');
let start = Common.DateFormat(today.setMonth(diff), 'yyyy-MM-dd'); let start = Common.DateFormat(today.setMonth(today.getMonth()+ diff), 'yyyy-MM-dd');
this.filter.start = start; this.filter.start = start;
this.filter.end = end; this.filter.end = end;
@ -595,7 +595,9 @@
if (!these.Status.filterMode) { if (!these.Status.filterMode) {
if (these.filter.MM) { if (these.filter.MM) {
start = new Date(these.filter.MM + '-01'); start = new Date(these.filter.MM + '-01');
end = start.setMonth(1); end = new Date(these.filter.MM + '-01')
end.setMonth(end.getMonth()+1);
end.setDate(end.getDate()+1);
data = data.filter(v => { data = data.filter(v => {
let t = v.linkEqs[0].linkTime let t = v.linkEqs[0].linkTime
@ -613,7 +615,7 @@
console.log("these.filter.end=",these.filter.end); console.log("these.filter.end=",these.filter.end);
start = new Date(these.filter.start); start = new Date(these.filter.start);
end = new Date(these.filter.end); end = new Date(these.filter.end);
end.setMonth(1); end.setDate(end.getDate()+1);
console.log("start=",start); console.log("start=",start);
console.log("end=",end); console.log("end=",end);
if(start && end){ if(start && end){
@ -643,7 +645,8 @@
return t >= start; return t >= start;
}); });
} else if (these.filter.end) { } else if (these.filter.end) {
end = new Date(these.filter.end).setMonth(1); end = new Date(these.filter.end);
end.setDate(end.getDate()+1);
data = data.filter(v => { data = data.filter(v => {
@ -680,7 +683,7 @@
if (systemInfo.uniPlatform == 'web') { if (systemInfo.uniPlatform == 'web') {
for (let i = 0; i < 20; i++) { for (let i = 0; i < 20; i++) {
const timestamp = 1710072900000 + (i * 3600000); // 每小时递增 const timestamp = new Date().getTime() - (i * 3600000); // 每小时递增
const numItems = Math.floor(Math.random() * 5) + 1; // 1-5条 const numItems = Math.floor(Math.random() * 5) + 1; // 1-5条
const item = { const item = {
@ -740,7 +743,8 @@
console.log("hese.filter.end=" + these.filter.end); console.log("hese.filter.end=" + these.filter.end);
let start = new Date(these.filter.start); let start = new Date(these.filter.start);
let end = new Date(these.filter.end); let end = new Date(these.filter.end);
end.setMonth(1);
end.setDate(end.getDate()+ 1);
data = data.filter(v => { data = data.filter(v => {
let t = v.warnTime let t = v.warnTime
@ -748,7 +752,7 @@
t = new Date(v.warnTime); t = new Date(v.warnTime);
} }
return t >= start && t <= end; return t >= start && t < end;
}); });
} else if (these.filter.start) { } else if (these.filter.start) {
let start = new Date(these.filter.start); let start = new Date(these.filter.start);
@ -762,7 +766,8 @@
return t >= start; return t >= start;
}); });
} else if (these.filter.end) { } else if (these.filter.end) {
let end = new Date(these.filter.end).setMonth(1); let end = new Date(these.filter.end);
end.setDate(end.getDate()+ 1);
data = data.filter(v => { data = data.filter(v => {
let t = v.warnTime let t = v.warnTime
if (!(t instanceof Date)) { if (!(t instanceof Date)) {
@ -774,7 +779,9 @@
} else { } else {
if (these.filter.MM) { if (these.filter.MM) {
let start = new Date(these.filter.MM + '-01'); let start = new Date(these.filter.MM + '-01');
let end = start.setMonth(1); let end = new Date(these.filter.MM + '-01');
end.setMonth(end.getMonth()+1);
end.setDate(end.getDate()+1);
data = data.filter((v) => { data = data.filter((v) => {
let t = v.warnTime let t = v.warnTime
if (!(t instanceof Date)){ if (!(t instanceof Date)){

View File

@ -824,7 +824,7 @@
let packetData = these.rgb565Data.slice(startIndex, let packetData = these.rgb565Data.slice(startIndex,
endIndex); endIndex);
// 构建数据包 // 构建数据包
let bufferSize = os == 'Android' ? 505 :133; // 5 + packetData.length * 2; // 头部5字节 + 数据部分 let bufferSize = os ==packetSize.length*2+5; // 5 + packetData.length * 2; // 头部5字节 + 数据部分
let buffer = new ArrayBuffer(bufferSize); let buffer = new ArrayBuffer(bufferSize);
let dataView = new DataView(buffer); let dataView = new DataView(buffer);

View File

@ -340,7 +340,7 @@ export default {
value: "55", value: "55",
label: "修改信道", label: "修改信道",
checked: false, checked: false,
type: ['4877'] type: ['4877','102']
}, },
{ {
value: "56", value: "56",