设备系数

This commit is contained in:
磷叶 2024-12-16 21:36:17 +08:00
parent 29ca4d69cb
commit 6cd799bfdb
11 changed files with 73 additions and 1 deletions

View File

@ -96,6 +96,11 @@ public class IotConstants {
*/
public static final String COMMAND_SET_TOTAL_ELE = "pow_set";
/**
* 命令 设置电压系数
*/
public static final String COMMAND_SET_VXS = "v_xs";
/**----------------------------命令end----------------------------*/
}

View File

@ -35,4 +35,7 @@ public class ReceiveConstants {
// 数据点IDVER 版本号
public static final String DS_VER = "VER";
// 数据点IDVXS 电压系数
public static final String DS_VXS = "VXS";
}

View File

@ -32,6 +32,7 @@ public class IotDeviceInfo {
private String model; // 型号
private String wifi; // WIFI
private String version; // 版本号
private BigDecimal vxs; // 电压系数
public static IotDeviceInfo newDefaultInstance() {
return IotDeviceInfo.builder()
@ -45,7 +46,7 @@ public class IotDeviceInfo {
.time(BigDecimal.ZERO)
.model(null)
.version(null)
.vxs(BigDecimal.ONE)
.build();
}
}

View File

@ -6,6 +6,7 @@ import com.ruoyi.iot.domain.IotDeviceInfo;
import com.ruoyi.iot.domain.response.CommandResponse;
import com.ruoyi.iot.interfaces.IotDevice;
import com.ruoyi.ss.device.domain.enums.DeviceOnlineStatus;
import com.ruoyi.ss.device.domain.vo.DeviceVO;
import java.math.BigDecimal;
import java.util.List;
@ -125,4 +126,8 @@ public interface IotService {
*/
HistoryDeviceData getHistoryDataPoint(String deviceName, String productId);
/**
* 设置电压系数
*/
CommandResponse setVxs(DeviceVO device, BigDecimal vxs, String reason);
}

View File

@ -99,6 +99,9 @@ public class IotConverterImpl implements IotConverter {
case ReceiveConstants.DS_VER:
device.setVersion(value);
break;
case ReceiveConstants.DS_VXS:
device.setVxs(NumberUtils.nonNullDecimal(value, BigDecimal.ZERO));
break;
default:
break;
}

View File

@ -23,6 +23,7 @@ import com.ruoyi.iot.service.IotConverter;
import com.ruoyi.iot.service.IotService;
import com.ruoyi.ss.commandLog.service.ICommandLogService;
import com.ruoyi.ss.device.domain.enums.DeviceOnlineStatus;
import com.ruoyi.ss.device.domain.vo.DeviceVO;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
@ -207,6 +208,29 @@ public class IotServiceImpl implements IotService {
return response.getData();
}
@Override
public CommandResponse setVxs(DeviceVO device, BigDecimal vxs, String reason) {
ServiceUtil.assertion(device == null || vxs == null, "设备或参数为空");
CommandResponse res = null;
if (StringUtils.hasText(device.iotMac1())) {
res = this.setVxs(device.iotMac1(), vxs, device.getProductId(), reason);
}
if ((res == null || !res.isSuccess()) && StringUtils.hasText(device.iotMac2())) {
res = this.setVxs(device.iotMac2(), vxs, device.getProductId(), reason);
}
return res;
}
private CommandResponse setVxs(String deviceName, BigDecimal vxs, String productId, String reason) {
if (StringUtils.isBlank(deviceName) || vxs == null || productId == null) {
return null;
}
String command = IotConstants.COMMAND_SET_VXS + vxs + IotConstants.COMMAND_SEPARATOR;
return sendCommand(deviceName, command, productId, reason);
}
// 获取当前设备数据点信息
public List<CurrentDeviceData> getCurrentDataPoint(List<String> deviceNames, String productId) {
String param = "device_name=" + String.join(",", deviceNames) + "&product_id=" + productId;

View File

@ -256,4 +256,7 @@ public class Device extends BaseEntity
@Excel(name = "最后一次设置总电量初始读数的时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
@ApiModelProperty("最后一次设置总电量初始读数的时间")
private LocalDateTime lastInitReading;
@ApiModelProperty("电压系数")
private BigDecimal vxs;
}

View File

@ -68,6 +68,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
sd.version,
sd.expire_ele,
sd.last_init_reading,
sd.vxs,
sm.model_name as model,
sm.picture as picture,
sm.tags as model_tags,
@ -394,6 +395,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="version != null">version,</if>
<if test="expireEle != null">expire_ele,</if>
<if test="lastInitReading != null">last_init_reading,</if>
<if test="vxs != null">vxs,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="storeId != null">#{storeId},</if>
@ -448,6 +450,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="version != null">#{version},</if>
<if test="expireEle != null">#{expireEle},</if>
<if test="lastInitReading != null">#{lastInitReading},</if>
<if test="vxs != null">#{vxs},</if>
</trim>
</insert>
@ -533,6 +536,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="version != null">version = #{version},</if>
<if test="expireEle != null">expire_ele = #{expireEle},</if>
<if test="lastInitReading != null">last_init_reading = #{lastInitReading},</if>
<if test="vxs != null">vxs = #{vxs},</if>
</trim>
where device_id = #{deviceId}
</update>

View File

@ -389,4 +389,8 @@ public interface DeviceService
*/
int initTotalEle(Long deviceId);
/**
* 修改电压系数
*/
int updateVxs(Long deviceId, BigDecimal vxs, String reason);
}

View File

@ -967,6 +967,7 @@ public class DeviceServiceImpl implements DeviceService
device.setVoltage(deviceInfo.getV());
device.setElectricity(deviceInfo.getA());
device.setVersion(deviceInfo.getVersion());
device.setVxs(deviceInfo.getVxs());
// 总用电量
if (deviceInfo.getW() != null) {
@ -1240,6 +1241,18 @@ public class DeviceServiceImpl implements DeviceService
return deviceMapper.initTotalEle(deviceId);
}
@Override
public int updateVxs(Long deviceId, BigDecimal vxs, String reason) {
if (deviceId == null || vxs == null) {
return 0;
}
DeviceVO device = this.selectById(deviceId);
ServiceUtil.assertion(device == null, "设备不存在");
CommandResponse res = iotService.setVxs(device, vxs, reason);
return res != null && res.isSuccess() ? 1 : 0;
}
/**
* 设备是否已经被绑定
*

View File

@ -299,6 +299,13 @@ public class AppDeviceController extends BaseController {
return toAjax(smDeviceService.switchDevice(deviceId, open, "小程序管理员开关设备"));
}
@ApiOperation("管理员修改设备电压系数")
@DeviceAdminRequired
@PutMapping("/admin/{deviceId}/vxs")
public AjaxResult getExistMac(@PathVariable @ApiParam("设备ID") Long deviceId, @RequestParam @ApiParam("电压系数") BigDecimal vxs) {
return toAjax(smDeviceService.updateVxs(deviceId, vxs, "小程序管理员修改设备电压系数"));
}
@ApiOperation("获取正在使用中的设备列表")
@GetMapping("/usingDevice")
@JsonView(JsonViewProfile.App.class)