Compare commits
2 Commits
4790892a24
...
864dd59b4c
| Author | SHA1 | Date | |
|---|---|---|---|
| 864dd59b4c | |||
| a8ce1d9680 |
3
App.vue
3
App.vue
@ -36,6 +36,7 @@
|
|||||||
},
|
},
|
||||||
onShow: function() {
|
onShow: function() {
|
||||||
console.log('App Show');
|
console.log('App Show');
|
||||||
|
|
||||||
//将检查更新换到onshow,因为苹果用户喜欢一直挂着
|
//将检查更新换到onshow,因为苹果用户喜欢一直挂着
|
||||||
uni.getSystemInfo({
|
uni.getSystemInfo({
|
||||||
success: function(res) {
|
success: function(res) {
|
||||||
@ -46,8 +47,6 @@
|
|||||||
console.log("appid=", appid);
|
console.log("appid=", appid);
|
||||||
upgrade.checkAndUpdateWgt();
|
upgrade.checkAndUpdateWgt();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|||||||
@ -2,7 +2,7 @@
|
|||||||
const config = {
|
const config = {
|
||||||
// 开发环境
|
// 开发环境
|
||||||
development: {
|
development: {
|
||||||
BASE_URL: 'https://www.cnxhyc.com/jq',
|
BASE_URL: 'http://139.224.253.23:8000',
|
||||||
API_PREFIX: '',
|
API_PREFIX: '',
|
||||||
// MQTT 配置
|
// MQTT 配置
|
||||||
MQTT_HOST: 'www.cnxhyc.com',
|
MQTT_HOST: 'www.cnxhyc.com',
|
||||||
|
|||||||
@ -56,7 +56,8 @@
|
|||||||
"<uses-permission android:name=\"android.permission.BLUETOOTH_CONNECT\"/>"
|
"<uses-permission android:name=\"android.permission.BLUETOOTH_CONNECT\"/>"
|
||||||
],
|
],
|
||||||
"minSdkVersion" : 21,
|
"minSdkVersion" : 21,
|
||||||
"abiFilters" : [ "armeabi-v7a", "arm64-v8a", "x86" ]
|
"abiFilters" : [ "armeabi-v7a", "arm64-v8a", "x86" ],
|
||||||
|
"schemes" : ""
|
||||||
},
|
},
|
||||||
/* ios打包配置 */
|
/* ios打包配置 */
|
||||||
"ios" : {
|
"ios" : {
|
||||||
@ -72,7 +73,8 @@
|
|||||||
"NSCameraUsageDescription" : "App需要您的同意访问相机,用于上传头像,设备开机画面",
|
"NSCameraUsageDescription" : "App需要您的同意访问相机,用于上传头像,设备开机画面",
|
||||||
"NSMicrophoneUsageDescription" : "App需要您的同意访问麦克风,用于上传语音包"
|
"NSMicrophoneUsageDescription" : "App需要您的同意访问麦克风,用于上传语音包"
|
||||||
},
|
},
|
||||||
"idfa" : false
|
"idfa" : false,
|
||||||
|
"urltypes" : ""
|
||||||
},
|
},
|
||||||
/* SDK配置 */
|
/* SDK配置 */
|
||||||
"sdkConfigs" : {
|
"sdkConfigs" : {
|
||||||
|
|||||||
@ -77,7 +77,7 @@
|
|||||||
<text class="smallTxt">泛光模式</text>
|
<text class="smallTxt">泛光模式</text>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<!-- <view class="mode fleft" v-on:click.stop="UploadOpenImg()">
|
<view class="mode fleft" v-on:click.stop="UploadOpenImg()">
|
||||||
<view class="leftImg">
|
<view class="leftImg">
|
||||||
<image class="img" src="/static/images/6155/DeviceDetail/open.png" mode="aspectFit"></image>
|
<image class="img" src="/static/images/6155/DeviceDetail/open.png" mode="aspectFit"></image>
|
||||||
</view>
|
</view>
|
||||||
@ -85,8 +85,8 @@
|
|||||||
<text class="bigTxt">开机画面</text>
|
<text class="bigTxt">开机画面</text>
|
||||||
<text class="smallTxt">上传</text>
|
<text class="smallTxt">上传</text>
|
||||||
</view>
|
</view>
|
||||||
</view> -->
|
</view>
|
||||||
<view class="mode fleft" v-on:click.stop="UploadOpenVideo()">
|
<view class="mode fleft marginLeft" v-on:click.stop="UploadOpenVideo()">
|
||||||
<view class="leftImg">
|
<view class="leftImg">
|
||||||
<image class="img" src="/static/images/common/video.png" mode="aspectFit"></image>
|
<image class="img" src="/static/images/common/video.png" mode="aspectFit"></image>
|
||||||
</view>
|
</view>
|
||||||
@ -446,35 +446,6 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
calcTotalPackets(frames) {
|
|
||||||
if (!Array.isArray(frames) || frames.length === 0) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
return frames.reduce((frameSum, frame) => {
|
|
||||||
if (!Array.isArray(frame)) {
|
|
||||||
return frameSum;
|
|
||||||
}
|
|
||||||
const packSum = frame.reduce((packAcc, pack) => {
|
|
||||||
if (!Array.isArray(pack)) {
|
|
||||||
return packAcc;
|
|
||||||
}
|
|
||||||
return packAcc + pack.length;
|
|
||||||
}, 0);
|
|
||||||
return frameSum + packSum;
|
|
||||||
}, 0);
|
|
||||||
},
|
|
||||||
toByteValue(value) {
|
|
||||||
if (typeof value === 'number') {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
if (typeof value === 'string') {
|
|
||||||
if (value.startsWith('0x') || value.startsWith('0X')) {
|
|
||||||
return parseInt(value, 16);
|
|
||||||
}
|
|
||||||
return parseInt(`0x${value}`, 16);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
},
|
|
||||||
deviceRecovry(res) {
|
deviceRecovry(res) {
|
||||||
if (this.Status.pageHide) {
|
if (this.Status.pageHide) {
|
||||||
return;
|
return;
|
||||||
@ -574,22 +545,13 @@
|
|||||||
if (!json) {
|
if (!json) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
console.log("收到设备数据:", json);
|
|
||||||
let keys = Object.keys(json);
|
let keys = Object.keys(json);
|
||||||
keys.forEach((key) => {
|
keys.forEach((key) => {
|
||||||
if (key in these.formData) {
|
if (key in these.formData) {
|
||||||
// 确保响应式更新
|
these.formData[key] = json[key];
|
||||||
console.log(`更新字段 ${key}: ${these.formData[key]} -> ${json[key]}`);
|
|
||||||
these.$set(these.formData, key, json[key]);
|
|
||||||
} else {
|
|
||||||
console.log(`字段 ${key} 不在 formData 中,跳过更新`);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// 强制触发视图更新,确保电量显示同步
|
|
||||||
these.$forceUpdate();
|
|
||||||
console.log("更新后的电量:", these.formData.battary);
|
|
||||||
|
|
||||||
if (this.formData.battary <= 20) {
|
if (this.formData.battary <= 20) {
|
||||||
this.showPop({
|
this.showPop({
|
||||||
message: "设备电量低",
|
message: "设备电量低",
|
||||||
@ -915,7 +877,7 @@
|
|||||||
"clientid": clientid
|
"clientid": clientid
|
||||||
},
|
},
|
||||||
formData: {
|
formData: {
|
||||||
code: 2
|
code: 1
|
||||||
},
|
},
|
||||||
timeout: 600000,
|
timeout: 600000,
|
||||||
fail: (ex) => {
|
fail: (ex) => {
|
||||||
@ -937,7 +899,7 @@
|
|||||||
|
|
||||||
if (res.statusCode === 200) {
|
if (res.statusCode === 200) {
|
||||||
if (res.data.code == 200) {
|
if (res.data.code == 200) {
|
||||||
console.log("上传完成,耗时:" + m + "分" + s + "秒");
|
console.log("上传完成,耗时:" + m + "分" + s + "秒,获得数据:"+res.data.length);
|
||||||
updateLoading(these, {
|
updateLoading(these, {
|
||||||
text: "上传完成,耗时:" + m + "分" + s + "秒,正在切片。"
|
text: "上传完成,耗时:" + m + "分" + s + "秒,正在切片。"
|
||||||
})
|
})
|
||||||
@ -961,38 +923,41 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
//视频切片
|
//视频切片
|
||||||
let videoCutPacket = (data) => {
|
let videoCutPacket = (array) => {
|
||||||
|
console.log("开始切片:",array.length);
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
try {
|
try {
|
||||||
const imgSize = 25600;
|
let index=0;
|
||||||
const packetSize = 3200;
|
let imgSize = 25600;
|
||||||
const chunkSize = 500;
|
let packetSize = 3200;
|
||||||
const maxPacketCount = 30;
|
let tdSize = 500; //只能是400/500
|
||||||
|
let childPackLength = (tdSize === 400 ? 8 : 7);
|
||||||
let source = Array.isArray(data) ? data.slice() : [];
|
|
||||||
let results = [];
|
let results = [];
|
||||||
for (let i = 0; i < maxPacketCount && source.length >= imgSize; i++) {
|
for (let i = 0; i < 30; i++) { //先切出30张,每张25600字节
|
||||||
let frameBytes = source.splice(0, imgSize);
|
let packet = array.slice(0, imgSize);
|
||||||
let framePackets = [];
|
array.splice(0, imgSize)
|
||||||
|
|
||||||
for (let j = 0; j < 8 && frameBytes.length > 0; j++) {
|
let secondLevel = [];
|
||||||
let majorPacket = frameBytes.splice(0, packetSize);
|
for (let j = 0; j < 8; j++) { //每张切8大包,每包3200字节
|
||||||
let childPackets = [];
|
let childPacket = packet.slice(0, packetSize);
|
||||||
|
|
||||||
while (majorPacket.length > 0) {
|
packet.splice(0, packetSize);
|
||||||
let chunk = majorPacket.splice(0, chunkSize);
|
|
||||||
if (chunk.length) {
|
|
||||||
childPackets.push(chunk);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (childPackets.length) {
|
|
||||||
framePackets.push(childPackets);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (framePackets.length) {
|
let thirdLevel = [];
|
||||||
results.push(framePackets);
|
for (let k = 0; k < childPackLength; k++) {
|
||||||
|
//如果每小包500字节的话,每1个大包切出7个小包,前6包500字节,第7包200字节,共计56小包
|
||||||
|
//如果每小包400字节的话,每1个大包切出8个小包,每包400字节,共计64小包
|
||||||
|
|
||||||
|
let arr = childPacket.slice(0, tdSize);
|
||||||
|
|
||||||
|
childPacket.splice(0, tdSize)
|
||||||
|
thirdLevel.push(arr);
|
||||||
|
index++;
|
||||||
|
console.log("第"+index+"包长度:"+arr.length);
|
||||||
}
|
}
|
||||||
|
secondLevel.push(thirdLevel);
|
||||||
|
}
|
||||||
|
results.push(secondLevel);
|
||||||
}
|
}
|
||||||
updateLoading(these, {
|
updateLoading(these, {
|
||||||
text: '切片完成,正在发送'
|
text: '切片完成,正在发送'
|
||||||
@ -1005,25 +970,31 @@
|
|||||||
reject(error);
|
reject(error);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//发送视频到设备
|
//发送视频到设备
|
||||||
let shotVideoClick = (array, type, ReSendNo) => {
|
let shotVideoClick = (array, type, ReSendNo) => {
|
||||||
var sendImagePackets = () => {
|
var sendImagePackets = () => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
this.currentPacket = 0;
|
this.currentPacket = 0;
|
||||||
let totalPackets = these.calcTotalPackets(array);
|
let smallPacketLen = array[0][0][0].length;
|
||||||
|
// 总数据包数,每包400字节就是1920包,每包500字节时1680包
|
||||||
|
var totalPackets = smallPacketLen === 400 ? 1920 : 1680;
|
||||||
this.totalPackets = totalPackets;
|
this.totalPackets = totalPackets;
|
||||||
if (totalPackets === 0) {
|
|
||||||
reject('没有可发送的数据');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let currentPacket = 1;
|
let currentPacket = 1;
|
||||||
|
|
||||||
let imgIndex = 0;
|
let imgIndex = 0;
|
||||||
let imgPackIndex = 0;
|
let imgPackIndex = 0;
|
||||||
let childPacketIndex = 0;
|
let childPacketIndex = 0;
|
||||||
if (ReSendNo) {
|
if (ReSendNo) {
|
||||||
|
|
||||||
this.currentPacket = ReSendNo - 1;
|
this.currentPacket = ReSendNo - 1;
|
||||||
currentPacket = ReSendNo;
|
currentPacket = ReSendNo;
|
||||||
totalPackets = ReSendNo;
|
totalPackets = ReSendNo;
|
||||||
@ -1031,49 +1002,59 @@
|
|||||||
}
|
}
|
||||||
// 发送单个数据包
|
// 发送单个数据包
|
||||||
const sendNextPacket = () => {
|
const sendNextPacket = () => {
|
||||||
if (imgIndex >= array.length) {
|
// console.log("111111")
|
||||||
|
if (currentPacket > totalPackets) {
|
||||||
resolve();
|
resolve();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
// console.log("111111")
|
||||||
|
// 计算当前包的数据
|
||||||
|
let packetSize = smallPacketLen;
|
||||||
|
|
||||||
if (!array[imgIndex]) {
|
|
||||||
console.error("没有找到对应的帧数据", imgIndex);
|
|
||||||
reject(`帧数据缺失,索引 ${imgIndex}`);
|
if (smallPacketLen === 500) {
|
||||||
return;
|
if ((currentPacket - 1) % 56 === 0) {
|
||||||
|
packetSize = 508;
|
||||||
}
|
}
|
||||||
|
|
||||||
let childPacketsGroup = array[imgIndex][imgPackIndex];
|
if (childPacketIndex === 6) {
|
||||||
if (!childPacketsGroup || !childPacketsGroup.length) {
|
packetSize = 200;
|
||||||
console.error("帧数据结构异常", imgIndex, imgPackIndex);
|
|
||||||
reject(`帧数据结构异常,帧 ${imgIndex}`);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let packetData = childPacketsGroup[childPacketIndex];
|
if ((currentPacket - 1) % 56 === 55) {
|
||||||
let packetSize = packetData.length;
|
packetSize = 201;
|
||||||
|
}
|
||||||
const isFirstChild = childPacketIndex === 0;
|
} else if (smallPacketLen === 400) {
|
||||||
const isLastChild = childPacketIndex === (childPacketsGroup
|
if ((currentPacket - 1) % 64 === 0) {
|
||||||
.length - 1);
|
packetSize = 408;
|
||||||
|
}
|
||||||
if (isFirstChild) {
|
if ((currentPacket - 1) % 64 === 63) {
|
||||||
packetSize = packetData.length + 8;
|
packetSize = 401;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isLastChild) {
|
|
||||||
packetSize = packetData.length + (isFirstChild ? 9 : 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
const buffer = new ArrayBuffer(packetSize);
|
|
||||||
const dataView = new DataView(buffer);
|
|
||||||
|
|
||||||
|
let packetData = array[imgIndex][imgPackIndex][childPacketIndex];
|
||||||
|
console.log("imgIndex=" + imgIndex + ",imgPackIndex=" +imgPackIndex +",childPacketIndex=" + childPacketIndex+',packetData='+packetData.length);
|
||||||
|
|
||||||
|
let buffer = new ArrayBuffer(packetSize);
|
||||||
|
let dataView = new DataView(buffer);
|
||||||
|
|
||||||
|
let sortNo = currentPacket.toString(16).padStart(4, '0');
|
||||||
|
// console.log("11111");
|
||||||
let start = 0;
|
let start = 0;
|
||||||
if (isFirstChild) {
|
if (((currentPacket - 1) % 56 === 0 && smallPacketLen === 500)
|
||||||
|
|| ((currentPacket - 1) % 64 ===0 && smallPacketLen === 400)) {
|
||||||
// 填充头部
|
// 填充头部
|
||||||
dataView.setUint8(0, 0xFA); // 帧头
|
dataView.setUint8(0, 0xFA); // 帧头
|
||||||
dataView.setUint8(1, 0x09); // 帧类型:开机画面
|
dataView.setUint8(1, 0x09); // 帧类型:开机画面
|
||||||
dataView.setUint8(2, 0x0C);
|
dataView.setUint8(2, 0x0C);
|
||||||
dataView.setUint8(3, 0x84);
|
dataView.setUint8(3, 0x84);
|
||||||
|
|
||||||
|
|
||||||
dataView.setUint8(4, 0xFD);
|
dataView.setUint8(4, 0xFD);
|
||||||
dataView.setUint8(5, 0x09);
|
dataView.setUint8(5, 0x09);
|
||||||
dataView.setUint8(6, imgIndex);
|
dataView.setUint8(6, imgIndex);
|
||||||
@ -1082,17 +1063,24 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (let i = 0; i < packetData.length; i++) {
|
for (let i = 0; i < packetData.length; i++) {
|
||||||
dataView.setUint8(start + i, these.toByteValue(packetData[i]));
|
dataView.setUint8(start + i, '0x' + packetData[i]);
|
||||||
}
|
}
|
||||||
|
if (smallPacketLen === 500) {
|
||||||
if (isLastChild) {
|
if ((currentPacket - 1) % 56 === 55) {
|
||||||
dataView.setUint8(packetSize - 1, 0xFF);
|
dataView.setUint8(200, 0xFF);
|
||||||
}
|
}
|
||||||
|
} else if (smallPacketLen === 400) {
|
||||||
|
if ((currentPacket - 1) % 64 === 63) {
|
||||||
|
dataView.setUint8(200, 0xFF);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// console.log("444444");
|
||||||
let inteval = parseInt(this.inteval ? this.inteval : 80);
|
let inteval = parseInt(this.inteval ? this.inteval : 80);
|
||||||
|
|
||||||
ble.sendData(f.deviceId, buffer, f.writeServiceId, f
|
ble.sendData(f.deviceId, buffer, f.writeServiceId, f
|
||||||
.wirteCharactId).then(() => {
|
.wirteCharactId,15).then(() => {
|
||||||
if (ReSendNo) {
|
if (ReSendNo) {
|
||||||
|
|
||||||
resolve();
|
resolve();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1104,18 +1092,21 @@
|
|||||||
totalPackets
|
totalPackets
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
childPacketIndex++;
|
childPacketIndex++;
|
||||||
if (childPacketIndex >= childPacketsGroup.length) {
|
if (childPacketIndex == (smallPacketLen === 500?7:8)) {
|
||||||
childPacketIndex = 0;
|
|
||||||
imgPackIndex++;
|
imgPackIndex++;
|
||||||
if (imgPackIndex >= array[imgIndex].length) {
|
if (imgPackIndex == 8) {
|
||||||
imgPackIndex = 0;
|
|
||||||
imgIndex++;
|
imgIndex++;
|
||||||
|
imgPackIndex = 0;
|
||||||
}
|
}
|
||||||
|
childPacketIndex = 0;
|
||||||
}
|
}
|
||||||
// 发送下一个包(添加延迟避免蓝牙缓冲区溢出)
|
// 发送下一个包(添加延迟避免蓝牙缓冲区溢出)
|
||||||
currentPacket++;
|
currentPacket++;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
setTimeout(sendNextPacket, inteval);
|
setTimeout(sendNextPacket, inteval);
|
||||||
}).catch(err => {
|
}).catch(err => {
|
||||||
if (err.code == 10007) {
|
if (err.code == 10007) {
|
||||||
@ -1132,31 +1123,38 @@
|
|||||||
reject(err);
|
reject(err);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// console.log("111111")
|
||||||
|
|
||||||
sendNextPacket();
|
sendNextPacket();
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
return sendImagePackets();
|
return sendImagePackets();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uni.chooseVideo({
|
uni.chooseVideo({
|
||||||
sourceType: ['album'],
|
sourceType: ['album'],
|
||||||
|
compressed:false,
|
||||||
success: function(res) {
|
success: function(res) {
|
||||||
console.log("res=", res);
|
console.log("res=", res);
|
||||||
let path = res.tempFilePath;
|
let path = res.tempFilePath;
|
||||||
// iOS可能返回浮点数,需要转换为整数进行比较
|
let width = res.width;
|
||||||
let width = Math.round(res.width);
|
let height = res.height;
|
||||||
let height = Math.round(res.height);
|
|
||||||
let duration = res.duration;
|
let duration = res.duration;
|
||||||
console.log("视频信息 - 宽度:", width, "高度:", height, "时长:", duration);
|
|
||||||
let err = [];
|
let err = [];
|
||||||
if (duration < 2) {
|
if (duration < 2) {
|
||||||
err.push("视频时长至少2秒");
|
err.push("视频时长至少2秒");
|
||||||
}
|
}
|
||||||
|
|
||||||
// 使用容差比较,允许1像素的误差(iOS可能有精度问题)
|
// if (width != 160 || height != 80) {
|
||||||
if (Math.abs(width - 160) > 1 || Math.abs(height - 80) > 1) {
|
// err.push("视频宽高必须是160*80");
|
||||||
err.push("视频宽高必须是160*80,当前分辨率:" + width + "*" + height);
|
// }
|
||||||
}
|
|
||||||
if (err.length > 0) {
|
if (err.length > 0) {
|
||||||
err = err.join(";");
|
err = err.join(";");
|
||||||
these.showPop({
|
these.showPop({
|
||||||
@ -1173,25 +1171,7 @@
|
|||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
uplploadVideo(path).then(result => {
|
uplploadVideo(path).then(result => {
|
||||||
|
|
||||||
let data = result.data;
|
videoCutPacket(result.data).then(array => {
|
||||||
let convertedData = [];
|
|
||||||
for (let i = 0; i < data.length; i += 2) {
|
|
||||||
if (i + 1 < data.length) {
|
|
||||||
const byte1 = these.toByteValue(data[i]);
|
|
||||||
const byte2 = these.toByteValue(data[i + 1]);
|
|
||||||
const rgb565 = (byte1 << 8) | byte2;
|
|
||||||
const red = (rgb565 & 0xF800) >> 11;
|
|
||||||
const green = (rgb565 & 0x07E0) >> 5;
|
|
||||||
const blue = (rgb565 & 0x001F);
|
|
||||||
const bgr565 = (blue << 11) | (green << 5) | red;
|
|
||||||
convertedData.push((bgr565 >> 8) & 0xFF);
|
|
||||||
convertedData.push(bgr565 & 0xFF);
|
|
||||||
} else {
|
|
||||||
convertedData.push(these.toByteValue(data[i]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
videoCutPacket(convertedData).then(array => {
|
|
||||||
|
|
||||||
let start = new Date();
|
let start = new Date();
|
||||||
console.log("开始发送");
|
console.log("开始发送");
|
||||||
@ -1480,24 +1460,6 @@
|
|||||||
these.showBleUnConnect()
|
these.showBleUnConnect()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let err = false;
|
|
||||||
this.formData.textLines.find((txt) => {
|
|
||||||
if (txt.length === 0 || txt.length > 7) {
|
|
||||||
console.log("txt=", txt);
|
|
||||||
err = true;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
})
|
|
||||||
if (err) {
|
|
||||||
this.showPop({
|
|
||||||
message: "单位、部门、姓名必须填写且最多7字",
|
|
||||||
iconUrl: "/static/images/6155/DeviceDetail/uploadErr.png",
|
|
||||||
borderColor: "#e034344d",
|
|
||||||
buttonBgColor: "#E03434",
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
showLoading(these, {
|
showLoading(these, {
|
||||||
text: "请稍候..."
|
text: "请稍候..."
|
||||||
});
|
});
|
||||||
@ -1604,8 +1566,8 @@
|
|||||||
});
|
});
|
||||||
console.log("result=", result);
|
console.log("result=", result);
|
||||||
|
|
||||||
// var str1="FA 06 01 00 FF FF F7 9F EF 6F EC F7 EA 09 CF FF AF FB EF EB EF EB EC 6B EF EB EC 6B EF EB EF FB EE 63 FF FF FF FF F7 9F EF 6F EC F7 EA 09 CF FF AF FB EF EB EF EB EC 6B EF EB EC 6B EF EB EF FB EE 63 FF FF FF FF F7 FF 81 03 ED BB DD B7 CB CF F3 C7 CD 39 BE FF FE FF C0 03 FE FB FD FB F3 F7 8F 87 FF FF FF FF FE FF FE FF FE FF C0 03 FF FB FD FB FD FB FD FB FD FB FB FB FB FF F7 F7 EF F7 9F 8F FF FF 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 FF"
|
// var str1="FA 06 01 00 FF FF F7 9F EF 6F EC F7 EA 09 CF FF AF FB EF EB EF EB EC 6B EF EB EC 6B EF EB EF FB EE 63 FF FF FF FF F7 9F EF 6F EC F7 EA 09 CF FF AF FB EF EB EF EB EC 6B EF EB EC 6B EF EB EF FB EE 63 FF FF FF FF F7 FF 81 03 ED BB DD B7 CB CF F3 C7 CD 39 BE FF FE FF C0 03 FE FB FD FB F3 F7 8F 87 FF FF FF FF FE FF FE FF FE FF C0 03 FF FB FD FB FD FB FD FB FD FB FB FB FB FF F7 F7 EF F7 9F 8F FF FF 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 FF"
|
||||||
// var str2="FA 07 01 00 FF FF EE DD EE DF EF 5B AB DF AA 03 AE FF AE FF EE 03 EE FF EE FF EE 03 EE FF EE FF EE E3 FF FF FF FF EE DD EE DF EF 5B AB DF AA 03 AE FF AE FF EE 03 EE FF EE FF EE 03 EE FF EE FF EE E3 FF FF FF FF EF 77 EF 73 EF 7F 80 01 EF 7F EF 7F EF 03 E7 3B 8E BB EE D7 EE EF ED E7 ED 9B 8B 7D FF FF FF FF FF FF F7 EF F7 F7 EF F7 DF FB FF FF FF FF FE FF 80 01 FE 7F FD BF FB DF F7 E7 9F F9 FF FF 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 FF"
|
// var str2="FA 07 01 00 FF FF EE DD EE DF EF 5B AB DF AA 03 AE FF AE FF EE 03 EE FF EE FF EE 03 EE FF EE FF EE E3 FF FF FF FF EE DD EE DF EF 5B AB DF AA 03 AE FF AE FF EE 03 EE FF EE FF EE 03 EE FF EE FF EE E3 FF FF FF FF EF 77 EF 73 EF 7F 80 01 EF 7F EF 7F EF 03 E7 3B 8E BB EE D7 EE EF ED E7 ED 9B 8B 7D FF FF FF FF FF FF F7 EF F7 F7 EF F7 DF FB FF FF FF FF FE FF 80 01 FE 7F FD BF FB DF F7 E7 9F F9 FF FF 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 FF"
|
||||||
// var str3="FA 08 01 00 FF FF EF DF EC 01 EF FF AB FF AA 03 AA FB AE FB EE 03 EF DF EF DF EE DB ED DF ED DD EF 1F FF FF FF FF EF BF EF 87 81 77 EE F7 EC 03 81 7F EF 7F EF 7F EF 03 81 7F EF 7F EF 7D EF 7D EF 03 FF FF FF FF F9 F1 CF BF DF FF DF FF C1 FF DD 81 DD F7 DD F7 C1 F7 DF 77 FF 77 BF 77 BF 77 FF F7 FF FF FF FF FD FF FD FF FB FF FB FF F0 07 E7 F7 EF F7 D8 07 BF F7 FF F7 F8 07 FF F7 FF F7 FF C7 FF FF FF FF FF FF FF FF FF FF FE FF FE 7F FE 7F FE FF FD BF FD FF FB DF F7 EF EF F7 DF FB BF FD FF FF 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 FF"
|
// var str3="FA 08 01 00 FF FF EF DF EC 01 EF FF AB FF AA 03 AA FB AE FB EE 03 EF DF EF DF EE DB ED DF ED DD EF 1F FF FF FF FF EF BF EF 87 81 77 EE F7 EC 03 81 7F EF 7F EF 7F EF 03 81 7F EF 7F EF 7D EF 7D EF 03 FF FF FF FF F9 F1 CF BF DF FF DF FF C1 FF DD 81 DD F7 DD F7 C1 F7 DF 77 FF 77 BF 77 BF 77 FF F7 FF FF FF FF FD FF FD FF FB FF FB FF F0 07 E7 F7 EF F7 D8 07 BF F7 FF F7 F8 07 FF F7 FF F7 FF C7 FF FF FF FF FF FF FF FF FF FF FE FF FE 7F FE 7F FE FF FD BF FD FF FB DF F7 EF EF F7 DF FB BF FD FF FF 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 FF"
|
||||||
|
|
||||||
// let arr1=('0x'+(str1.split(' ').join(",0x"))).split(',');
|
// let arr1=('0x'+(str1.split(' ').join(",0x"))).split(',');
|
||||||
|
|||||||
@ -2,9 +2,9 @@
|
|||||||
<view class="content contentBg">
|
<view class="content contentBg">
|
||||||
<custom-navbar :title="Status.navbar.title" :showBack="Status.navbar.showBack" color="#FFFFFF"
|
<custom-navbar :title="Status.navbar.title" :showBack="Status.navbar.showBack" color="#FFFFFF"
|
||||||
:rightIcons="Status.navbar.icons" @icon-click="handleRightClick"></custom-navbar>
|
:rightIcons="Status.navbar.icons" @icon-click="handleRightClick"></custom-navbar>
|
||||||
<view>
|
<view>
|
||||||
|
|
||||||
</view>
|
</view>
|
||||||
<view class="eq" :style="{marginTop:Status.navbar.height+'px'}">
|
<view class="eq" :style="{marginTop:Status.navbar.height+'px'}">
|
||||||
<view class="leftImg" @click.stop="previewImg(device.devicePic?device.devicePic:formData.img)">
|
<view class="leftImg" @click.stop="previewImg(device.devicePic?device.devicePic:formData.img)">
|
||||||
<image class="img" :src="device.devicePic?device.devicePic:formData.img" mode="aspectFit"></image>
|
<image class="img" :src="device.devicePic?device.devicePic:formData.img" mode="aspectFit"></image>
|
||||||
@ -219,7 +219,7 @@
|
|||||||
<view>
|
<view>
|
||||||
|
|
||||||
<view class="item">
|
<view class="item">
|
||||||
<input class="value" style="text-indent: 20rpx;" v-model="formData.msgTxt" placeholder="请输入文字"
|
<input maxlength="16" class="value" style="text-indent: 20rpx;" v-model="formData.msgTxt" placeholder="请输入文字"
|
||||||
placeholder-class="usrplace" />
|
placeholder-class="usrplace" />
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
@ -309,8 +309,8 @@
|
|||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
Status: {
|
Status: {
|
||||||
msgOkIntval:null,//紧急通知等待的时间
|
msgOkIntval: null, //紧急通知等待的时间
|
||||||
msgOkTime:null,//
|
msgOkTime: null, //
|
||||||
pageHide: false,
|
pageHide: false,
|
||||||
apiType: "listA",
|
apiType: "listA",
|
||||||
navbar: {
|
navbar: {
|
||||||
@ -391,7 +391,7 @@
|
|||||||
bleLinkCnt: 0
|
bleLinkCnt: 0
|
||||||
},
|
},
|
||||||
formData: {
|
formData: {
|
||||||
img:'/static/images/common/HBY670.png',
|
img: '/static/images/common/HBY670.png',
|
||||||
battary: "", //电量
|
battary: "", //电量
|
||||||
xuhang: "", //续航
|
xuhang: "", //续航
|
||||||
imei: "", //imei
|
imei: "", //imei
|
||||||
@ -867,8 +867,10 @@
|
|||||||
// console.log("收到文本回复", payload);
|
// console.log("收到文本回复", payload);
|
||||||
// // this.SendTxtMQ(json);
|
// // this.SendTxtMQ(json);
|
||||||
// }
|
// }
|
||||||
if (keys.indexOf('sta_BreakNews') > -1) { //紧急通知
|
if (keys.indexOf('sta_BreakNews') > -
|
||||||
if(json.sta_BreakNews==='I get it')// && this.Status.msgOkTime && this.Status.msgOkIntval){
|
1) { //紧急通知
|
||||||
|
if (json.sta_BreakNews ===
|
||||||
|
'I get it') // && this.Status.msgOkTime && this.Status.msgOkIntval){
|
||||||
{
|
{
|
||||||
these.showPop({
|
these.showPop({
|
||||||
showPop: true,
|
showPop: true,
|
||||||
|
|||||||
@ -1828,7 +1828,7 @@ class BleHelper {
|
|||||||
Promise.race([timeOut(ms), promise]).then(resolve).catch((ex) => {
|
Promise.race([timeOut(ms), promise]).then(resolve).catch((ex) => {
|
||||||
// console.error("ex=", ex);
|
// console.error("ex=", ex);
|
||||||
if (ex.code == -1) {
|
if (ex.code == -1) {
|
||||||
console.error('专业给Uniapp填坑,发送消息永无回调');
|
// console.error('专业给Uniapp填坑,发送消息永无回调');
|
||||||
resolve(ex);
|
resolve(ex);
|
||||||
} else {
|
} else {
|
||||||
reject(ex);
|
reject(ex);
|
||||||
|
|||||||
Reference in New Issue
Block a user