This commit is contained in:
3321822538@qq.com 2024-12-03 17:35:37 +08:00
parent ec2140d707
commit aa6d0c218b
13 changed files with 606 additions and 265 deletions

View File

@ -1,6 +1,6 @@
const install = (Vue, vm) => {
Vue.prototype.$u.http.setConfig({
// baseUrl: 'http://192.168.2.18:3202',
// baseUrl: 'http://192.168.2.100:3202',
baseUrl: 'https://fen.ccttiot.com/prod-api',
loadingText: '努力加载中~',
loadingTime: 800,

View File

@ -1,4 +1,5 @@
var mOnFire = require("./other/onfire.js");
var $wxBlufiImpl = require("./xBlufi-wx-impl.js"); // 0表示阿里支付宝小程序 1表示微信小程序

View File

@ -83255,7 +83255,7 @@ TooltipRichContent.prototype = {
var name = text.substr(startId + prefix.length, endId - startId - prefix.length);
if (name.indexOf('sub') > -1) {
markers['marker' + name] = {
textWidth: 4,
textwidth: 1,
textHeight: 4,
textBorderRadius: 2,
textBackgroundColor: markerRich[name],

View File

@ -18,6 +18,14 @@
{{obj.apiaryName == undefined ? '--' : obj.apiaryName}}-{{obj.name == undefined ? '--' : obj.name}}
<view class="sets">
<!-- <image @click="btnmenu" src="https://api.ccttiot.com/smartmeter/img/static/ulHBKvkXDfe9OIveIJKZ" mode=""></image> -->
<!-- 正在连接 -->
<image v-if="zcljflag" style="width: 184rpx;height: 40rpx;margin-right:20rpx" src="https://api.ccttiot.com/smartmeter/img/static/uYUoki4Tc56rzINzY2Ba" mode=""></image>
<!-- 连接成功 -->
<image v-if="ljcgflag" style="width: 40rpx;height: 40rpx;margin-right:20rpx" src="https://api.ccttiot.com/smartmeter/img/static/uhSqWj4f07z8oDMh0i8f" mode=""></image>
<!-- 未连接 -->
<image v-if="wljflag" style="width: 40rpx;height: 40rpx;margin-right:20rpx" src="https://api.ccttiot.com/smartmeter/img/static/uBp1lbXlGEMD4s5P8LGu" mode=""></image>
<image @click="btnedit" src="https://api.ccttiot.com/smartmeter/img/static/ulHBKvkXDfe9OIveIJKZ"
mode=""></image>
<view class="menu" v-if="menuflag">
@ -113,7 +121,7 @@
<view class="time">
{{obj.lastOnlineTime == undefined ? '--' : obj.lastOnlineTime}}
</view>
<view class="ele">
<view class="ele" v-if="obj.onlineStatus == 1">
<image style="height: 25rpx;" v-if="obj.surplusPowerPoint <= 100 && obj.surplusPowerPoint >= 80"
src="https://api.ccttiot.com/smartmeter/img/static/uWbKPMvIuFZjzviEJjmP" mode=""></image>
<image style="height: 25rpx;" v-if="obj.surplusPowerPoint < 80 && obj.surplusPowerPoint >= 50"
@ -124,6 +132,17 @@
src="https://api.ccttiot.com/smartmeter/img/static/uIRhPmP5WUJaIg0nft9E" mode=""></image>
{{obj.surplusPowerPoint == undefined ? '--' : obj.surplusPowerPoint}}%
</view>
<view class="ele" v-else>
<image style="height: 25rpx;" v-if="ver_data.bat <= 100 && ver_data.bat >= 80"
src="https://api.ccttiot.com/smartmeter/img/static/uWbKPMvIuFZjzviEJjmP" mode=""></image>
<image style="height: 25rpx;" v-if="ver_data.bat < 80 && ver_data.bat >= 50"
src="https://api.ccttiot.com/smartmeter/img/static/u0mCXpSrvcROLCMsahNh" mode=""></image>
<image style="height: 25rpx;" v-if="ver_data.bat < 50 && ver_data.bat >= 20"
src="https://api.ccttiot.com/smartmeter/img/static/uGGgEPbe8ryHspQPL2o8" mode=""></image>
<image style="height: 25rpx;" v-if="ver_data.bat < 20"
src="https://api.ccttiot.com/smartmeter/img/static/uIRhPmP5WUJaIg0nft9E" mode=""></image>
{{ver_data.bat == undefined ? '--' : ver_data.bat}}%
</view>
</view>
<view class="echarts_box" v-if="xnwd" @click="btnec(1)">
<view class="echarts_top">
@ -132,9 +151,12 @@
<image style="width: 36rpx;height: 34rpx;"
src="https://api.ccttiot.com/smartmeter/img/static/utoKXhZBoejfRZwNUMP9" mode=""></image>
</view>
<view class="top_cont">
<view class="top_cont" v-if="obj.onlineStatus == 1">
当前 {{obj.innerTemperature == undefined ? '--' : obj.innerTemperature}}
</view>
<view class="top_cont" v-else>
当前 {{ver_data.temp_n == undefined ? '--' : ver_data.temp_n}}
</view>
<view class="top_right">
<view style="width: 1rpx;">
@ -158,8 +180,11 @@
<image style="width: 30rpx;height: 32rpx;"
src="https://api.ccttiot.com/smartmeter/img/static/una6Kbd2gdBZ9gG6lg44" mode=""></image>
</view>
<view class="top_cont">
当前 {{obj.innerHumidity}}%
<view class="top_cont" v-if="obj.onlineStatus == 1">
当前 {{obj.innerHumidity == undefined ? '--' : obj.innerHumidity}}%
</view>
<view class="top_cont" v-else>
当前 {{ver_data.hp_n == undefined ? '--' : ver_data.hp_n}}%
</view>
<view class="top_right">
<view style="width: 1rpx;">
@ -184,9 +209,12 @@
<image style="width: 28rpx;height: 33rpx;"
src="https://api.ccttiot.com/smartmeter/img/static/uk7CvwzeU0ukxvS9cBtD" mode=""></image>
</view>
<view class="top_cont">
<view class="top_cont" v-if="obj.onlineStatus == 1">
当前 {{obj.totalWeight == 999999 ? '--' : (obj.totalWeight / 1000).toFixed(1)}}kg
</view>
<view class="top_cont" v-else>
当前 {{ver_data.weight == undefined ? '--' : (ver_data.weight / 1000).toFixed(1)}}kg
</view>
<view class="top_right">
<view style="width: 1rpx;">
@ -210,8 +238,11 @@
<image style="width: 33rpx;height: 33rpx;"
src="https://api.ccttiot.com/smartmeter/img/static/uhsU6Y1K35jxA4aRauzy" mode=""></image>
</view>
<view class="top_cont">
当前 {{obj.ioCountDay}}
<view class="top_cont" v-if="obj.onlineStatus == 1">
当前 {{obj.ioCountDay == undefined ? '--' : obj.ioCountDay}}
</view>
<view class="top_cont" v-else>
当前 {{ver_data.out_day == undefined ? '--' : ver_data.out_day}}
</view>
<view class="top_right">
<view style="width: 1rpx;">
@ -236,9 +267,12 @@
<image style="width: 38rpx;height: 32rpx;"
src="https://api.ccttiot.com/smartmeter/img/static/up9IaGzSg1RKhIZz3V7a" mode=""></image>
</view>
<view class="top_cont">
<view class="top_cont" v-if="obj.onlineStatus == 1">
当前 {{obj.volume / 1000 == 0 ? obj.volume : (obj.volume / 1000).toFixed(1)}}khz
</view>
<view class="top_cont" v-else>
当前 {{ver_data.MIC / 1000 == 0 ? ver_data.MIC : (ver_data.MIC / 1000).toFixed(1)}}khz
</view>
<view class="top_right">
<view style="width: 1rpx;">
@ -262,9 +296,12 @@
<image style="width: 36rpx;height: 38rpx;"
src="https://api.ccttiot.com/smartmeter/img/static/uAw3ZCXnMbekNML7CTSu" mode=""></image>
</view>
<view class="top_cont">
<view class="top_cont" v-if="obj.onlineStatus == 1">
当前 {{obj.innerCo2}}ppm
</view>
<view class="top_cont" v-else>
当前 {{ver_data.CO2 == undefined ? '--' : ver_data.CO2}}ppm
</view>
<view class="top_right">
<view style="width: 1rpx;">
@ -323,10 +360,10 @@
<view class="type_li" @click="btndow(2)" v-if="beep">
蜂鸣寻箱
</view>
<view class="type_li" @click="btndow(3)">
<view class="type_li" :id="fskx == '关' ? 'active' : ''" @click="btndow(3)">
风扇{{fskx}}
</view>
<view class="type_li" @click="btndow(4)">
<view class="type_li" :id="jrkg == '关' ? 'active' : ''" @click="btndow(4)">
加热{{jrkg}}
</view>
</view>
@ -335,6 +372,7 @@
</template>
<script>
var xBlufi = require("@/components/blufi/xBlufi.js")
import uniEcCanvas from '@/components/uni-ec-canvas/uni-ec-canvas.vue'
import * as echarts from '@/components/uni-ec-canvas/echarts'
let chart = null
@ -405,14 +443,22 @@
sypl: false,
eyht: false,
beep: false,
timer: null,
mac:'',
devicesList:[],
ver_data:{},
zcljflag:false,
ljcgflag:false,
wljflag:false
}
},
onLoad(option) {
this.beehiveId = option.beehiveId
},
onShow() {
this.zcljflag = false
this.wljflag = false
this.ljcgflag = false
setTimeout(() => {
this.$refs.canvas1.init(this.initChart)
this.$refs.canvas2.init(this.initChart2)
@ -439,14 +485,249 @@
this.getchartData4()
this.getchartData5()
this.getchartData6()
//
this.startTimer()
},
onUnload() {
//
this.clearTimer()
},
methods: {
// id
getobj() {
this.$u.get(`/app/beehive/${this.beehiveId}`).then(res => {
if (res.code == 200) {
if(res.data.onlineStatus == 0){
this.mac = res.data.mac
this.Binddevice()
}else{
//
this.startTimer()
}
this.obj = res.data
if(res.data.lat == null || res.data.lng == null){
this.latitude = 27.100845
this.longitude = 120.25469
}else{
this.latitude = res.data.lat
this.longitude = res.data.lng
}
this.modelTags = res.data.modelTags
this.modelTags.forEach(item => {
if (item == 1) {
this.height = true
} else if (item == 2) {
this.io = true
} else if (item == 3) {
this.xnwd = true
this.xnsd = true
} else if (item == 10) {
this.sypl = true
} else if (item == 9) {
this.eyht = true
} else if (item == 13) {
this.beep = true
}
})
if (res.data.enableFan == false) {
this.fskx = '关'
} else {
this.fskx = '开'
}
if (res.data.enableHeat == false) {
this.jrkg = '关'
} else {
this.jrkg = '开'
}
this.dtflag = false
this.covers.push({
id: parseFloat(res.data.beehiveId),
latitude: this.latitude,
longitude: this.longitude,
width: 30,
height: 33,
iconPath: 'https://api.ccttiot.com/smartmeter/img/static/ukbyhyrDcp3VzgyeJo2G',
})
this.gettq()
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
},
//
Binddevice() {
this.zcljflag = true
this.wljflag = false
this.ljcgflag = false
xBlufi.initXBlufi(1);
xBlufi.listenDeviceMsgEvent(true, this.funListenDeviceMsgEvent);
xBlufi.notifyStartDiscoverBle({
'isStart': true
})
//
setTimeout(() => {
xBlufi.notifyStartDiscoverBle({
'isStart': false
})
setTimeout(() => {
if (this.devicesList.length == 0) {
this.zcljflag = false
this.wljflag = true
this.ljcgflag = false
// let that = this
// uni.showModal({
// title: '',
// content: ',',
// showCancel: true ,//
// success:function(res) {
// that.Binddevice()
// }
// })
} else {
let uniqueDevicesList = Array.from(new Set(this.devicesList))
this.devicesList = uniqueDevicesList
console.log(this.devicesList,'列表');
//
let isMatched = false
//
this.devicesList.forEach(device => {
// MACMAC12
let macFromName = device.name.substring(device.name.length - 12)
console.log(macFromName,this.mac)
// MAC
if (macFromName == this.mac) {
this.createBLEConnection(device)
console.log('对比正确')
isMatched = true // true
} else {
console.log('对比错误')
}
})
//
if (!isMatched) {
this.zcljflag = false
this.wljflag = true
this.ljcgflag = false
let that = this
uni.showModal({
title: '温馨提示',
content: '暂未发现蜂箱设备,是否重新搜索连接',
showCancel: true ,
success:function(res) {
that.Binddevice()
}
})
}else{
this.zcljflag = false
this.wljflag = false
this.ljcgflag = true
}
}
}, 200)
}, 3000)
},
//
createBLEConnection(e) {
xBlufi.notifyStartDiscoverBle({
'isStart': false
});
console.log(e, '蓝牙信息')
const deviceId = e.deviceId
let name = e.name;
xBlufi.notifyConnectBle({
isStart: true,
deviceId: e.deviceId,
name
})
},
//
funListenDeviceMsgEvent: function(options) {
let that = this;
switch (options.type) {
case xBlufi.XBLUFI_TYPE.TYPE_GET_DEVICE_LISTS:
if (options.result) {
let devicesarr = options.data
devicesarr.forEach(device => {
this.devicesList.push(device);
let uniqueDevicesList = Array.from(new Set(this.devicesList));
// this.devicesList
this.devicesList = uniqueDevicesList
})
}
break
case xBlufi.XBLUFI_TYPE.TYPE_CONNECTED:
console.log("连接回调:" + JSON.stringify(options))
uni.showToast({
title: '连接成功',
icon: 'success',
duration:2000
})
this.zcljflag = false
this.wljflag = false
this.ljcgflag = true
{
xBlufi.notifyInitBleEsp32({
deviceId: options.data.deviceId
})
}
break
case xBlufi.XBLUFI_TYPE.TYPE_RECIEVE_MY_DATA:
this.loadPercent = options.data;
this.loadText = '文件读取中'
console.log("文件读取中", options.data);
break
case xBlufi.XBLUFI_TYPE.TYPE_RECIEVE_CUSTON_DATA:
let dataString = options.data
//
dataString = dataString.slice(1, -1);
// 使 split
let pairs = dataString.match(/([^,]+)/g);
let obj = {};
//
pairs.forEach(pair => {
let [key, value] = pair.split(':');
obj[key] = !isNaN(value) ? parseFloat(value) : value;
})
this.ver_data = obj
console.log(this.ver_data,this.ver_data.bat)
break
case xBlufi.XBLUFI_TYPE.TYPE_INIT_ESP32_RESULT:
if (options.result) {
console.log('初始化成功')
} else {
console.log('初始化失败')
this.zcljflag = false
this.wljflag = true
this.ljcgflag = false
break
}
break
case xBlufi.XBLUFI_TYPE.TYPE_GET_DEVICE_LISTS_START:
if (!options.result) {
this.zcljflag = false
this.wljflag = true
this.ljcgflag = false
uni.showToast({
title: '蓝牙未开启',
icon: 'none',
duration: 3000
})
return
}
break
case xBlufi.XBLUFI_TYPE.TYPE_STATUS_CONNECTED: {
console.log('蓝牙异常断开', options.result)
}
break;
}
},
//
btntqxq(){
@ -506,23 +787,32 @@
},
//
btnvideo() {
if(this.obj.apiaryId == '' || this.obj.apiaryId == null){
let that = this
uni.showModal({
title: "提示",
content: '请将该设备绑定蜂场在进行此操作',
success: function(res) {
if (res.confirm) {
uni.navigateTo({
url:'/page_Beehive/add_Beehive?tit=' + '修改蜂箱' + '&beehiveId=' + that.beehiveId
})
const user = uni.getStorageSync('user')
if(this.obj.userId == user.userId){
if(this.obj.apiaryId == '' || this.obj.apiaryId == null){
let that = this
uni.showModal({
title: "提示",
content: '请将该设备绑定蜂场在进行此操作',
success: function(res) {
if (res.confirm) {
uni.navigateTo({
url:'/page_Beehive/add_Beehive?tit=' + '修改蜂箱' + '&beehiveId=' + that.beehiveId
})
}
}
}
})
})
}else{
uni.navigateTo({
url: '/page_Beehive/Beehive_log?apiaryId=' + this.obj.apiaryId + ' &name=' + this.obj.apiaryName
})
}
}else{
uni.navigateTo({
url: '/page_Beehive/Beehive_log?apiaryId=' + this.obj.apiaryId + ' &name=' + this.obj.apiaryName
})
uni.showToast({
title: '您没有权限操作',
icon: 'none',
duration: 2000
})
}
},
//
@ -535,16 +825,34 @@
},
//
btnyj() {
uni.navigateTo({
url: '/page_Beehive/Beehive_woring?apiaryId=' + this.beehiveId + '&tit=' + '蜂箱预警记录'
})
const user = uni.getStorageSync('user')
if(this.obj.userId == user.userId){
uni.navigateTo({
url: '/page_Beehive/Beehive_woring?apiaryId=' + this.beehiveId + '&tit=' + '蜂箱预警记录'
})
}else{
uni.showToast({
title: '您没有权限操作',
icon: 'none',
duration: 2000
})
}
},
//
btnedit() {
this.menuflag = false
uni.navigateTo({
url: '/page_Beehive/add_Beehive?tit=' + '修改蜂箱' + '&beehiveId=' + this.beehiveId
})
const user = uni.getStorageSync('user')
if(this.obj.userId == user.userId){
this.menuflag = false
uni.navigateTo({
url: '/page_Beehive/add_Beehive?tit=' + '修改蜂箱' + '&beehiveId=' + this.beehiveId
})
}else{
uni.showToast({
title: '您没有权限操作',
icon: 'none',
duration: 2000
})
}
},
btnfx() {
this.menuflag = false
@ -623,202 +931,197 @@
//
btndow(num) {
if (num == 1) {
this.$u.put(`farm/beehive/iot/${this.beehiveId}/clearWeight`).then(res => {
if (res.code == 200) {
uni.showToast({
title: '去皮成功',
icon: 'success',
duration: 2000
})
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
if(this.obj.onlineStatus == 0){
xBlufi.notifySendCustomData({
      customData: "11clear_weight@"
 })
uni.showToast({
title: '去皮成功',
icon: 'success',
duration: 2000
})
}else{
this.$u.put(`farm/beehive/iot/${this.beehiveId}/clearWeight`).then(res => {
if (res.code == 200) {
uni.showToast({
title: '去皮成功',
icon: 'success',
duration: 2000
})
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
}
} else if (num == 2) {
this.$u.put(`farm/beehive/iot/${this.beehiveId}/buzzer`).then(res => {
if (res.code == 200) {
uni.showToast({
title: '响铃成功',
icon: 'success',
duration: 2000
})
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
if(this.obj.onlineStatus == 0){
xBlufi.notifySendCustomData({
      customData: "11beep11@" + 10
 })
uni.showToast({
title: '响铃成功',
icon: 'success',
duration: 2000
})
}else{
this.$u.put(`farm/beehive/iot/${this.beehiveId}/buzzer`).then(res => {
if (res.code == 200) {
uni.showToast({
title: '响铃成功',
icon: 'success',
duration: 2000
})
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
}
} else if (num == 3) {
if (this.fskx == '关') {
this.$u.put(`farm/beehive/iot/${this.beehiveId}/fan?open=true`).then(res => {
if (res.code == 200) {
if (this.fskx == '关') {
this.fskx = '开'
if(this.obj.onlineStatus == 0){
xBlufi.notifySendCustomData({
    customData: '11fan100@'
})
this.fskx = '开'
uni.showToast({
title: '风扇开启成功',
icon: 'success',
duration: 2000
})
}else{
this.$u.put(`farm/beehive/iot/${this.beehiveId}/fan?open=true`).then(res => {
if (res.code == 200) {
if (this.fskx == '关') {
this.fskx = '开'
} else {
this.fskx = '关'
}
uni.showToast({
title: '风扇开启成功',
icon: 'success',
duration: 2000
})
} else {
this.fskx = '关'
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
uni.showToast({
title: '风扇开启成功',
icon: 'success',
duration: 2000
})
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
})
}
} else {
this.$u.put(`farm/beehive/iot/${this.beehiveId}/fan?open=false`).then(res => {
if (res.code == 200) {
if (this.fskx == '关') {
this.fskx = '开'
if(this.obj.onlineStatus == 0){
xBlufi.notifySendCustomData({
    customData: "11fan0@"
})
this.fskx = '关'
uni.showToast({
title: '风扇关闭成功',
icon: 'success',
duration: 2000
})
}else{
this.$u.put(`farm/beehive/iot/${this.beehiveId}/fan?open=false`).then(res => {
if (res.code == 200) {
if (this.fskx == '关') {
this.fskx = '开'
} else {
this.fskx = '关'
}
uni.showToast({
title: '风扇关闭成功',
icon: 'success',
duration: 2000
})
} else {
this.fskx = '关'
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
uni.showToast({
title: '风扇关闭成功',
icon: 'success',
duration: 2000
})
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
})
}
}
} else if (num == 4) {
if (this.jrkg == '关') {
this.$u.put(`farm/beehive/iot/${this.beehiveId}/heat?open=true`).then(res => {
if (res.code == 200) {
if (this.jrkg == '关') {
this.jrkg = '开'
if(this.obj.onlineStatus == 0){
xBlufi.notifySendCustomData({
    customData: "11hot100@"
})
this.jrkg = '开'
uni.showToast({
title: '加热开启成功',
icon: 'success',
duration: 2000
})
}else{
this.$u.put(`farm/beehive/iot/${this.beehiveId}/heat?open=true`).then(res => {
if (res.code == 200) {
if (this.jrkg == '关') {
this.jrkg = '开'
} else {
this.jrkg = '关'
}
uni.showToast({
title: '加热开启成功',
icon: 'success',
duration: 2000
})
} else {
this.jrkg = '关'
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
uni.showToast({
title: '加热开启成功',
icon: 'success',
duration: 2000
})
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
})
}
} else {
this.$u.put(`farm/beehive/iot/${this.beehiveId}/heat?open=false`).then(res => {
if (res.code == 200) {
if (this.jrkg == '关') {
this.jrkg = '开'
if(this.obj.onlineStatus == 0){
xBlufi.notifySendCustomData({
    customData: "11hot0@"
})
this.jrkg = '关'
uni.showToast({
title: '加热关闭成功',
icon: 'success',
duration: 2000
})
}else{
this.$u.put(`farm/beehive/iot/${this.beehiveId}/heat?open=false`).then(res => {
if (res.code == 200) {
if (this.jrkg == '关') {
this.jrkg = '开'
} else {
this.jrkg = '关'
}
uni.showToast({
title: '加热关闭成功',
icon: 'success',
duration: 2000
})
} else {
this.jrkg = '关'
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
uni.showToast({
title: '加热关闭成功',
icon: 'success',
duration: 2000
})
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
})
}
}
}
},
// id
getobj() {
this.$u.get(`/app/beehive/${this.beehiveId}`).then(res => {
if (res.code == 200) {
this.obj = res.data
if(res.data.lat == null || res.data.lng == null){
this.latitude = 27.100845
this.longitude = 120.25469
}else{
this.latitude = res.data.lat
this.longitude = res.data.lng
}
this.modelTags = res.data.modelTags
this.modelTags.forEach(item => {
if (item == 1) {
this.height = true
} else if (item == 2) {
this.io = true
} else if (item == 3) {
this.xnwd = true
this.xnsd = true
} else if (item == 10) {
this.sypl = true
} else if (item == 9) {
this.eyht = true
} else if (item == 13) {
this.beep = true
}
})
if (res.data.enableFan == false) {
this.fskx = '关'
} else {
this.fskx = '开'
}
if (res.data.enableHeat == false) {
this.jrkg = '关'
} else {
this.jrkg = '开'
}
// if (res.data.lat == null && res.data.lng == null) {
// // this.latitude = 39.56
// // this.longitude = 116.20
// this.zoomSize = 1
// this.dtflag = true
// } else {
// this.dtflag = false
// this.covers.push({
// id: parseFloat(res.data.beehiveId),
// latitude: this.latitude,
// longitude: this.longitude,
// width: 30,
// height: 33,
// iconPath: 'https://api.ccttiot.com/smartmeter/img/static/ukbyhyrDcp3VzgyeJo2G',
// })
// }
this.dtflag = false
this.covers.push({
id: parseFloat(res.data.beehiveId),
latitude: this.latitude,
longitude: this.longitude,
width: 30,
height: 33,
iconPath: 'https://api.ccttiot.com/smartmeter/img/static/ukbyhyrDcp3VzgyeJo2G',
})
this.gettq()
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
},
//
gettq() {
this.$u.get(`weather/7d?location=${this.longitude},${this.latitude}`).then(res => {
@ -929,7 +1232,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1036,7 +1339,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1143,7 +1446,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1250,7 +1553,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1357,7 +1660,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1464,7 +1767,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1624,6 +1927,9 @@
</script>
<style lang="scss">
#active{
color: red !important;
}
.mask {
width: 100%;
height: 100vh;

View File

@ -429,7 +429,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -537,7 +537,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -646,7 +646,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -755,7 +755,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -864,7 +864,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -973,7 +973,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {

View File

@ -898,7 +898,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1006,7 +1006,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1115,7 +1115,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1224,7 +1224,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1333,7 +1333,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -1442,7 +1442,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {

View File

@ -239,7 +239,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -348,7 +348,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {

View File

@ -22,10 +22,10 @@
总重量{{(obj.totalWeight == undefined ? '--' : (Number(obj.totalWeight / 1000)).toFixed(2)) + 'kg'}}
</view>
<view class="machao">
箱内湿度{{obj.innerHumidity == undefined ? '--' : obj.innerHumidity + '°C'}}
箱内湿度{{obj.innerHumidity == undefined ? '--' : obj.innerHumidity + '%'}}
</view>
<view class="machao">
箱外湿度{{obj.outerHumidity == undefined ? '--' : obj.outerHumidity + '°C'}}
箱外湿度{{obj.outerHumidity == undefined ? '--' : obj.outerHumidity + '%'}}
</view>
<view class="machao">
箱内温度{{obj.innerTemperature == undefined ? '--' : obj.innerTemperature + '°C'}}

View File

@ -34,7 +34,7 @@
<image src="https://api.ccttiot.com/smartmeter/img/static/unI3QR7NPZsPSn5ryMMH" mode=""></image>
加热
</view>
<view class="" style="display: flex;align-items: center;justify-content: space-between;font-size: 32rpx;color: #3D3D3D;">
<!-- <view class="" style="display: flex;align-items: center;justify-content: space-between;font-size: 32rpx;color: #3D3D3D;">
<view class="bot">{{retxt}}</view>
<view class="cont" @click="btnrekg">
<view class="top" style="padding-top: 10rpx;">
@ -48,11 +48,11 @@
</view>
</view>
</view>
</view>
</view> -->
</view>
<view style="color: red;font-size: 26rpx;margin-left: 65rpx;">
<!-- <view style="color: red;font-size: 26rpx;margin-left: 65rpx;">
切记开关关闭的话加热是不会工作的
</view>
</view> -->
<view class="set_li">
箱外温度低于<view class="ipt_box"><input type="text" class="ips" v-model="minHeat" placeholder=" "
placeholder-class="my-placeholder" /> </view>加热板工作
@ -66,7 +66,7 @@
<image src="https://api.ccttiot.com/smartmeter/img/static/urouHoLnzjyyRn0MmNoL" mode=""></image>
风扇 ppm
</view>
<view class="" style="display: flex;align-items: center;justify-content: space-between;font-size: 32rpx;color: #3D3D3D;">
<!-- <view class="" style="display: flex;align-items: center;justify-content: space-between;font-size: 32rpx;color: #3D3D3D;">
<view class="bot">{{fstxt}}</view>
<view class="cont" @click="btnfskg">
<view class="top" style="padding-top: 10rpx;">
@ -80,11 +80,11 @@
</view>
</view>
</view>
</view>
</view> -->
</view>
<view style="color: red;font-size: 26rpx;margin-left: 65rpx;">
<!-- <view style="color: red;font-size: 26rpx;margin-left: 65rpx;">
切记开关关闭的话风扇是不会工作的
</view>
</view> -->
<view class="set_li">
箱内温度高于<view class="ipt_box"><input type="text" class="ips" v-model="maxFan" placeholder=" "
placeholder-class="my-placeholder" /> </view>风扇工作

View File

@ -742,7 +742,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -850,7 +850,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {

View File

@ -64,7 +64,7 @@
{{item.onlineStatus == 0 ? '离线' : '在线'}}
</view>
<view class="ele">
<view class="type" @click.stop="btngengxin">
<view class="type" @click.stop="btngengxin(item,index)">
更新数据
</view>
<view class="one">
@ -275,14 +275,45 @@
//
btngengxin(){
uni.showLoading({
title: '更新数据中...',
mask: true
})
this.curtitidx = 0
this.pagesum = 1
this.getlist()
btngengxin(item, index) {
uni.showLoading({
title: '数据更新中...',
mask: true
});
this.$u.put(`app/beehive/iot/${item.beehiveId}/upload`).then(res => {
if(res.code == 200){
setTimeout(()=>{
this.$u.get(`app/beehive/${item.beehiveId}?refreshIot=true`).then(res => {
if (res.code === 200) {
uni.showToast({
title: res.msg,
icon: 'success',
duration: 2000
})
const wateringList = this.miyuancolumns[index].wateringList;
const matchingIndex = wateringList.findIndex(val => val.beehiveId === item.beehiveId);
if (matchingIndex !== -1) {
console.log('Before update:', wateringList[matchingIndex]); //
Object.assign(wateringList[matchingIndex], res.data);
console.log('After update:', wateringList[matchingIndex]); //
}
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
}).catch(error => {
uni.showToast({
title: '请求失败,请稍后再试',
icon: 'none',
duration: 2000
})
})
},2000)
}
})
},
//
changserch(){

View File

@ -214,8 +214,8 @@
let sn = getQueryParam(decodedValue, 's')
this.$u.get(`/app/beehive/isBind?sn=${sn}`).then(res => {
if (res.code == 200) {
let that = this;
if(res.data == false){
let that = this;
uni.showModal({
title: "提示",
content: '该蜂箱暂未被绑定,是否前去绑定?',
@ -299,6 +299,8 @@
getuserinfo() {
this.$u.get(`/app/user/userInfo`).then(res => {
if (res.code == 200) {
console.log(res.data);
uni.setStorageSync('user',res.data)
if (res.data.type == 1) {
this.logoflag = false
this.ishave()
@ -480,7 +482,7 @@
axisLabel: {
show: true,
color: '#ccc',
fontSize: 11,
fontSize: 2,
rotate: 0,
},
splitLine: {
@ -537,7 +539,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {
@ -645,7 +647,7 @@
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
width: 1,
},
areaStyle: {
normal: {

View File

@ -57,16 +57,16 @@
<view class="">箱内湿度{{fxobj.innerHumidity == undefined ? '--' : fxobj.innerHumidity}}%</view>
</view>
<view class="fcli">
<view class="">蜂箱重量{{fxobj.totalYield == undefined ? '--' : fxobj.totalYield}}kg</view>
<view class="">蜂箱重量{{fxobj.totalYield == undefined ? '--' : (Number(fxobj.totalYield / 1000)).toFixed(2) + 'kg'}}</view>
</view>
<view class="fcli">
<view class="">二氧化碳浓度{{fxobj.innerCo2 == undefined ? '--' : fxobj.innerCo2}}ppm</view>
</view>
<view class="fcli">
<view class="">进出量(){{fxobj.ioCountDay == undefined ? '--' : fxobj.ioCountDay}}</view>
<view class="">进出量(){{fxobj.ioCountDay == undefined ? '--' : fxobj.ioCountDay}}</view>
</view>
<view class="fcli">
<view class="">频率{{fxobj.volume == undefined ? '--' : fxobj.volume}}</view>
<view class="">频率{{fxobj.volume == undefined ? '--' : (fxobj.volume / 1000).toFixed(1) + 'KHz'}}</view>
</view>
</view>
<view class="btncha" @click="btnpage(1)">
@ -523,7 +523,7 @@
height: 88rpx;
background: #FFCC25;
border-radius: 20rpx 20rpx 20rpx 20rpx;
margin-top: 46rpx;
margin-top: 26rpx;
text-align: center;
line-height: 88rpx;
font-size: 32rpx;
@ -533,9 +533,10 @@
display: flex;
flex-wrap: wrap;
margin-top: 28rpx;
justify-content: space-between;
.fcli{
margin: 10rpx;
flex: 1 0 calc(50% - 20rpx);
// flex: 1 0 calc(50% - 20rpx);
}
}
.fcfm {