|
@@ -260,6 +260,7 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
|
|
|
/**
|
|
|
* web页面实时流接口
|
|
|
+ *
|
|
|
* @param cameraCode
|
|
|
* @param channel
|
|
|
* @return
|
|
@@ -561,7 +562,7 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
host = caneraConfig.getHost();
|
|
|
appKey = caneraConfig.getAppKey();
|
|
|
appSecret = caneraConfig.getAppSecret();
|
|
|
- rtmpUrl=caneraConfig.getRtmpUrl();
|
|
|
+ rtmpUrl = caneraConfig.getRtmpUrl();
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -704,6 +705,7 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
|
|
|
/**
|
|
|
* web页面视频回放接口
|
|
|
+ *
|
|
|
* @param code
|
|
|
* @param startTm
|
|
|
* @param endTm
|
|
@@ -744,8 +746,8 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
@Override
|
|
|
public String call() throws Exception {
|
|
|
// 执行网络请求...
|
|
|
- log.info(ffmpegPath + " -re -i /opt/streams/compress/" + code + ".mp4 -c:v copy -c:a copy -f flv "+rtmpUrl+"/live/" + code);
|
|
|
- cmdCameraUtil.cmd(ffmpegPath + " -re -i /opt/streams/compress/" + code + ".mp4 -c:v copy -c:a copy -f flv "+rtmpUrl+"/live/" + code);
|
|
|
+ log.info(ffmpegPath + " -re -i /opt/streams/compress/" + code + ".mp4 -c:v copy -c:a copy -f flv " + rtmpUrl + "/live/" + code);
|
|
|
+ cmdCameraUtil.cmd(ffmpegPath + " -re -i /opt/streams/compress/" + code + ".mp4 -c:v copy -c:a copy -f flv " + rtmpUrl + "/live/" + code);
|
|
|
return "Response";
|
|
|
}
|
|
|
};
|
|
@@ -759,7 +761,7 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
}
|
|
|
|
|
|
executor.shutdown();
|
|
|
- return bakUrlRtsp+"/live/"+code;
|
|
|
+ return bakUrlRtsp + "/live/" + code;
|
|
|
}
|
|
|
|
|
|
|
|
@@ -767,9 +769,9 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
* RTSP流视频压缩
|
|
|
*/
|
|
|
public void videoCompression(String code) {
|
|
|
- // 执行网络请求...
|
|
|
- log.info(ffmpegPath + " -i /opt/streams/map/"+code+".mp4 -c:v libx264 -s 640x480 -c:a adpcm_swf -ar 44100 /opt/streams/compress/" + code+".mp4");
|
|
|
- cmdCameraUtil.cmd(ffmpegPath + " -i /opt/streams/map/"+code+".mp4 -c:v libx264 -s 640x480 -c:a adpcm_swf -ar 44100 /opt/streams/compress/" + code+".mp4");
|
|
|
+ // 执行网络请求...
|
|
|
+ log.info(ffmpegPath + " -i /opt/streams/map/" + code + ".mp4 -c:v libx264 -s 640x480 -c:a adpcm_swf -ar 44100 /opt/streams/compress/" + code + ".mp4");
|
|
|
+ cmdCameraUtil.cmd(ffmpegPath + " -i /opt/streams/map/" + code + ".mp4 -c:v libx264 -s 640x480 -c:a adpcm_swf -ar 44100 /opt/streams/compress/" + code + ".mp4");
|
|
|
}
|
|
|
|
|
|
|
|
@@ -940,10 +942,11 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
|
|
|
/**
|
|
|
* 车载终端实时流调用的远程天网接口
|
|
|
+ *
|
|
|
* @param camerasVo
|
|
|
* @param channel
|
|
|
*/
|
|
|
- public String apiPreviewURLs(CamerasVo camerasVo) {
|
|
|
+ public String apiPreviewURLs(CamerasVo camerasVo) {
|
|
|
/**
|
|
|
* jsonBody.put("cameraIndexCode", "01ea43e6676f4e47bd6c5cd9e02aa006");
|
|
|
* jsonBody.put("streamType", 0);
|
|
@@ -963,13 +966,14 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
JSONObject data = outJson.getJSONObject("data");
|
|
|
String urls = data.getString("url");
|
|
|
return urls;
|
|
|
- }else {
|
|
|
+ } else {
|
|
|
return "1";
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* web页面实时流调用的远程天网接口
|
|
|
+ *
|
|
|
* @param camerasVo
|
|
|
* @param channel
|
|
|
*/
|
|
@@ -1000,15 +1004,16 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
/**
|
|
|
* 报警回放本地测试
|
|
|
* 从天网拉回放流,然后根据url把流下载下来变成文件,然后进行视频压缩
|
|
|
+ *
|
|
|
* @param list
|
|
|
* @param alarmPlayTimeValue
|
|
|
*/
|
|
|
public void playbackURLs(List<String> list, String alarmPlayTimeValue) {
|
|
|
log.info("--------------->playbackURLs");
|
|
|
- CompletableFuture future = CompletableFuture.supplyAsync(() -> {
|
|
|
+ String code = "42010001541320000024";
|
|
|
+ CompletableFuture<Void> recordFuture = CompletableFuture.runAsync(() -> {
|
|
|
log.info("异步任务开始-----》");
|
|
|
// for (String code : list) {
|
|
|
- String code="42010001541320000024";
|
|
|
PlaybackVo playbackVo = new PlaybackVo();
|
|
|
playbackVo.setCameraIndexCode(code);
|
|
|
// 获取当前时间
|
|
@@ -1039,18 +1044,22 @@ ffmpeg -i "concat:1.ts|2.ts" -c copy output.mp4
|
|
|
// String urls = data.getString("url");
|
|
|
// log.info("--------------->urls::" + urls);
|
|
|
|
|
|
- String FilePath = "/opt/streams/map/"+code+".mp4";
|
|
|
+ String FilePath = "/opt/streams/map/" + code + ".mp4";
|
|
|
// String FilePath = "/opt/streams/map/01ea43e6676f4e47bd6c5cd9e02aa006.mp4";
|
|
|
- Process process = rtspToMP4.StartRecord(ffmpegPath, "rtsp://124.70.58.209:8554/"+code+"/"+code, FilePath);
|
|
|
+ Process process = rtspToMP4.StartRecord(ffmpegPath, "rtsp://124.70.58.209:8554/" + code + "/" + code, FilePath);
|
|
|
log.info("------playbackURLs----->>>>:" + process);
|
|
|
if (null != process) {
|
|
|
map.put(code, process);
|
|
|
}
|
|
|
- log.info("-------videoCompression------->");
|
|
|
- videoCompression(code);
|
|
|
- return 1;
|
|
|
});
|
|
|
- future.join();
|
|
|
+ CompletableFuture<Integer> compressionFuture = recordFuture.thenCompose(result ->
|
|
|
+ CompletableFuture.supplyAsync(() -> {
|
|
|
+ log.info("-------videoCompression------->");
|
|
|
+ videoCompression(code);
|
|
|
+ return 1;
|
|
|
+ })
|
|
|
+ );
|
|
|
+ compressionFuture.join();
|
|
|
}
|
|
|
|
|
|
public AjaxResult stop(String id) {
|