617 lines
20 KiB
JavaScript
617 lines
20 KiB
JavaScript
|
'use strict';
|
|||
|
// 版本更新
|
|||
|
function updateApp() {
|
|||
|
mui.toast(document.getElementById('text').innerHTML);
|
|||
|
}
|
|||
|
|
|||
|
// 重量校准
|
|||
|
function weightFix() {
|
|||
|
if (!feedList.length > 0) {
|
|||
|
mui.toast("没有装料信息");
|
|||
|
return false;
|
|||
|
}
|
|||
|
var btnArray1 = [feedName + '已完成', feedName + '未开始'];
|
|||
|
mui.confirm('<b style="color:red">如果装料完成需要先上传</b>', '<b style="font-weight:900">校准前' + feedName + '状态</b>', btnArray1, function (e) {
|
|||
|
if (e.index == 0) {
|
|||
|
mui.toast('<b style="color:red">校准失败,已完成请先上传</b>');
|
|||
|
} else {
|
|||
|
beforeWeight = nowWeight;
|
|||
|
mui.toast("校准完成");
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
// 开始装料
|
|||
|
function startLoad() {
|
|||
|
if (!feedList.length > 0) {
|
|||
|
mui.toast("没有装料信息");
|
|||
|
return false;
|
|||
|
}
|
|||
|
// 初始化查询称和字符卡配置信息
|
|||
|
initService();
|
|||
|
}
|
|||
|
|
|||
|
// 提交数据
|
|||
|
function submitData() {
|
|||
|
var date = new Date();
|
|||
|
var dateOf = getDateStr(date);
|
|||
|
var dateTime = currTimeFn(date);
|
|||
|
var param = {
|
|||
|
dateOf: dateOf,
|
|||
|
name: feedName,
|
|||
|
planWeight: Number(_planSum),
|
|||
|
rationCowAmount: feedList[feedIndex] ? feedList[feedIndex].cow : 0,
|
|||
|
batchRation: feedList[feedIndex].batchRation,
|
|||
|
feedWeight: _feedNum,
|
|||
|
feedId: feedList[feedIndex].id,
|
|||
|
driver: driverName,
|
|||
|
type: feedList[feedIndex].batchRation ? 2 : 1,
|
|||
|
sourceCow: api.getPrefs({sync: true, key: 'sourceCow'}),
|
|||
|
classCode: classCode,
|
|||
|
trainNumber: trainNumber,
|
|||
|
templet: templateName,
|
|||
|
templetType: templetType,
|
|||
|
sbId: sbId,
|
|||
|
createBy: driverName,
|
|||
|
start: api.getGlobalData({key: 'startTime'}),
|
|||
|
end: dateTime,
|
|||
|
time: dateTime
|
|||
|
};
|
|||
|
api.ajax({
|
|||
|
url: 'https://tmr.nxcyx.com/api/app/tmr/resultUpload',
|
|||
|
headers: {
|
|||
|
'Content-Type': 'application/json;charset=utf-8' //建议key使用首字母大写的形式,如 User-Agent
|
|||
|
},
|
|||
|
method: 'post',
|
|||
|
data: {
|
|||
|
body: param
|
|||
|
}
|
|||
|
}, function (ret, err) {
|
|||
|
if (ret && ret.code == 200) {
|
|||
|
mui.toast(param.name + " 已上传 " + param.feedWeight);
|
|||
|
beforeWeight = nowWeight;
|
|||
|
// document.getElementById('beforeWeight').innerHTML = '称实时/装料前:' + nowWeight + '/' + beforeWeight;
|
|||
|
feedIndex = feedIndex + 1;
|
|||
|
// 没有下一个饲料,车次加一
|
|||
|
if (feedIndex > feedList.length - 1) {
|
|||
|
trainIndex = trainIndex + 1;
|
|||
|
// 没有下一个车次,饲喂完成
|
|||
|
if (trainIndex > trainArr.length - 1) {
|
|||
|
mui.toast('本班次饲喂完成');
|
|||
|
document.getElementById('submitData').setAttribute("class", 'btnc mui-btn-primary dis');
|
|||
|
return false;
|
|||
|
}
|
|||
|
// 自动点击下一车,并定位,同时刷新下一个开始装料时间
|
|||
|
document.getElementById('classeCode_' + classCode + 'train_' + trainIndex).click();
|
|||
|
document.querySelector('#' + 'classeCode_' + classCode + 'train_' + trainIndex).scrollIntoView(true);
|
|||
|
api.setGlobalData({key: 'startTime', value: currTimeFn(new Date())});
|
|||
|
return false;
|
|||
|
} else {
|
|||
|
// 判断是否是圈舍
|
|||
|
if (feedList[feedIndex].batchRation) {
|
|||
|
load = false;
|
|||
|
} else {
|
|||
|
load = true;
|
|||
|
}
|
|||
|
// 设置下一个饲料选中状态
|
|||
|
var doms = document.getElementsByClassName('mui-badge');
|
|||
|
if (doms.length > 0) {
|
|||
|
for (var i = 0; i < doms.length; i++) {
|
|||
|
doms[i].setAttribute("class", 'mui-badge');
|
|||
|
}
|
|||
|
}
|
|||
|
document.getElementById('feed_' + feedIndex).setAttribute("class", 'mui-badge mui-badge-purple');
|
|||
|
}
|
|||
|
// 刷新已装装料为0,显示下一个饲料名称,定位到下一个饲料位置,刷新允许误差,刷新计划重量,刷新显示班次信息
|
|||
|
_feedNum = 0;
|
|||
|
feedName = feedList[feedIndex].name;
|
|||
|
// document.getElementById("upload").innerHTML = '上传'+json[0].name
|
|||
|
document.getElementById('submitData').innerHTML = '上传' + feedName;
|
|||
|
document.getElementById('fix').innerHTML = '装料前校准' + feedName;
|
|||
|
document.querySelector('#feed_' + feedIndex).scrollIntoView(true);
|
|||
|
allow = feedList[feedIndex].allow;
|
|||
|
_planSum = feedList[feedIndex].weight.toFixed(0);
|
|||
|
text = feedName + _planSum;
|
|||
|
document.getElementById('nowFeed').innerHTML = '<font style="color:blue">' + batchName + ',' + feedName + '</font>';
|
|||
|
ledStatus = false;
|
|||
|
// setTimeout(() => {
|
|||
|
console.log("停止蜂鸣");
|
|||
|
control("00", "00");
|
|||
|
setTimeout(function () {
|
|||
|
ledStatus = true;
|
|||
|
statusEle = false;
|
|||
|
}, 500);
|
|||
|
// },500)
|
|||
|
} else if (err) {
|
|||
|
addNotice('submitData,' + err.msg);
|
|||
|
mui.alert("submitData:" + err.msg);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
var weightDataFilter;
|
|||
|
var status = '';
|
|||
|
var statusEle = false;
|
|||
|
var ledStatus = true;
|
|||
|
var uuid = '';
|
|||
|
var serviceUUID = '';
|
|||
|
var characteristicUUID = '';
|
|||
|
var lastTime = "";
|
|||
|
var msgList = [];
|
|||
|
var time = "";
|
|||
|
|
|||
|
|
|||
|
var connetcedStatus = false;
|
|||
|
// setInterval(function () {
|
|||
|
// console.log(connetcedStatus)
|
|||
|
// if (connetcedStatus && uuid) {
|
|||
|
// connetcedStatus = false
|
|||
|
// connect({peripheralUUID: uuid}, function (ret3) {
|
|||
|
// console.log(JSON.stringify(ret3))
|
|||
|
// })
|
|||
|
// }
|
|||
|
// }, 1000)
|
|||
|
|
|||
|
// 初始化所有服务
|
|||
|
function initService() {
|
|||
|
initManager({single: true});
|
|||
|
}
|
|||
|
|
|||
|
// 获取当前日期字符串
|
|||
|
function getDateStr(date) {
|
|||
|
var seperator1 = "-";
|
|||
|
var seperator2 = ":";
|
|||
|
var month = date.getMonth() + 1;
|
|||
|
var strDate = date.getDate();
|
|||
|
if (month >= 1 && month <= 9) {
|
|||
|
month = "0" + month;
|
|||
|
}
|
|||
|
if (strDate >= 0 && strDate <= 9) {
|
|||
|
strDate = "0" + strDate;
|
|||
|
}
|
|||
|
var currentdate = date.getFullYear() + seperator1 + month + seperator1 + strDate;
|
|||
|
return currentdate;
|
|||
|
}
|
|||
|
|
|||
|
// 获取当前时间字符串
|
|||
|
function currTimeFn(_date) {
|
|||
|
var _year = _date.getFullYear();
|
|||
|
var _month = _date.getMonth() + 1 < 10 ? '0' + (_date.getMonth() + 1) : _date.getMonth() + 1;
|
|||
|
var _day = _date.getDate() < 10 ? '0' + _date.getDate() : _date.getDate();
|
|||
|
var _hour = _date.getHours() < 10 ? '0' + _date.getHours() : _date.getHours();
|
|||
|
var _minutes = _date.getMinutes() < 10 ? '0' + _date.getMinutes() : _date.getMinutes();
|
|||
|
var _seconds = _date.getSeconds() < 10 ? '0' + _date.getSeconds() : _date.getSeconds();
|
|||
|
return _year + "-" + _month + "-" + _day + " " + _hour + ":" + _minutes + ":" + _seconds;
|
|||
|
}
|
|||
|
|
|||
|
// 显示字符卡称重配置信息和未上传数据
|
|||
|
function showZifuka() {
|
|||
|
initService();
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* 上传异常信息
|
|||
|
*/
|
|||
|
// ajax防止重复提交状态
|
|||
|
var canUpload = true;
|
|||
|
|
|||
|
function uploadNotice() {
|
|||
|
var notice = api.getPrefs({sync: true, key: 'notice'});
|
|||
|
if (notice !== '' && canUpload) {
|
|||
|
canUpload = false;
|
|||
|
api.ajax({
|
|||
|
url: 'https://tmr.nxcyx.com/api/app/tmr/noticeSave',
|
|||
|
headers: {
|
|||
|
'Content-Type': 'application/json;charset=utf-8' //建议key使用首字母大写的形式,如 User-Agent
|
|||
|
},
|
|||
|
method: 'post',
|
|||
|
data: {
|
|||
|
body: notice
|
|||
|
}
|
|||
|
}, function (ret, err) {
|
|||
|
if (ret && ret.code == 200) {
|
|||
|
api.removePrefs({
|
|||
|
key: 'notice'
|
|||
|
});
|
|||
|
} else if (err) {
|
|||
|
mui.toast("noticeSave:" + err.msg);
|
|||
|
}
|
|||
|
canUpload = true;
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* 上传100条实时重量信息
|
|||
|
*/
|
|||
|
// 实时重量数组
|
|||
|
var totalList = [];
|
|||
|
// ajax防止重复提交状态
|
|||
|
var totalAjax = true;
|
|||
|
|
|||
|
function uploadTotalWeight() {
|
|||
|
if (totalList.length > 100 && totalAjax) {
|
|||
|
totalAjax = false;
|
|||
|
api.ajax({
|
|||
|
url: 'https://tmr.nxcyx.com/api/app/tmr/totalWeightUpload',
|
|||
|
// url: 'http://10.10.100.101:8088/app/tmr/totalWeightUpload',
|
|||
|
headers: {
|
|||
|
'Content-Type': 'application/json;charset=utf-8' //建议key使用首字母大写的形式,如 User-Agent
|
|||
|
},
|
|||
|
method: 'post',
|
|||
|
data: {
|
|||
|
body: {
|
|||
|
sbId: sbId,
|
|||
|
weightList: totalList
|
|||
|
}
|
|||
|
}
|
|||
|
}, function (ret, err) {
|
|||
|
if (ret && ret.code === 200) {
|
|||
|
totalList = [];
|
|||
|
} else if (err) {
|
|||
|
mui.toast("totalWeightUpload" + err.msg);
|
|||
|
}
|
|||
|
totalAjax = true;
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* 添加异常通知
|
|||
|
* @param {} describe
|
|||
|
*/
|
|||
|
function addNotice(describe) {
|
|||
|
var param = {
|
|||
|
sourceCow: api.getPrefs({sync: true, key: 'sourceCow'}),
|
|||
|
type: 4,
|
|||
|
color: 'red',
|
|||
|
time: currTimeFn(new Date()),
|
|||
|
describe: describe
|
|||
|
};
|
|||
|
api.setPrefs({
|
|||
|
key: 'notice',
|
|||
|
value: param
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* 定时任务
|
|||
|
*/
|
|||
|
function totalWeightUpload() {
|
|||
|
uploadNotice();
|
|||
|
uploadTotalWeight();
|
|||
|
}
|
|||
|
|
|||
|
function convertToPolarPoint(renderItemParams, radius, radian) {
|
|||
|
return [Math.cos(radian) * radius + renderItemParams.coordSys.cx, -Math.sin(radian) * radius + renderItemParams.coordSys.cy];
|
|||
|
}
|
|||
|
|
|||
|
function makePionterPoints(renderItemParams, polarEndRadian) {
|
|||
|
return [convertToPolarPoint(renderItemParams, _outerRadius, polarEndRadian), convertToPolarPoint(renderItemParams, _outerRadius, polarEndRadian + Math.PI * 0.03), convertToPolarPoint(renderItemParams, _pointerInnerRadius, polarEndRadian)];
|
|||
|
}
|
|||
|
|
|||
|
//计划量/已装量echarts参数
|
|||
|
function renderItemFeed(params, api) {
|
|||
|
var valOnRadian = api.value(1);
|
|||
|
var coords = api.coord([api.value(0), valOnRadian]);
|
|||
|
var polarEndRadian = coords[3];
|
|||
|
var imageStyle = {
|
|||
|
image: "https://tmr.nxcyx.com/img/custom-gauge-panel.png",
|
|||
|
x: params.coordSys.cx - _outerRadius,
|
|||
|
y: params.coordSys.cy - _outerRadius,
|
|||
|
width: _outerRadius * 2,
|
|||
|
height: _outerRadius * 2
|
|||
|
};
|
|||
|
return {
|
|||
|
type: 'group',
|
|||
|
children: [{
|
|||
|
type: 'image',
|
|||
|
style: imageStyle,
|
|||
|
clipPath: {
|
|||
|
type: 'sector',
|
|||
|
shape: {
|
|||
|
cx: params.coordSys.cx,
|
|||
|
cy: params.coordSys.cy,
|
|||
|
r: _outerRadius,
|
|||
|
r0: _innerRadius,
|
|||
|
startAngle: 0,
|
|||
|
endAngle: -polarEndRadian,
|
|||
|
transition: 'endAngle',
|
|||
|
enterFrom: {endAngle: 0}
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
type: 'image',
|
|||
|
style: imageStyle,
|
|||
|
clipPath: {
|
|||
|
type: 'polygon',
|
|||
|
shape: {
|
|||
|
points: makePionterPoints(params, polarEndRadian)
|
|||
|
},
|
|||
|
extra: {
|
|||
|
polarEndRadian: polarEndRadian,
|
|||
|
transition: 'polarEndRadian',
|
|||
|
enterFrom: {polarEndRadian: 0}
|
|||
|
},
|
|||
|
during: function during(apiDuring) {
|
|||
|
apiDuring.setShape('points', makePionterPoints(params, apiDuring.getExtra('polarEndRadian')));
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
type: 'circle',
|
|||
|
shape: {
|
|||
|
cx: params.coordSys.cx,
|
|||
|
cy: params.coordSys.cy,
|
|||
|
r: _insidePanelRadius
|
|||
|
},
|
|||
|
style: {
|
|||
|
fill: '#fff',
|
|||
|
shadowBlur: 25,
|
|||
|
shadowOffsetX: 0,
|
|||
|
shadowOffsetY: 0,
|
|||
|
shadowColor: 'rgba(76,107,167,0.4)'
|
|||
|
}
|
|||
|
}, {
|
|||
|
type: 'text',
|
|||
|
extra: {
|
|||
|
valOnRadian: valOnRadian,
|
|||
|
transition: 'valOnRadian',
|
|||
|
enterFrom: {valOnRadian: 0}
|
|||
|
},
|
|||
|
style: {
|
|||
|
text: makeTextFeed(valOnRadian),
|
|||
|
fontSize: fontsize,
|
|||
|
fontWeight: 900,
|
|||
|
x: params.coordSys.cx,
|
|||
|
y: params.coordSys.cy,
|
|||
|
fill: 'rgb(255, 0, 0)',
|
|||
|
align: 'center',
|
|||
|
verticalAlign: 'middle',
|
|||
|
enterFrom: {opacity: 0}
|
|||
|
},
|
|||
|
during: function during(apiDuring) {
|
|||
|
apiDuring.setStyle('text', makeTextFeed(apiDuring.getExtra('valOnRadian')));
|
|||
|
}
|
|||
|
}]
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
function makeTextFeed(valOnRadian) {
|
|||
|
// if (load) {
|
|||
|
if (Math.abs(_planSum - _feedNum) >= 0) {
|
|||
|
// return '剩余应装\n' + valOnRadian.toFixed(1) + 'kg';
|
|||
|
return feedName + '\n' + echartsType + Math.abs(_planSum - _feedNum).toFixed(0) + 'kg';
|
|||
|
} else {
|
|||
|
// return '剩余应卸\n' + valOnRadian.toFixed(1) + 'kg';
|
|||
|
return feedName + '\n' + echartsType + Math.abs(_planSum - _feedNum).toFixed(0) + 'kg';
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
function renderLoad(title) {
|
|||
|
|
|||
|
var weightOption = {
|
|||
|
animation: false,
|
|||
|
dataset: {
|
|||
|
source: [[1, nowWeight]]
|
|||
|
},
|
|||
|
tooltip: {},
|
|||
|
angleAxis: {
|
|||
|
type: 'value',
|
|||
|
startAngle: 0,
|
|||
|
show: false,
|
|||
|
min: 0,
|
|||
|
max: _weightSum
|
|||
|
},
|
|||
|
radiusAxis: {
|
|||
|
type: 'value',
|
|||
|
show: false
|
|||
|
},
|
|||
|
polar: {},
|
|||
|
series: [{
|
|||
|
type: 'custom',
|
|||
|
coordinateSystem: 'polar',
|
|||
|
renderItem: renderItemWeight
|
|||
|
}]
|
|||
|
};
|
|||
|
weightOption && weightMyChart.setOption(weightOption);
|
|||
|
}
|
|||
|
|
|||
|
function renderUnload() {
|
|||
|
|
|||
|
var feedOption = {
|
|||
|
animation: false,
|
|||
|
dataset: {
|
|||
|
// source: [[1, _planSum]]
|
|||
|
source: [[1, _feedNum]]
|
|||
|
},
|
|||
|
// title: {
|
|||
|
// text:feedName + '计划'+ _feedNum +'kg'
|
|||
|
// // text:title
|
|||
|
// },
|
|||
|
tooltip: {},
|
|||
|
angleAxis: {
|
|||
|
type: 'value',
|
|||
|
startAngle: 0,
|
|||
|
show: false,
|
|||
|
min: 0,
|
|||
|
max: _planSum
|
|||
|
},
|
|||
|
radiusAxis: {
|
|||
|
type: 'value',
|
|||
|
show: false
|
|||
|
},
|
|||
|
polar: {},
|
|||
|
series: [{
|
|||
|
type: 'custom',
|
|||
|
coordinateSystem: 'polar',
|
|||
|
renderItem: renderItemFeed
|
|||
|
}]
|
|||
|
};
|
|||
|
feedOption && feedMyChart.setOption(feedOption);
|
|||
|
}
|
|||
|
|
|||
|
//总重量/剩余量echarts参数
|
|||
|
function renderItemWeight(params, api) {
|
|||
|
var valOnRadian = api.value(1);
|
|||
|
var coords = api.coord([api.value(0), valOnRadian]);
|
|||
|
var polarEndRadian = coords[3];
|
|||
|
var imageStyle = {
|
|||
|
image: "https://tmr.nxcyx.com/img/custom-gauge-panel.png",
|
|||
|
x: params.coordSys.cx - _outerRadius,
|
|||
|
y: params.coordSys.cy - _outerRadius,
|
|||
|
width: _outerRadius * 2,
|
|||
|
height: _outerRadius * 2
|
|||
|
};
|
|||
|
return {
|
|||
|
type: 'group',
|
|||
|
children: [{
|
|||
|
type: 'image',
|
|||
|
style: imageStyle,
|
|||
|
clipPath: {
|
|||
|
type: 'sector',
|
|||
|
shape: {
|
|||
|
cx: params.coordSys.cx,
|
|||
|
cy: params.coordSys.cy,
|
|||
|
r: _outerRadius,
|
|||
|
r0: _innerRadius,
|
|||
|
startAngle: 0,
|
|||
|
endAngle: -polarEndRadian,
|
|||
|
transition: 'endAngle',
|
|||
|
enterFrom: {endAngle: 0}
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
type: 'image',
|
|||
|
style: imageStyle,
|
|||
|
clipPath: {
|
|||
|
type: 'polygon',
|
|||
|
shape: {
|
|||
|
points: makePionterPoints(params, polarEndRadian)
|
|||
|
},
|
|||
|
extra: {
|
|||
|
polarEndRadian: polarEndRadian,
|
|||
|
transition: 'polarEndRadian',
|
|||
|
enterFrom: {polarEndRadian: 0}
|
|||
|
},
|
|||
|
during: function during(apiDuring) {
|
|||
|
apiDuring.setShape('points', makePionterPoints(params, apiDuring.getExtra('polarEndRadian')));
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
type: 'circle',
|
|||
|
shape: {
|
|||
|
cx: params.coordSys.cx,
|
|||
|
cy: params.coordSys.cy,
|
|||
|
r: _insidePanelRadius
|
|||
|
},
|
|||
|
style: {
|
|||
|
fill: '#fff',
|
|||
|
shadowBlur: 25,
|
|||
|
shadowOffsetX: 0,
|
|||
|
shadowOffsetY: 0,
|
|||
|
shadowColor: 'rgba(76,107,167,0.4)'
|
|||
|
}
|
|||
|
}, {
|
|||
|
type: 'text',
|
|||
|
extra: {
|
|||
|
valOnRadian: valOnRadian,
|
|||
|
transition: 'valOnRadian',
|
|||
|
enterFrom: {valOnRadian: 0}
|
|||
|
},
|
|||
|
style: {
|
|||
|
text: makeTextWeight(valOnRadian),
|
|||
|
fontSize: fontsize,
|
|||
|
fontWeight: 900,
|
|||
|
x: params.coordSys.cx,
|
|||
|
y: params.coordSys.cy,
|
|||
|
fill: 'rgb(0, 0, 0)',
|
|||
|
align: 'center',
|
|||
|
verticalAlign: 'middle',
|
|||
|
enterFrom: {opacity: 0}
|
|||
|
},
|
|||
|
during: function during(apiDuring) {
|
|||
|
apiDuring.setStyle('text', makeTextWeight(apiDuring.getExtra('valOnRadian')));
|
|||
|
}
|
|||
|
}]
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
function makeTextWeight(valOnRadian) {
|
|||
|
return '车内总重\n' + valOnRadian.toFixed(0) + 'kg';
|
|||
|
}
|
|||
|
|
|||
|
function hex2a(hexx) {
|
|||
|
var hex = hexx.toString(); //force conversion
|
|||
|
var str = '';
|
|||
|
for (var i = 0; i < hex.length; i += 2) {
|
|||
|
str += String.fromCharCode(parseInt(hex.substr(i, 2), 16));
|
|||
|
}return str;
|
|||
|
}
|
|||
|
|
|||
|
function speakTest(text, speed) {
|
|||
|
// IFlyVoice.stopSpeaking();
|
|||
|
IFlyVoice.startSynthetic({
|
|||
|
text: text,
|
|||
|
commonPath_Android: 'widget://res/aisound/common.jet',
|
|||
|
pronouncePath_Android: 'widget://res/aisound/xiaofeng.jet',
|
|||
|
commonPath_iOS: 'widget://res/aisound/common.jet',
|
|||
|
pronouncePath_iOS: 'widget://res/aisound/xiaofeng.jet',
|
|||
|
pronounceName: 'xiaofeng',
|
|||
|
volume: '100',
|
|||
|
speed: speed
|
|||
|
}, function (ret, err) {
|
|||
|
if (ret.status) {
|
|||
|
console.log('合成成功');
|
|||
|
} else {}
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
function closeApp() {
|
|||
|
mui.confirm('确认关闭TMR饲喂系统?', '提示', btnArray, function (e) {
|
|||
|
if (e.index == 0) {} else {
|
|||
|
api.closeWidget({
|
|||
|
id: api.appId, //应用ID
|
|||
|
retData: { name: 'closeWidget' },
|
|||
|
silent: true
|
|||
|
});
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
// 以下是一个基于JavaScript的称重异常过滤程序示例,该程序使用滑动窗口算法来过滤异常值:
|
|||
|
// 该程序使用一个dataBuffer数组来保存最近的一组测量值,并返回这组值的平均值。程序在filter方法中,将新的测量值加入到dataBuffer中,并调用getAverageValue方法获取平均值。如果该平均值与上一个有效值的偏差小于maxDeviation,则将该测量值视为有效值,并返回该平均值;否则将该测量值视为异常值,并返回上一个有效值。
|
|||
|
// 使用时,可以创建一个WeightDataFilter实例并调用filter方法来传入新的测量值,如下所示:
|
|||
|
// let weightDataFilter = new WeightDataFilter(10, 0.5);
|
|||
|
// let filteredValue = weightDataFilter.filter(measurementValue);
|
|||
|
|
|||
|
// 其中,10是窗口大小,0.5是最大的偏差值,可以根据实际需求进行调整。measurementValue是当前的测量值。
|
|||
|
class WeightDataFilter {
|
|||
|
constructor(windowSize, maxDeviation) {
|
|||
|
this.windowSize = windowSize;
|
|||
|
this.maxDeviation = maxDeviation;
|
|||
|
this.dataBuffer = [];
|
|||
|
this.lastValidValue = NaN;
|
|||
|
}
|
|||
|
|
|||
|
filter(value) {
|
|||
|
this.dataBuffer.push(value);
|
|||
|
if (this.dataBuffer.length > this.windowSize) {
|
|||
|
this.dataBuffer.shift();
|
|||
|
}
|
|||
|
let filteredValue = this.getAverageValue();
|
|||
|
// console.log(filteredValue,Math.abs(filteredValue - this.lastValidValue),this.maxDeviation);
|
|||
|
if (isNaN(this.lastValidValue) || Math.abs(filteredValue - this.lastValidValue) <= this.maxDeviation) {
|
|||
|
this.lastValidValue = filteredValue;
|
|||
|
return filteredValue;
|
|||
|
} else {
|
|||
|
return this.lastValidValue;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
getAverageValue() {
|
|||
|
let sum = this.dataBuffer.reduce((total, value) => total + value, 0);
|
|||
|
return sum / this.dataBuffer.length;
|
|||
|
}
|
|||
|
|
|||
|
}
|