临时提交

结构优化
648540858 2024-01-29 12:32:35 +08:00
parent 367acdaf97
commit 565acaefb5
10 changed files with 159 additions and 57 deletions

View File

@ -5,6 +5,9 @@ import com.genersoft.iot.vmp.common.StreamInfo;
import com.genersoft.iot.vmp.conf.exception.ControllerException; import com.genersoft.iot.vmp.conf.exception.ControllerException;
import com.genersoft.iot.vmp.gb28181.bean.Device; import com.genersoft.iot.vmp.gb28181.bean.Device;
import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel; import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
import com.genersoft.iot.vmp.gb28181.bean.command.PTZCommand;
import com.genersoft.iot.vmp.gb28181.transmit.cmd.ISIPCommander;
import com.genersoft.iot.vmp.gb28181.utils.SipUtils;
import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem; import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem;
import com.genersoft.iot.vmp.service.IPlayService; import com.genersoft.iot.vmp.service.IPlayService;
import com.genersoft.iot.vmp.service.IResourcePlayCallback; import com.genersoft.iot.vmp.service.IResourcePlayCallback;
@ -14,11 +17,16 @@ import com.genersoft.iot.vmp.service.bean.InviteErrorCode;
import com.genersoft.iot.vmp.storager.dao.DeviceChannelMapper; import com.genersoft.iot.vmp.storager.dao.DeviceChannelMapper;
import com.genersoft.iot.vmp.storager.dao.DeviceMapper; import com.genersoft.iot.vmp.storager.dao.DeviceMapper;
import com.genersoft.iot.vmp.vmanager.bean.ErrorCode; import com.genersoft.iot.vmp.vmanager.bean.ErrorCode;
import org.aspectj.bridge.ICommand;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import javax.sip.InvalidArgumentException;
import javax.sip.SipException;
import java.text.ParseException;
/** /**
* *
@ -37,6 +45,9 @@ public class GB28181ResourceServiceImpl implements IResourceService {
@Autowired @Autowired
private IPlayService playService; private IPlayService playService;
@Autowired
private ISIPCommander commander;
@Override @Override
public boolean deleteChannel(CommonGbChannel commonGbChannel) { public boolean deleteChannel(CommonGbChannel commonGbChannel) {
if (!CommonGbChannelType.GB28181.equals(commonGbChannel.getType())) { if (!CommonGbChannelType.GB28181.equals(commonGbChannel.getType())) {
@ -49,26 +60,19 @@ public class GB28181ResourceServiceImpl implements IResourceService {
@Override @Override
public void startPlay(CommonGbChannel commonGbChannel, IResourcePlayCallback callback) { public void startPlay(CommonGbChannel commonGbChannel, IResourcePlayCallback callback) {
assert callback != null; assert callback != null;
if (!CommonGbChannelType.GB28181.equals(commonGbChannel.getType())) { CheckCommonGbChannelResult checkResult = checkCommonGbChannel(commonGbChannel);
logger.warn("[资源类-国标28181] 收到播放通道: {} 时发现类型不为28181", commonGbChannel.getCommonGbId());
callback.call(commonGbChannel, null, ErrorCode.ERROR100.getCode(), "数据关系错误", null); if (checkResult.errorMsg != null) {
callback.call(commonGbChannel, null, ErrorCode.SUCCESS.getCode(), checkResult.errorMsg, null);
return; return;
} }
DeviceChannel channel = deviceChannelMapper.getChannelByCommonChannelId(commonGbChannel.getCommonGbId()); if (checkResult.device == null || checkResult.channel == null) {
if (channel == null) { callback.call(commonGbChannel, null, ErrorCode.SUCCESS.getCode(), "设备获取失败", null);
logger.warn("[资源类-国标28181] 收到播放通道: {} 时未找到国标通道", commonGbChannel.getCommonGbId());
callback.call(commonGbChannel, null, ErrorCode.ERROR100.getCode(), "未找到通道", null);
return; return;
} }
Device device = deviceMapper.getDeviceByDeviceId(channel.getDeviceId());
if (device == null) { MediaServerItem mediaServerItem = playService.getNewMediaServerItem(checkResult.device);
logger.warn("[资源类-国标28181] 收到播放通道: {} 时未找到通道 {} 所属的国标设备", playService.play(mediaServerItem, checkResult.channel.getDeviceId(), checkResult.channel.getChannelId(), null, (code, msg, data) -> {
commonGbChannel.getCommonGbId(), channel.getDeviceId());
callback.call(commonGbChannel, null, ErrorCode.ERROR100.getCode(), "未找到设备", null);
return;
}
MediaServerItem mediaServerItem = playService.getNewMediaServerItem(device);
playService.play(mediaServerItem, channel.getDeviceId(), channel.getChannelId(), null, (code, msg, data) -> {
if (code == InviteErrorCode.SUCCESS.getCode()) { if (code == InviteErrorCode.SUCCESS.getCode()) {
StreamInfo streamInfo = (StreamInfo)data; StreamInfo streamInfo = (StreamInfo)data;
callback.call(commonGbChannel, mediaServerItem, ErrorCode.SUCCESS.getCode(), ErrorCode.SUCCESS.getMsg(), streamInfo); callback.call(commonGbChannel, mediaServerItem, ErrorCode.SUCCESS.getCode(), ErrorCode.SUCCESS.getMsg(), streamInfo);
@ -80,23 +84,18 @@ public class GB28181ResourceServiceImpl implements IResourceService {
@Override @Override
public void stopPlay(CommonGbChannel commonGbChannel, IResourcePlayCallback callback) { public void stopPlay(CommonGbChannel commonGbChannel, IResourcePlayCallback callback) {
if (!CommonGbChannelType.GB28181.equals(commonGbChannel.getType())) { CheckCommonGbChannelResult checkResult = checkCommonGbChannel(commonGbChannel);
logger.warn("[资源类-国标28181] 收到停止播放通道: {} 时发现类型不为28181", commonGbChannel.getCommonGbId());
if (callback != null) { if (checkResult.errorMsg != null) {
callback.call(commonGbChannel,null, ErrorCode.ERROR100.getCode(), "数据关系错误", null); callback.call(commonGbChannel, null, ErrorCode.SUCCESS.getCode(), checkResult.errorMsg, null);
}
return; return;
} }
DeviceChannel channel = deviceChannelMapper.getChannelByCommonChannelId(commonGbChannel.getCommonGbId()); if (checkResult.device == null || checkResult.channel == null) {
if (channel == null) { callback.call(commonGbChannel, null, ErrorCode.SUCCESS.getCode(), "设备获取失败", null);
logger.warn("[资源类-国标28181] 收到停止播放通道: {} 时未找到国标通道", commonGbChannel.getCommonGbId());
if (callback != null) {
callback.call(commonGbChannel, null, ErrorCode.ERROR100.getCode(), "未找到通道", null);
}
return; return;
} }
try { try {
playService.stop(channel.getDeviceId(), channel.getChannelId()); playService.stop(checkResult.channel.getDeviceId(), checkResult.channel.getChannelId());
} catch (ControllerException exception) { } catch (ControllerException exception) {
if (callback != null) { if (callback != null) {
callback.call(commonGbChannel, null,exception.getCode(), exception.getMsg(), null); callback.call(commonGbChannel, null,exception.getCode(), exception.getMsg(), null);
@ -105,9 +104,22 @@ public class GB28181ResourceServiceImpl implements IResourceService {
} }
@Override @Override
public boolean ptzControl(CommonGbChannel commonGbChannel, public boolean ptzControl(CommonGbChannel commonGbChannel, PTZCommand ptzCommand) {
String command, Integer horizonSpeed, CheckCommonGbChannelResult checkResult = checkCommonGbChannel(commonGbChannel);
Integer verticalSpeed, Integer zoomSpeed) {
if (checkResult.errorMsg != null) {
logger.warn("[资源类-国标28181] 云台控制失败: {}", checkResult.errorMsg);
return false;
}
if (checkResult.device == null || checkResult.channel == null) {
logger.warn("[资源类-国标28181] 云台控制失败: 设备获取失败");
return false;
}
try {
commander.ptzCmd(checkResult.device, checkResult.channel.getChannelId(), ptzCommand);
} catch (InvalidArgumentException | SipException | ParseException e) {
logger.error("[命令发送失败] ", e);
}
return false; return false;
} }
@ -125,4 +137,44 @@ public class GB28181ResourceServiceImpl implements IResourceService {
public void startDownload(CommonGbChannel channel, Long startTime, Long stopTime, Integer downloadSpeed, IResourcePlayCallback playCallback) { public void startDownload(CommonGbChannel channel, Long startTime, Long stopTime, Integer downloadSpeed, IResourcePlayCallback playCallback) {
} }
static class CheckCommonGbChannelResult {
Device device;
DeviceChannel channel;
String errorMsg;
public CheckCommonGbChannelResult(String errorMsg) {
this.errorMsg = errorMsg;
}
public CheckCommonGbChannelResult(Device device, DeviceChannel channel) {
this.device = device;
this.channel = channel;
}
}
private CheckCommonGbChannelResult checkCommonGbChannel(CommonGbChannel commonGbChannel) {
if (commonGbChannel == null) {
logger.warn("[资源类-检验参数] 通道不可为NULL");
return new CheckCommonGbChannelResult("通道不可为NULL");
}
if (!CommonGbChannelType.GB28181.equals(commonGbChannel.getType())) {
logger.warn("[资源类-国标28181] 收到通道: {} 时发现类型不为28181", commonGbChannel.getCommonGbId());
return new CheckCommonGbChannelResult("数据关系错误");
}
DeviceChannel channel = deviceChannelMapper.getChannelByCommonChannelId(commonGbChannel.getCommonGbId());
if (channel == null) {
logger.warn("[资源类-国标28181] 收到通道: {} 时未找到国标通道", commonGbChannel.getCommonGbId());
return new CheckCommonGbChannelResult("未找到通道");
}
Device device = deviceMapper.getDeviceByDeviceId(channel.getDeviceId());
if (device == null) {
logger.warn("[资源类-国标28181] 收到通道: {} 时未找到通道 {} 所属的国标设备",
commonGbChannel.getCommonGbId(), channel.getDeviceId());
return new CheckCommonGbChannelResult("未找到设备");
}
return new CheckCommonGbChannelResult(device, channel);
}
} }

View File

@ -4,6 +4,7 @@ import com.genersoft.iot.vmp.common.StreamInfo;
import com.genersoft.iot.vmp.conf.exception.SsrcTransactionNotFoundException; import com.genersoft.iot.vmp.conf.exception.SsrcTransactionNotFoundException;
import com.genersoft.iot.vmp.gb28181.bean.Device; import com.genersoft.iot.vmp.gb28181.bean.Device;
import com.genersoft.iot.vmp.gb28181.bean.DeviceAlarm; import com.genersoft.iot.vmp.gb28181.bean.DeviceAlarm;
import com.genersoft.iot.vmp.gb28181.bean.command.PTZCommand;
import com.genersoft.iot.vmp.gb28181.event.SipSubscribe; import com.genersoft.iot.vmp.gb28181.event.SipSubscribe;
import com.genersoft.iot.vmp.media.zlm.ZlmHttpHookSubscribe; import com.genersoft.iot.vmp.media.zlm.ZlmHttpHookSubscribe;
import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem; import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem;
@ -72,6 +73,7 @@ public interface ISIPCommander {
* @param zoomSpeed * @param zoomSpeed
*/ */
void ptzCmd(Device device,String channelId,int leftRight, int upDown, int inOut, int moveSpeed, int zoomSpeed) throws InvalidArgumentException, SipException, ParseException; void ptzCmd(Device device,String channelId,int leftRight, int upDown, int inOut, int moveSpeed, int zoomSpeed) throws InvalidArgumentException, SipException, ParseException;
void ptzCmd(Device device, String channelId, PTZCommand ptzCommand) throws InvalidArgumentException, SipException, ParseException;
/** /**
* PTZFI * PTZFI

View File

@ -9,6 +9,7 @@ import com.genersoft.iot.vmp.gb28181.SipLayer;
import com.genersoft.iot.vmp.gb28181.bean.Device; import com.genersoft.iot.vmp.gb28181.bean.Device;
import com.genersoft.iot.vmp.gb28181.bean.DeviceAlarm; import com.genersoft.iot.vmp.gb28181.bean.DeviceAlarm;
import com.genersoft.iot.vmp.gb28181.bean.SsrcTransaction; import com.genersoft.iot.vmp.gb28181.bean.SsrcTransaction;
import com.genersoft.iot.vmp.gb28181.bean.command.PTZCommand;
import com.genersoft.iot.vmp.gb28181.event.SipSubscribe; import com.genersoft.iot.vmp.gb28181.event.SipSubscribe;
import com.genersoft.iot.vmp.gb28181.session.VideoStreamSessionManager; import com.genersoft.iot.vmp.gb28181.session.VideoStreamSessionManager;
import com.genersoft.iot.vmp.gb28181.transmit.SIPSender; import com.genersoft.iot.vmp.gb28181.transmit.SIPSender;

View File

@ -2,10 +2,10 @@ package com.genersoft.iot.vmp.gb28181.transmit.event.request.impl.message.contro
import com.genersoft.iot.vmp.common.CommonGbChannel; import com.genersoft.iot.vmp.common.CommonGbChannel;
import com.genersoft.iot.vmp.common.enums.DeviceControlType; import com.genersoft.iot.vmp.common.enums.DeviceControlType;
import com.genersoft.iot.vmp.gb28181.bean.Device; import com.genersoft.iot.vmp.gb28181.bean.*;
import com.genersoft.iot.vmp.gb28181.bean.DragZoomRequest; import com.genersoft.iot.vmp.gb28181.bean.command.CommandType;
import com.genersoft.iot.vmp.gb28181.bean.HomePositionRequest; import com.genersoft.iot.vmp.gb28181.bean.command.ICommandInfo;
import com.genersoft.iot.vmp.gb28181.bean.ParentPlatform; import com.genersoft.iot.vmp.gb28181.bean.command.PTZCommand;
import com.genersoft.iot.vmp.gb28181.event.SipSubscribe; import com.genersoft.iot.vmp.gb28181.event.SipSubscribe;
import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander; import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommanderFroPlatform; import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommanderFroPlatform;
@ -143,18 +143,36 @@ public class DeviceControlQueryMessageHandler extends SIPRequestProcessorParent
} }
return; return;
} }
// 解析云台控制参数
// resourceService.ptzControl(commonGbChannel)
String cmdString = getText(rootElement, type.getVal()); String cmdString = getText(rootElement, type.getVal());
byte[] bytes = cmdString.getBytes(); // 解析云台控制参数
System.out.println(cmdString); ICommandInfo commandInfo = ControlCommand.analysisCommand(cmdString);
for (byte aByte : bytes) { if (commandInfo == null || !commandInfo.getType().equals(CommandType.PTZ)) {
System.out.print(aByte); try {
System.out.print(" "); responseAck(request, Response.OK);
} catch (SipException | InvalidArgumentException | ParseException e) {
logger.error("[命令发送失败] 错误信息: {}", e.getMessage());
} }
System.out.println(" "); return;
}
PTZCommand ptzCommand = (PTZCommand)commandInfo;
logger.info("\r\n[云台控制]: \r\n镜头变倍: 放大: {},缩小: {} " +
" \r\n垂直方向控制 上: {} 下: {} 左: {},右: {}" +
" \r\n平控制速度相对值: {}, 垂直控制速度相对值: {}, 变倍控制速度相对值: {}",
ptzCommand.isIn(), ptzCommand.isOut(),
ptzCommand.isUp(), ptzCommand.isDown(), ptzCommand.isLeft(), ptzCommand.isRight(),
ptzCommand.getxSpeed(), ptzCommand.getySpeed(), ptzCommand.getzSpeed());
resourceService.ptzControl(commonGbChannel, ptzCommand);
// System.out.println();
// byte[] bytes = cmdString.getBytes();
// System.out.println(cmdString);
// for (byte aByte : bytes) {
// System.out.print(aByte);
// System.out.print(" ");
// }
// System.out.println(" ");
// try { // try {
// cmder.fronEndCmd(device, channelId, cmdString, // cmder.fronEndCmd(device, channelId, cmdString,
// errorResult -> onError(request, errorResult), // errorResult -> onError(request, errorResult),

View File

@ -1,6 +1,7 @@
package com.genersoft.iot.vmp.gb28181.utils; package com.genersoft.iot.vmp.gb28181.utils;
import com.genersoft.iot.vmp.gb28181.bean.*; import com.genersoft.iot.vmp.gb28181.bean.*;
import com.genersoft.iot.vmp.gb28181.bean.command.PTZCommand;
import com.genersoft.iot.vmp.utils.DateUtil; import com.genersoft.iot.vmp.utils.DateUtil;
import com.genersoft.iot.vmp.utils.GitUtil; import com.genersoft.iot.vmp.utils.GitUtil;
import gov.nist.javax.sdp.TimeDescriptionImpl; import gov.nist.javax.sdp.TimeDescriptionImpl;
@ -143,6 +144,38 @@ public class SipUtils {
return builder.toString(); return builder.toString();
} }
public static String cmdString(PTZCommand command) {
int byte4Int = 0;
if (command.isRight()) {
byte4Int += 1;
}
if (command.isLeft()) {
byte4Int += 2;
}
if (command.isDown()) {
byte4Int += 4;
}
if (command.isUp()) {
byte4Int += 8;
}
if (command.isIn()) {
byte4Int += 16;
}
if (command.isOut()) {
byte4Int += 32;
}
StringBuilder builder = new StringBuilder("A50F01");
builder.append(Integer.toHexString(byte4Int), 0, 2);
builder.append(Integer.toHexString(command.getxSpeed()), 0, 2);
builder.append(Integer.toHexString(command.getySpeed()), 0, 2);
builder.append(Integer.toHexString(command.getzSpeed()), 0, 1);
//计算校验码
int checkCode = (0XA5 + 0X0F + 0X01 + byte4Int + command.getxSpeed() + command.getySpeed() + (command.getzSpeed() /*<< 4*/ & 0XF0)) % 0X100;
builder.append(String.format("%02X", checkCode), 0, 2);
return builder.toString();
}
/** /**
* ip * ip
* @param request * @param request

View File

@ -498,7 +498,7 @@ public class ZLMHttpHookListener {
} }
// 收到无人观看说明流也没有在往上级推送 // 收到无人观看说明流也没有在往上级推送
List<SendRtpItem> sendRtpItems = streamSendManager.getByByChanelId(inviteInfo.getChannelId()); List<SendRtpItem> sendRtpItems = streamSendManager.getByByChanelId(inviteInfo.getChannelId());
if (!sendRtpItems.isEmpty()) { if (sendRtpItems != null && !sendRtpItems.isEmpty()) {
for (SendRtpItem sendRtpItem : sendRtpItems) { for (SendRtpItem sendRtpItem : sendRtpItems) {
ParentPlatform parentPlatform = storager.queryParentPlatByServerGBId(sendRtpItem.getDestId()); ParentPlatform parentPlatform = storager.queryParentPlatByServerGBId(sendRtpItem.getDestId());
try { try {

View File

@ -2,6 +2,7 @@ package com.genersoft.iot.vmp.service;
import com.genersoft.iot.vmp.common.CommonGbChannel; import com.genersoft.iot.vmp.common.CommonGbChannel;
import com.genersoft.iot.vmp.common.StreamInfo; import com.genersoft.iot.vmp.common.StreamInfo;
import com.genersoft.iot.vmp.gb28181.bean.command.PTZCommand;
/** /**
* *
@ -28,15 +29,8 @@ public interface IResourceService {
/** /**
* *
* @param commonGbChannel
* @param command ,: left, right, up, down, upleft, upright, downleft, downright, zoomin, zoomout, stop
* @param horizonSpeed 0-255
* @param verticalSpeed 0-255
* @param zoomSpeed
* @return
*/ */
boolean ptzControl(CommonGbChannel commonGbChannel, String command, boolean ptzControl(CommonGbChannel commonGbChannel, PTZCommand ptzCommand);
Integer horizonSpeed, Integer verticalSpeed, Integer zoomSpeed);
/** /**
* 线 * 线

View File

@ -201,7 +201,7 @@ public class MediaServerServiceImpl implements IMediaServerService {
@Override @Override
public void closeRTPServer(String mediaServerId, String streamId) { public void closeRTPServer(String mediaServerId, String streamId) {
MediaServerItem mediaServerItem = this.getOne(mediaServerId); MediaServerItem mediaServerItem = this.getOne(mediaServerId);
if (mediaServerItem.isRtpEnable()) { if (mediaServerItem != null && mediaServerItem.isRtpEnable()) {
closeRTPServer(mediaServerItem, streamId); closeRTPServer(mediaServerItem, streamId);
} }
zlmresTfulUtils.closeStreams(mediaServerItem, "rtp", streamId); zlmresTfulUtils.closeStreams(mediaServerItem, "rtp", streamId);

View File

@ -3,6 +3,7 @@ package com.genersoft.iot.vmp.service.impl;
import com.genersoft.iot.vmp.common.CommonGbChannel; import com.genersoft.iot.vmp.common.CommonGbChannel;
import com.genersoft.iot.vmp.common.StreamInfo; import com.genersoft.iot.vmp.common.StreamInfo;
import com.genersoft.iot.vmp.gb28181.GB28181ResourceServiceImpl; import com.genersoft.iot.vmp.gb28181.GB28181ResourceServiceImpl;
import com.genersoft.iot.vmp.gb28181.bean.command.PTZCommand;
import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem; import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem;
import com.genersoft.iot.vmp.media.zlm.dto.StreamProxy; import com.genersoft.iot.vmp.media.zlm.dto.StreamProxy;
import com.genersoft.iot.vmp.service.*; import com.genersoft.iot.vmp.service.*;
@ -75,7 +76,7 @@ public class StreamProxyResourceServiceImpl implements IResourceService {
} }
@Override @Override
public boolean ptzControl(CommonGbChannel commonGbChannel, String command, Integer horizonSpeed, Integer verticalSpeed, Integer zoomSpeed) { public boolean ptzControl(CommonGbChannel commonGbChannel, PTZCommand ptzCommand) {
return false; return false;
} }

View File

@ -1,6 +1,7 @@
package com.genersoft.iot.vmp.service.impl; package com.genersoft.iot.vmp.service.impl;
import com.genersoft.iot.vmp.common.CommonGbChannel; import com.genersoft.iot.vmp.common.CommonGbChannel;
import com.genersoft.iot.vmp.gb28181.bean.command.PTZCommand;
import com.genersoft.iot.vmp.service.IResourcePlayCallback; import com.genersoft.iot.vmp.service.IResourcePlayCallback;
import com.genersoft.iot.vmp.service.IResourceService; import com.genersoft.iot.vmp.service.IResourceService;
import com.genersoft.iot.vmp.service.bean.CommonGbChannelType; import com.genersoft.iot.vmp.service.bean.CommonGbChannelType;
@ -24,7 +25,7 @@ public class StreamPushResourceServiceImpl implements IResourceService {
} }
@Override @Override
public boolean ptzControl(CommonGbChannel commonGbChannel, String command, Integer horizonSpeed, Integer verticalSpeed, Integer zoomSpeed) { public boolean ptzControl(CommonGbChannel commonGbChannel, PTZCommand ptzCommand) {
return false; return false;
} }