2023-09-28 10:07:02 +00:00
< template >
< view class = "timeEnvironment" >
< u -navbar :background ="background" : is -back = ' true ' back -icon -color = ' # FFFFFF ' :border-bottom ="false" title = "实时环境"
title - color = '#FFFFFF' : title - bold = 'true' title - size = '32' > < / u - n a v b a r >
< view class = "navbar" >
2023-10-05 04:08:22 +00:00
< image src = "../../static/timeEnvironment_bg.png" mode = "" > < / image >
2023-09-28 10:07:02 +00:00
< / view >
< view class = "content" >
< view class = "title" >
2023-10-05 04:08:22 +00:00
< image src = "../../static/logo_1.png" mode = "" > < / image >
2023-09-28 10:07:02 +00:00
< view class = "right" >
< view class = "" >
温室智慧云
< / view >
< view class = "" >
Greenhouse wisdom Cloud
< / view >
< / view >
< / view >
< view class = "subtitle" >
欢迎使用温室智慧云数据统计
< / view >
2024-01-26 02:25:01 +00:00
<!-- 以下是单独调接口的气象数据 -- >
< template v-for ="item0 in weatherList" >
< view class = "waterAndFertilizerParams" :key ="item0.id" >
< view class = "nav" >
< image src = "../../static/PH.png" mode = "" > < / image >
< text > { { item0 . deviceName } } < / text >
< / view >
< view class = "detail" >
2024-01-30 06:54:13 +00:00
< view class = "item" v-for ="item,index in item0.weatherListChild" :key="index" @click="toTarget_water_fertilizer_PH(item.equipmentId,item.environmentData,item.environmentDataId,item.equipmentNumber,item.targetValue,getTypeList(item.formula),item.equipmentName,1)" >
2024-01-26 02:25:01 +00:00
< image : src = "`../../static/icon_new/icon${ item.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { item . environmentDataId } }
< / view >
2024-01-26 11:09:08 +00:00
< view class = "" : style = "item.equipmentStart == 0 ? 'color:red':''" > { { item . equipmentStart == 0 ? '故障' : ( ( item . formula == '12' ? getWindDirection ( item . environmentData ) : item . environmentData ) + ( item . formula == '12' ? '' : getTypeList ( item . formula ) ) ) } } < / view >
2024-01-26 02:25:01 +00:00
< / view >
< / view >
< / view >
< view class = "line" v-if ="item0.weatherListChild.length > 0" > < / view >
< view class = "updateTime" >
< span > < / span >
< span > * 更新数据时间 & nbsp ; : & nbsp ; { { ( updateTimeWeather . filter ( el => el . equipmentId == item0 . deviceId ) ) . length > 0 ? ( updateTimeWeather . filter ( el => el . equipmentId == item0 . deviceId ) ) [ 0 ] . updateTime : '暂无' } } < / span >
< / view >
< / view >
< / template >
<!-- 以下是通过userid调取的气象数据 -- >
< template v-for ="item0 in equipmentName30List" >
< view class = "waterAndFertilizerParams" :key ="item0.id" >
< view class = "nav" >
< image src = "../../static/PH.png" mode = "" > < / image >
< text > { { item0 . deviceTypeName } } < / text >
< / view >
< view class = "detail" >
2024-01-30 06:54:13 +00:00
< view class = "item" v-for ="item,index in item0.equipmentName30ListChild" :key="index" @click="toTarget_water_fertilizer_PH(item.equipmentId,item.environmentData,item.environmentDataId,item.equipmentNumber,item.targetValue,getTypeList(item.formula),item.equipmentName,1)" >
2024-01-26 02:25:01 +00:00
< image : src = "`../../static/icon_new/icon${ item.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { item . environmentDataId } }
< / view >
2024-01-26 11:09:08 +00:00
< view class = "" : style = "item.equipmentStart == 0 ? 'color:red':''" > { { item . equipmentStart == 0 ? '故障' : ( ( item . formula == '12' ? getWindDirection ( item . environmentData ) : item . environmentData ) + ( item . formula == '12' ? '' : getTypeList ( item . formula ) ) ) } } < / view >
2024-01-26 02:25:01 +00:00
< / view >
< / view >
< / view >
< view class = "line" v-if ="item0.equipmentName30ListChild.length > 0" > < / view >
< view class = "updateTime" >
< span > < / span >
< span > * 更新数据时间 & nbsp ; : & nbsp ; { { ( updateTime30 . filter ( el => el . equipmentId == item0 . deviceId ) ) . length > 0 ? ( updateTime30 . filter ( el => el . equipmentId == item0 . deviceId ) ) [ 0 ] . updateTime : '暂无' } } < / span >
< / view >
< / view >
< / template >
2023-09-28 10:07:02 +00:00
2023-11-10 02:43:22 +00:00
< view class = "waterAndFertilizerParams" v-for ="(item1,index1) in waterAndFertilizerParamsList" :key ="index1" >
2023-09-28 10:07:02 +00:00
< view class = "nav" >
2023-10-05 04:08:22 +00:00
< image src = "../../static/PH.png" mode = "" > < / image >
2023-09-28 10:07:02 +00:00
< text > { { item1 . deviceTypeName } } < / text >
< / view >
< view class = "detail" >
2024-01-10 02:42:05 +00:00
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_mubiao " :key ="index2"
2023-11-10 02:43:22 +00:00
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
2023-10-24 09:48:48 +00:00
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
2023-09-28 10:07:02 +00:00
< view class = "info" >
2023-11-10 02:43:22 +00:00
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : ( item2 . environmentData + getTypeList ( item2 . formula ) ) } } < / view >
2023-09-28 10:07:02 +00:00
< / view >
< / view >
2024-01-10 02:42:05 +00:00
< view class = "line" v-if ="item1.childList_mubiao.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_one " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_one.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_two " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_two.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_three " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_three.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_four " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_four.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_five " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_five.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_six " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_six.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_seven " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_seven.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_eight " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_eight.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_nine " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_nine.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_ten " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_ten.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_eleven " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_eleven.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_twelve " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_twelve.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_thirteen " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_thirteen.length > 0" > < / view >
< view class = "item" v -for = " ( item2 , index2 ) in item1.childList_fourteen " :key ="index2"
@ click = "toTarget_water_fertilizer_PH(item2.equipmentId,item2.environmentData,item2.environmentDataId,item2.equipmentNumber,item2.targetValue,getTypeList(item2.formula),item2.equipmentName)" >
< image : src = "`../../static/icon_new/icon${ item2.formula }.png`" mode = "" > < / image >
< view class = "info" >
< view class = "" >
{ { getStatus ( item2 . equipmentNumber , item2 . targetValue ) + item2 . environmentDataId } }
< / view >
2024-01-11 01:27:30 +00:00
< view class = "" : style = "item2.equipmentStart == 0 ? 'color:red':''" > { { item2 . equipmentStart == 0 ? '故障' : item2 . environmentData + getTypeList ( item2 . formula ) } } < / view >
2024-01-10 02:42:05 +00:00
< / view >
< / view >
< view class = "line" v-if ="item1.childList_fourteen.length > 0" > < / view >
2023-09-28 10:07:02 +00:00
< / view >
2023-10-12 09:15:37 +00:00
< view class = "updateTime" >
< span > < / span >
2024-01-18 07:21:50 +00:00
< span > * 更新数据时间 & nbsp ; : & nbsp ; { { ( updateTime . filter ( el => el . equipmentId == item1 . deviceId ) ) . length > 0 ? ( updateTime . filter ( el => el . equipmentId == item1 . deviceId ) ) [ 0 ] . updateTime : '暂无' } } < / span >
2023-10-12 09:15:37 +00:00
< / view >
2023-09-28 10:07:02 +00:00
< / view >
2024-01-22 01:42:36 +00:00
2023-09-28 10:07:02 +00:00
< / view >
< / view >
< / template >
< script >
export default {
data ( ) {
return {
// 头部导航背景
background : {
backgroundColor : 'transparent' ,
} ,
// 水肥参数
waterAndFertilizerParamsList : [
2023-11-10 02:43:22 +00:00
2023-09-28 10:07:02 +00:00
] ,
// 测试基地
testBaseList : [ {
2023-10-05 04:08:22 +00:00
img : "../../static/base1.png" ,
2023-09-28 10:07:02 +00:00
name : '空气温度' ,
value : "38.8klux"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base2.png" ,
2023-09-28 10:07:02 +00:00
name : '光亮度' ,
value : "38.8klux"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base3.png" ,
2023-09-28 10:07:02 +00:00
name : '二氧化碳' ,
value : "二氧化碳"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base3.png" ,
2023-09-28 10:07:02 +00:00
name : '二氧化碳' ,
value : "678PPM"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base4.png" ,
2023-09-28 10:07:02 +00:00
name : '土壤温度' ,
value : "20℃"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base4.png" ,
2023-09-28 10:07:02 +00:00
name : '土壤温度' ,
value : "30.1℃"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base5.png" ,
2023-09-28 10:07:02 +00:00
name : '土壤湿度' ,
value : "18.5%"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base5.png" ,
2023-09-28 10:07:02 +00:00
name : '土壤湿度' ,
value : "18.5%"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base6.png" ,
2023-09-28 10:07:02 +00:00
name : '水肥PH' ,
value : "0"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base6.png" ,
2023-09-28 10:07:02 +00:00
name : '水肥EC' ,
value : "0.2mS/cm"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base7.png" ,
2023-09-28 10:07:02 +00:00
name : '3#空气温度' ,
value : "29.8C"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base8.png" ,
2023-09-28 10:07:02 +00:00
name : '3#空气湿度' ,
value : "80.6%"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base2.png" ,
2023-09-28 10:07:02 +00:00
name : '3#光亮度' ,
value : "34.6 klux"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base3.png" ,
2023-09-28 10:07:02 +00:00
name : '3#二氧化碳' ,
value : "29.8C"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/base5.png" ,
2023-09-28 10:07:02 +00:00
name : '3#土壤温度' ,
value : "31℃"
} ,
] ,
// 测试基地
testBaseList1 : [ {
2023-10-05 04:08:22 +00:00
img : "../../static/1.png" ,
2023-09-28 10:07:02 +00:00
name : '4#光亮度' ,
value : "43 klux"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/2.png" ,
2023-09-28 10:07:02 +00:00
name : '4#二氧化碳' ,
value : "742 PPM"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/3.png" ,
2023-09-28 10:07:02 +00:00
name : '4#土壤温度' ,
value : "29.3C"
} ,
{
2023-10-05 04:08:22 +00:00
img : "../../static/4.png" ,
2023-09-28 10:07:02 +00:00
name : '4#土壤湿度' ,
value : "4%"
} ,
] ,
2023-11-10 02:43:22 +00:00
2023-10-05 04:08:22 +00:00
//label是名称 value是code码
//countType计算类型 0是原数据 1是原数据-400 2是原数据/10 3是(原数据-400) / 10
2023-11-22 09:28:49 +00:00
typeList : [ ] ,
2023-11-10 02:43:22 +00:00
timer : null ,
2024-01-26 02:25:01 +00:00
updateTime : [ ] ,
weatherList : [ ] ,
weatherDeviceName : '' ,
updateTimeWeather : [ ] ,
equipmentName30List : [ ] ,
equipmentName30ListChild : [ ] ,
updateTime30 : [ ] ,
2023-09-28 10:07:02 +00:00
}
} ,
2023-10-07 06:44:30 +00:00
onLoad ( ) {
2024-01-10 02:42:05 +00:00
this . typeList = this . api . typeList
2023-10-14 03:16:59 +00:00
uni . showLoading ( {
title : '加载中...'
} ) ;
2023-10-07 06:44:30 +00:00
let that = this
2023-10-14 03:16:59 +00:00
uni . getStorage ( {
key : 'token' ,
success : function ( res ) {
2024-01-26 02:25:01 +00:00
that . getEquipmentInfo ( uni . getStorageSync ( 'userid' ) ) ;
that . getcontrol _geteqetdata ( uni . getStorageSync ( 'userid' ) )
2023-10-14 03:16:59 +00:00
} ,
2024-01-26 02:25:01 +00:00
fail : function ( err ) {
uni . reLaunch ( {
url : '/pages/login/login'
} )
}
2023-11-10 02:43:22 +00:00
} )
2023-10-07 06:44:30 +00:00
} ,
2023-12-28 09:17:50 +00:00
onShow ( ) {
2024-01-22 01:42:36 +00:00
// console.log('timeEnvironment');
2023-12-28 09:17:50 +00:00
let that = this
clearInterval ( that . timer ) && that . timer
this . timer = setInterval ( function ( ) {
uni . getStorage ( {
key : 'token' ,
success : function ( res ) {
that . getEquipmentInfo ( uni . getStorageSync ( 'userid' ) )
2024-01-26 02:25:01 +00:00
that . getcontrol _geteqetdata ( uni . getStorageSync ( 'userid' ) )
2023-12-28 09:17:50 +00:00
} ,
} )
} , 60000 ) ;
} ,
2024-01-10 02:42:05 +00:00
onHide ( ) {
2023-10-14 03:16:59 +00:00
let that = this
2023-12-28 09:17:50 +00:00
clearInterval ( that . timer ) && that . timer
2023-10-07 06:44:30 +00:00
} ,
onPullDownRefresh ( ) {
2023-10-14 03:16:59 +00:00
uni . showLoading ( {
title : '加载中...'
} ) ;
2023-11-10 02:43:22 +00:00
let that = this
2023-10-07 06:44:30 +00:00
uni . getStorage ( {
key : 'token' ,
success : function ( res ) {
that . getEquipmentInfo ( uni . getStorageSync ( 'userid' ) )
2024-01-26 02:25:01 +00:00
that . getcontrol _geteqetdata ( uni . getStorageSync ( 'userid' ) )
2023-10-07 06:44:30 +00:00
} ,
2023-11-10 02:43:22 +00:00
} )
2023-09-28 10:07:02 +00:00
} ,
mounted ( ) {
2024-01-26 02:25:01 +00:00
// uni.showLoading({
// title: '加载中...'
// });
// let that = this
// uni.getStorage({
// key: 'token',
// success: function(res) {
// that.getEquipmentInfo(uni.getStorageSync('userid'));
// that.getcontrol_geteqetdata(uni.getStorageSync('userid'))
// },
// fail: function(err) {
// uni.reLaunch({
// url: '/pages/login/login'
// })
// }
// })
2023-09-28 10:07:02 +00:00
} ,
methods : {
// 根据用户id查询对应的设备数据
getEquipmentInfo ( userid ) {
let that = this
2023-10-14 03:16:59 +00:00
// uni.showLoading({
// title: '加载中...'
// });
2023-09-28 10:07:02 +00:00
this . $http ( {
url : this . api . sel _eqbyid + userid ,
2024-01-26 02:25:01 +00:00
// url: this.api.sel_eqbyid + '1730755572975824896',
2023-09-28 10:07:02 +00:00
method : 'GET'
} ) . then ( res => {
2023-10-07 06:44:30 +00:00
// console.log(res, '根据用户id查询对应的设备数据');
2023-09-28 10:07:02 +00:00
if ( res . code == 200 ) {
2024-01-26 02:25:01 +00:00
this . equipmentName30List = [ ] ;
res . data . forEach ( el => {
if ( el . equipmentName == 30 ) {
this . equipmentName30List . push ( el )
}
} )
if ( this . equipmentName30List . length != 0 ) {
this . getcontrol _rtDatastation1 ( )
}
2023-11-10 02:43:22 +00:00
this . waterAndFertilizerParamsList = res . data . map ( ( item , index ) => {
2023-09-28 10:07:02 +00:00
return {
... item ,
2024-01-10 02:42:05 +00:00
childList : [ ] ,
childList _mubiao : [ ] , //目标
childList _1 : [ ] , //平均
childList _2 : [ ] , //平均
childList _one : [ ] , //1#
childList _two : [ ] , //2#
childList _three : [ ] , //3#
childList _four : [ ] , //4#
childList _five : [ ] , //5#
childList _six : [ ] , //6#
childList _seven : [ ] , //7#
childList _eight : [ ] , //8#
childList _nine : [ ] , //9#
childList _ten : [ ] , //10#
childList _eleven : [ ] , //11#
childList _twelve : [ ] , //12#
childList _thirteen : [ ] , //13#
childList _fourteen : [ ] , //14#
2023-09-28 10:07:02 +00:00
}
} )
2024-01-18 01:47:38 +00:00
this . updateTime = [ ]
2023-11-10 02:43:22 +00:00
this . waterAndFertilizerParamsList . forEach ( ( i , index ) => {
2024-01-18 01:47:38 +00:00
2023-09-28 10:07:02 +00:00
this . $http ( {
2024-01-10 02:42:05 +00:00
url : ( i . equipmentName == 1 ? this . api . getFs _rtdata : this . api
. getcontrol _rtdata ) + "?equipmentId=" + i . deviceId ,
2023-09-28 10:07:02 +00:00
method : 'post' ,
} ) . then ( res => {
2023-10-08 07:37:17 +00:00
// console.log(res, '主页查看施肥机实时数据');
2023-11-10 02:43:22 +00:00
if ( res . code == 200 ) {
2023-09-28 10:07:02 +00:00
uni . hideLoading ( {
title : '完成'
} ) ;
2023-10-07 06:44:30 +00:00
uni . stopPullDownRefresh ( ) ;
2023-11-10 02:43:22 +00:00
i . childList = res . data ;
2024-01-10 02:42:05 +00:00
i . childList _mubiao = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == '目标' ) ;
i . childList _1 = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == '1#平均' ) ;
i . childList _2 = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == '2#平均' ) ;
i . childList _one = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 1 ) ;
i . childList _one = [ ... i . childList _1 , ... i . childList _one ] ;
i . childList _two = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 2 ) ;
i . childList _two = [ ... i . childList _2 , ... i . childList _two ]
i . childList _three = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 3 ) ;
i . childList _four = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 4 ) ;
i . childList _five = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 5 ) ;
i . childList _six = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 6 ) ;
i . childList _seven = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 7 ) ;
i . childList _eight = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 8 ) ;
i . childList _nine = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 9 ) ;
i . childList _ten = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 10 ) ;
i . childList _eleven = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 11 ) ;
i . childList _twelve = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 12 ) ;
i . childList _thirteen = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 13 ) ;
i . childList _fourteen = res . data . filter ( el => ( this . getStatus ( el . equipmentNumber , el . targetValue ) ) == ( el . equipmentNumber + '#' ) && el . equipmentNumber == 14 ) ;
2024-01-18 01:47:38 +00:00
2024-01-18 07:21:50 +00:00
this . updateTime . push ( res . data [ 0 ] )
2024-01-18 01:47:38 +00:00
2023-11-24 02:13:41 +00:00
// console.log(this.waterAndFertilizerParamsList);
2023-11-10 02:43:22 +00:00
} else {
2024-01-18 01:47:38 +00:00
this . updateTime . push ( '暂无' )
2023-09-28 10:07:02 +00:00
}
2024-01-22 01:42:36 +00:00
// console.log(this.updateTime,'this.updateTime');
2023-11-10 02:43:22 +00:00
} ) . catch ( err => {
2023-10-07 08:53:26 +00:00
console . log ( '接口失败' ) ;
2023-09-28 10:07:02 +00:00
} )
} )
2023-11-23 11:02:09 +00:00
// equipmentName==1的
2024-01-10 02:42:05 +00:00
let waterAndFertilizerParamsList _1 = this . waterAndFertilizerParamsList . filter ( e => e
. equipmentName == 1 ) . sort ( ( a , b ) => a . equipmentStatu - b . equipmentStatu )
2023-11-23 11:02:09 +00:00
// equipmentName==10的
2024-01-10 02:42:05 +00:00
let waterAndFertilizerParamsList _10 = this . waterAndFertilizerParamsList . filter ( e => e
. equipmentName == 10 ) . sort ( ( a , b ) => a . equipmentStatu - b . equipmentStatu ) ;
2023-11-24 02:13:41 +00:00
// console.log(waterAndFertilizerParamsList_1,waterAndFertilizerParamsList_10,'00000000000');
2024-01-10 02:42:05 +00:00
this . waterAndFertilizerParamsList = [ ... waterAndFertilizerParamsList _1 , ...
waterAndFertilizerParamsList _10
] ;
// console.log(this.waterAndFertilizerParamsList, 'this.waterAndFertilizerParamsList');
2023-09-28 10:07:02 +00:00
}
} )
} ,
2024-01-18 07:21:50 +00:00
2023-11-10 02:43:22 +00:00
2023-09-28 10:07:02 +00:00
// 跳转到折线图
2024-01-30 06:54:13 +00:00
toTarget _water _fertilizer _PH ( id , data , name , equipmentNumber , targetValue , unit , equipmentName , flag ) {
2023-09-28 10:07:02 +00:00
uni . navigateTo ( {
2023-11-10 02:43:22 +00:00
url : '/pages/target_water_fertilizer_PH/target_water_fertilizer_PH?id=' + id + '&data=' +
data + '&name=' + name + '&equipmentNumber=' + equipmentNumber + '&targetValue=' +
2024-01-30 06:54:13 +00:00
targetValue + '&unit=' + unit + '&equipmentName=' + equipmentName + '&flag=' + flag
2023-09-28 10:07:02 +00:00
} )
} ,
2023-11-10 02:43:22 +00:00
2023-10-05 04:08:22 +00:00
// 数据单位
2023-11-10 02:43:22 +00:00
getTypeList ( val ) {
2023-10-05 04:08:22 +00:00
let typeList1 = [ ]
2023-11-10 02:43:22 +00:00
typeList1 = this . typeList . filter ( item => {
return item . value == val
2023-10-05 04:08:22 +00:00
} )
return typeList1 [ 0 ] . unit
} ,
2023-11-10 02:43:22 +00:00
2023-10-05 04:08:22 +00:00
// 判断是否是平均或者目标,或者是1#
2023-11-10 02:43:22 +00:00
getStatus ( equipmentNumber , targetValue ) {
if ( targetValue == 1 ) {
2023-10-05 04:08:22 +00:00
return '目标'
2023-11-10 02:43:22 +00:00
} else if ( targetValue == 0 && equipmentNumber == 0 ) {
2023-10-05 04:08:22 +00:00
return '1#平均'
2023-11-10 02:43:22 +00:00
} else if ( targetValue == 0 && equipmentNumber == 15 ) {
2023-10-05 04:08:22 +00:00
return '2#平均'
2023-11-10 02:43:22 +00:00
} else if ( targetValue == 0 && equipmentNumber != 0 && equipmentNumber != 15 ) {
2023-10-07 01:49:48 +00:00
return equipmentNumber + '#'
2023-09-28 10:07:02 +00:00
}
2024-01-26 02:25:01 +00:00
} ,
// 气象站
getcontrol _geteqetdata ( userId ) {
this . $http ( {
url : this . api . getcontrol _geteqetdata + '?userId=' + userId ,
method : 'GET'
} ) . then ( res => {
// console.log(res,'小程序气象站显示');
if ( res . code == 200 ) {
this . weatherList = res . data
this . weatherList = this . weatherList . map ( ( item , index ) => {
return {
... item ,
weatherListChild : [ ]
}
} )
this . weatherList . forEach ( el => {
// 主页查看控制器气象站实时数据
this . $http ( {
url : this . api . getcontrol _rtDatastation + '?equipmentId=' + el . deviceId ,
method : 'GET'
} ) . then ( res => {
// console.log(res,'主页查看控制器气象站实时数据');
if ( res . code == 200 ) {
el . weatherListChild = res . data ;
this . updateTimeWeather . push ( res . data [ 0 ] )
}
} )
} )
}
} )
} ,
// 主页查看控制器气象站实时数据
getcontrol _rtDatastation ( equipmentId ) {
} ,
// 获取deviceName为30的气象站实时数据
getcontrol _rtDatastation1 ( ) {
this . equipmentName30List = this . equipmentName30List . map ( ( item , index ) => {
return {
... item ,
equipmentName30ListChild : [ ]
}
} )
this . updateTime30 = [ ]
this . equipmentName30List . forEach ( el => {
this . $http ( {
url : this . api . getcontrol _rtDatastation + '?equipmentId=' + el . deviceId ,
method : 'GET'
} ) . then ( res => {
if ( res . code == 200 ) {
el . equipmentName30ListChild = res . data ;
this . updateTime30 . push ( res . data [ 0 ] )
}
} )
} )
// console.log(this.equipmentName30List,'this.equipmentName30List');
} ,
2024-01-26 11:09:08 +00:00
// 风向判定
getWindDirection ( number ) {
let num = Number ( number )
if ( num <= 67 && num >= 22 ) {
return '东北'
} else if ( num > 67 && num < 112 ) {
return '东'
} else if ( num >= 112 && num <= 157 ) {
return '东南'
} else if ( num > 157 && num < 202 ) {
return '南'
} else if ( num >= 202 && num <= 247 ) {
return '西南'
} else if ( num > 247 && num < 292 ) {
return '西'
} else if ( num >= 292 && num <= 337 ) {
return '西北'
} else if ( num < 22 ) {
return '北'
} else if ( num > 337 ) {
return '北'
}
}
2023-09-28 10:07:02 +00:00
}
}
< / script >
< style lang = "scss" scoped >
. timeEnvironment {
width : 100 % ;
min - height : 100 vh ;
box - sizing : border - box ;
position : relative ;
background - color : # F5F6FA ;
2024-01-26 02:25:01 +00:00
overflow : auto ;
2023-09-28 10:07:02 +00:00
. navbar {
width : 100 % ;
height : 100 % ;
> image {
width : 750 rpx ;
height : 500 rpx ;
position : absolute ;
top : 0 ;
left : 0 ;
}
}
. content {
position : absolute ;
z - index : 2 ;
box - sizing : border - box ;
padding : 0 rpx 30 rpx 30 rpx ;
. title {
display : flex ;
align - items : center ;
> image {
width : 71 rpx ;
height : 65 rpx ;
}
. right {
margin - left : 14 rpx ;
> view : nth - child ( 1 ) {
font - size : 44 rpx ;
font - family : AlibabaPuHuiTiB ;
font - weight : bold ;
color : # FFFFFF ;
}
> view : nth - child ( 2 ) {
font - size : 16 rpx ;
font - family : Arial - BoldMT ;
font - weight : bold ;
color : # FFFFFF ;
line - height : 20 rpx ;
opacity : 0.5 ;
}
}
}
. subtitle {
font - size : 30 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # FFFFFF ;
margin - top : 26 rpx ;
}
. waterAndFertilizerParams {
width : 690 rpx ;
height : auto ;
box - sizing : border - box ;
padding : 20 rpx ;
background : # FFFFFF ;
box - shadow : 0 rpx 4 rpx 20 rpx 0 rpx rgba ( 153 , 153 , 153 , 0.1 ) ;
border - radius : 20 rpx ;
margin - top : 69 rpx ;
. nav {
height : 90 rpx ;
display : flex ;
align - items : center ;
border - bottom : 1 rpx solid # DDDDDD ;
> image {
width : 50 rpx ;
height : 50 rpx ;
margin - right : 16 rpx ;
}
> text {
font - size : 30 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 333333 ;
}
}
. detail {
width : 100 % ;
height : calc ( 100 % - 90 rpx ) ;
box - sizing : border - box ;
padding : 10 rpx 0 rpx ;
display : flex ;
flex - wrap : wrap ;
2023-10-12 09:15:37 +00:00
// justify-content: space-evenly;
2023-09-28 10:07:02 +00:00
2024-01-10 02:42:05 +00:00
. line {
width : 100 % ;
height : 1 rpx ;
background - color : # DDDDDD ;
flex - shrink : 0 ;
margin - top : 20 rpx ;
}
2023-09-28 10:07:02 +00:00
. item {
width : 50 % ;
display : flex ;
align - items : center ;
box - sizing : border - box ;
padding - left : 20 rpx ;
margin - top : 30 rpx ;
> image {
width : 80 rpx ;
height : 80 rpx ;
margin - right : 19 rpx ;
}
. info {
> view : nth - child ( 1 ) {
font - size : 24 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 333333 ;
}
> view : nth - child ( 2 ) {
font - size : 30 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 333333 ;
}
}
}
}
2023-11-10 02:43:22 +00:00
. updateTime {
2023-10-12 09:15:37 +00:00
width : 100 % ;
display : flex ;
justify - content : space - between ;
align - items : center ;
margin - top : 20 rpx ;
font - size : 22 rpx ;
}
2023-09-28 10:07:02 +00:00
}
. testBase {
width : 690 rpx ;
height : auto ;
background : # FFFFFF ;
box - shadow : 0 rpx 4 rpx 20 rpx 0 rpx rgba ( 153 , 153 , 153 , 0.1 ) ;
border - radius : 20 rpx ;
margin - top : 30 rpx ;
. nav {
height : 90 rpx ;
box - sizing : border - box ;
padding : 20 rpx ;
display : flex ;
align - items : center ;
> image {
width : 50 rpx ;
height : 50 rpx ;
margin - right : 16 rpx ;
}
> text {
font - size : 30 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 333333 ;
}
}
. detail {
width : 100 % ;
height : calc ( 100 % - 90 rpx ) ;
display : flex ;
flex - wrap : wrap ;
padding - bottom : 46 rpx ;
. item {
width : 33 % ;
display : flex ;
align - items : center ;
justify - content : center ;
flex - direction : column ;
margin - top : 30 rpx ;
> image {
width : 60 rpx ;
height : 60 rpx ;
}
. info {
display : flex ;
flex - direction : column ;
justify - content : center ;
align - items : center ;
margin - top : 10 rpx ;
> view : nth - child ( 1 ) {
font - size : 24 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 333333 ;
}
> view : nth - child ( 2 ) {
font - size : 30 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 333333 ;
}
}
}
}
}
. testBase1 {
width : 690 rpx ;
height : auto ;
background : # FFFFFF ;
box - shadow : 0 rpx 4 rpx 20 rpx 0 rpx rgba ( 153 , 153 , 153 , 0.1 ) ;
border - radius : 20 rpx ;
margin - top : 30 rpx ;
box - sizing : border - box ;
padding : 0 20 rpx 1 rpx ;
. nav {
height : 90 rpx ;
box - sizing : border - box ;
padding : 20 rpx ;
display : flex ;
align - items : center ;
> image {
width : 50 rpx ;
height : 50 rpx ;
margin - right : 16 rpx ;
}
> text : nth - child ( 2 ) {
font - size : 30 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 333333 ;
}
> text : nth - child ( 3 ) {
width : 90 rpx ;
height : 44 rpx ;
background : # EFFCF7 ;
border : 2 px solid rgba ( 58 , 187 , 144 , 0.25 ) ;
border - radius : 22 rpx ;
font - size : 20 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 37 BA8E ;
display : flex ;
justify - content : center ;
align - items : center ;
margin - left : 15 rpx ;
}
}
. item {
width : 650 rpx ;
height : 90 rpx ;
background : # F5F6FA ;
border : 2 px solid # E7E9F1 ;
border - radius : 10 rpx ;
display : flex ;
align - items : center ;
justify - content : space - between ;
margin - bottom : 30 rpx ;
box - sizing : border - box ;
padding : 0 30 rpx 0 20 rpx ;
> image {
width : 40 rpx ;
height : 39 rpx ;
margin - right : 20 rpx ;
}
> text : nth - child ( 2 ) {
flex : 1 ;
font - size : 28 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 333333 ;
}
> text : nth - child ( 3 ) {
font - size : 30 rpx ;
font - family : PingFang SC ;
font - weight : bold ;
color : # 333333 ;
}
}
}
}
}
2024-01-26 02:25:01 +00:00
. line {
width : 100 % ;
height : 1 rpx ;
background - color : # DDDDDD ;
flex - shrink : 0 ;
margin - top : 20 rpx ;
}
2023-09-28 10:07:02 +00:00
< / style >