Merge pull request #311 from szy833/wvp-28181-2.0
feat(): 增加拉框放大,缩小。接收下级设备控制Message信令后增加200返回,防止下级重复发送Message。pull/317/head
commit
b7c16fe6ed
|
@ -328,4 +328,13 @@ public interface ISIPCommander {
|
||||||
* @return true = 命令发送成功
|
* @return true = 命令发送成功
|
||||||
*/
|
*/
|
||||||
boolean catalogSubscribe(Device device, SipSubscribe.Event okEvent ,SipSubscribe.Event errorEvent);
|
boolean catalogSubscribe(Device device, SipSubscribe.Event okEvent ,SipSubscribe.Event errorEvent);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 拉框控制命令
|
||||||
|
*
|
||||||
|
* @param device 控制设备
|
||||||
|
* @param channelId 通道id
|
||||||
|
* @param cmdString 前端控制指令串
|
||||||
|
*/
|
||||||
|
boolean dragZoomCmd(Device device, String channelId, String cmdString);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1509,6 +1509,34 @@ public class SIPCommander implements ISIPCommander {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean dragZoomCmd(Device device, String channelId, String cmdString) {
|
||||||
|
try {
|
||||||
|
StringBuffer dragXml = new StringBuffer(200);
|
||||||
|
dragXml.append("<?xml version=\"1.0\" ?>\r\n");
|
||||||
|
dragXml.append("<Control>\r\n");
|
||||||
|
dragXml.append("<CmdType>DeviceControl</CmdType>\r\n");
|
||||||
|
dragXml.append("<SN>" + (int) ((Math.random() * 9 + 1) * 100000) + "</SN>\r\n");
|
||||||
|
if (StringUtils.isEmpty(channelId)) {
|
||||||
|
dragXml.append("<DeviceID>" + device.getDeviceId() + "</DeviceID>\r\n");
|
||||||
|
} else {
|
||||||
|
dragXml.append("<DeviceID>" + channelId + "</DeviceID>\r\n");
|
||||||
|
}
|
||||||
|
dragXml.append(cmdString);
|
||||||
|
dragXml.append("</Control>\r\n");
|
||||||
|
String tm = Long.toString(System.currentTimeMillis());
|
||||||
|
CallIdHeader callIdHeader = device.getTransport().equals("TCP") ? tcpSipProvider.getNewCallId()
|
||||||
|
: udpSipProvider.getNewCallId();
|
||||||
|
Request request = headerProvider.createMessageRequest(device, dragXml.toString(), "z9hG4bK-ViaPtz-" + tm, "FromPtz" + tm, null, callIdHeader);
|
||||||
|
logger.debug("拉框信令: " + request.toString());
|
||||||
|
transmitRequest(device, request);
|
||||||
|
return true;
|
||||||
|
} catch (SipException | ParseException | InvalidArgumentException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private ClientTransaction transmitRequest(Device device, Request request) throws SipException {
|
private ClientTransaction transmitRequest(Device device, Request request) throws SipException {
|
||||||
return transmitRequest(device, request, null, null);
|
return transmitRequest(device, request, null, null);
|
||||||
|
|
|
@ -16,7 +16,12 @@ import org.springframework.beans.factory.InitializingBean;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import javax.sip.InvalidArgumentException;
|
||||||
import javax.sip.RequestEvent;
|
import javax.sip.RequestEvent;
|
||||||
|
import javax.sip.SipException;
|
||||||
|
import javax.sip.message.Response;
|
||||||
|
|
||||||
|
import java.text.ParseException;
|
||||||
|
|
||||||
import static com.genersoft.iot.vmp.gb28181.utils.XmlUtil.getText;
|
import static com.genersoft.iot.vmp.gb28181.utils.XmlUtil.getText;
|
||||||
|
|
||||||
|
@ -40,6 +45,8 @@ public class DeviceControlResponseMessageHandler extends SIPRequestProcessorPare
|
||||||
@Override
|
@Override
|
||||||
public void handForDevice(RequestEvent evt, Device device, Element element) {
|
public void handForDevice(RequestEvent evt, Device device, Element element) {
|
||||||
// 此处是对本平台发出DeviceControl指令的应答
|
// 此处是对本平台发出DeviceControl指令的应答
|
||||||
|
try {
|
||||||
|
responseAck(evt, Response.OK);
|
||||||
JSONObject json = new JSONObject();
|
JSONObject json = new JSONObject();
|
||||||
String channelId = getText(element, "DeviceID");
|
String channelId = getText(element, "DeviceID");
|
||||||
XmlUtil.node2Json(element, json);
|
XmlUtil.node2Json(element, json);
|
||||||
|
@ -51,6 +58,13 @@ public class DeviceControlResponseMessageHandler extends SIPRequestProcessorPare
|
||||||
msg.setKey(key);
|
msg.setKey(key);
|
||||||
msg.setData(json);
|
msg.setData(json);
|
||||||
deferredResultHolder.invokeAllResult(msg);
|
deferredResultHolder.invokeAllResult(msg);
|
||||||
|
} catch (SipException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (InvalidArgumentException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (ParseException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -0,0 +1,138 @@
|
||||||
|
package com.genersoft.iot.vmp.vmanager.gb28181.dragZoom;
|
||||||
|
|
||||||
|
import com.genersoft.iot.vmp.gb28181.bean.Device;
|
||||||
|
import com.genersoft.iot.vmp.gb28181.transmit.callback.DeferredResultHolder;
|
||||||
|
import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
|
||||||
|
import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
|
||||||
|
import io.swagger.annotations.Api;
|
||||||
|
import io.swagger.annotations.ApiImplicitParam;
|
||||||
|
import io.swagger.annotations.ApiImplicitParams;
|
||||||
|
import io.swagger.annotations.ApiOperation;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.http.HttpStatus;
|
||||||
|
import org.springframework.http.ResponseEntity;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author szy
|
||||||
|
* @date 21:55 2022/1/15
|
||||||
|
*/
|
||||||
|
@Api(tags = "拉框控制")
|
||||||
|
@CrossOrigin
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/api/dragZoom")
|
||||||
|
public class DragZoomControl {
|
||||||
|
|
||||||
|
private final static Logger logger = LoggerFactory.getLogger(DragZoomControl.class);
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private SIPCommander cmder;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private IVideoManagerStorager storager;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private DeferredResultHolder resultHolder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 拉框放大
|
||||||
|
* @param deviceId 设备id
|
||||||
|
* @param channelId 通道id
|
||||||
|
* @param length 播放窗口长度像素值
|
||||||
|
* @param width 播放窗口宽度像素值
|
||||||
|
* @param midpointx 拉框中心的横轴坐标像素值
|
||||||
|
* @param midpointy 拉框中心的纵轴坐标像素值
|
||||||
|
* @param lengthx 拉框长度像素值
|
||||||
|
* @param lengthy 拉框宽度像素值
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@ApiOperation("拉框放大")
|
||||||
|
@ApiImplicitParams({
|
||||||
|
@ApiImplicitParam(name = "deviceId", value = "设备ID", required = true, dataTypeClass = String.class),
|
||||||
|
@ApiImplicitParam(name = "channelId", value = "通道ID", dataTypeClass = String.class),
|
||||||
|
@ApiImplicitParam(name = "length", value = "播放窗口长度像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "width", value = "播放窗口宽度像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "midpointx", value = "拉框中心的横轴坐标像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "midpointy", value = "拉框中心的纵轴坐标像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "lengthx", value = "拉框长度像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "lengthy", value = "拉框宽度像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
})
|
||||||
|
@GetMapping("/dragzoomin")
|
||||||
|
public ResponseEntity<String> dragZoomIn(@RequestParam String deviceId,
|
||||||
|
@RequestParam(required = false) String channelId,
|
||||||
|
@RequestParam int length,
|
||||||
|
@RequestParam int width,
|
||||||
|
@RequestParam int midpointx,
|
||||||
|
@RequestParam int midpointy,
|
||||||
|
@RequestParam int lengthx,
|
||||||
|
@RequestParam int lengthy){
|
||||||
|
if (logger.isDebugEnabled()) {
|
||||||
|
logger.debug(String.format("设备拉框放大 API调用,deviceId:%s ,channelId:%s ,length:%d ,width:%d ,midpointx:%d ,midpointy:%d ,lengthx:%d ,lengthy:%d",deviceId, channelId, length, width, midpointx, midpointy,lengthx, lengthy));
|
||||||
|
}
|
||||||
|
Device device = storager.queryVideoDevice(deviceId);
|
||||||
|
StringBuffer cmdXml = new StringBuffer(200);
|
||||||
|
cmdXml.append("<DragZoomIn>\r\n");
|
||||||
|
cmdXml.append("<Length>" + length+ "</Length>\r\n");
|
||||||
|
cmdXml.append("<Width>" + width+ "</Width>\r\n");
|
||||||
|
cmdXml.append("<MidPointX>" + midpointx+ "</MidPointX>\r\n");
|
||||||
|
cmdXml.append("<MidPointY>" + midpointy+ "</MidPointY>\r\n");
|
||||||
|
cmdXml.append("<LengthX>" + lengthx+ "</LengthX>\r\n");
|
||||||
|
cmdXml.append("<LengthY>" + lengthy+ "</LengthY>\r\n");
|
||||||
|
cmdXml.append("</DragZoomIn>\r\n");
|
||||||
|
cmder.dragZoomCmd(device, channelId, cmdXml.toString());
|
||||||
|
return new ResponseEntity<String>("success", HttpStatus.OK);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 拉框缩小
|
||||||
|
* @param deviceId 设备id
|
||||||
|
* @param channelId 通道id
|
||||||
|
* @param length 播放窗口长度像素值
|
||||||
|
* @param width 播放窗口宽度像素值
|
||||||
|
* @param midpointx 拉框中心的横轴坐标像素值
|
||||||
|
* @param midpointy 拉框中心的纵轴坐标像素值
|
||||||
|
* @param lengthx 拉框长度像素值
|
||||||
|
* @param lengthy 拉框宽度像素值
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@ApiOperation("拉框缩小")
|
||||||
|
@ApiImplicitParams({
|
||||||
|
@ApiImplicitParam(name = "deviceId", value = "设备ID", required = true, dataTypeClass = String.class),
|
||||||
|
@ApiImplicitParam(name = "channelId", value = "通道ID", dataTypeClass = String.class),
|
||||||
|
@ApiImplicitParam(name = "length", value = "播放窗口长度像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "width", value = "播放窗口宽度像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "midpointx", value = "拉框中心的横轴坐标像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "midpointy", value = "拉框中心的纵轴坐标像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "lengthx", value = "拉框长度像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
@ApiImplicitParam(name = "lengthy", value = "拉框宽度像素值", required = true, dataTypeClass = Integer.class),
|
||||||
|
})
|
||||||
|
@GetMapping("/dragzoomout")
|
||||||
|
public ResponseEntity<String> dragZoomOut(@RequestParam String deviceId,
|
||||||
|
@RequestParam(required = false) String channelId,
|
||||||
|
@RequestParam int length,
|
||||||
|
@RequestParam int width,
|
||||||
|
@RequestParam int midpointx,
|
||||||
|
@RequestParam int midpointy,
|
||||||
|
@RequestParam int lengthx,
|
||||||
|
@RequestParam int lengthy){
|
||||||
|
|
||||||
|
if (logger.isDebugEnabled()) {
|
||||||
|
logger.debug(String.format("设备拉框缩小 API调用,deviceId:%s ,channelId:%s ,length:%d ,width:%d ,midpointx:%d ,midpointy:%d ,lengthx:%d ,lengthy:%d",deviceId, channelId, length, width, midpointx, midpointy,lengthx, lengthy));
|
||||||
|
}
|
||||||
|
Device device = storager.queryVideoDevice(deviceId);
|
||||||
|
StringBuffer cmdXml = new StringBuffer(200);
|
||||||
|
cmdXml.append("<DragZoomOut>\r\n");
|
||||||
|
cmdXml.append("<Length>" + length+ "</Length>\r\n");
|
||||||
|
cmdXml.append("<Width>" + width+ "</Width>\r\n");
|
||||||
|
cmdXml.append("<MidPointX>" + midpointx+ "</MidPointX>\r\n");
|
||||||
|
cmdXml.append("<MidPointY>" + midpointy+ "</MidPointY>\r\n");
|
||||||
|
cmdXml.append("<LengthX>" + lengthx+ "</LengthX>\r\n");
|
||||||
|
cmdXml.append("<LengthY>" + lengthy+ "</LengthY>\r\n");
|
||||||
|
cmdXml.append("</DragZoomOut>\r\n");
|
||||||
|
cmder.dragZoomCmd(device, channelId, cmdXml.toString());
|
||||||
|
return new ResponseEntity<String>("success",HttpStatus.OK);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue