From edb033ccd7df53e2444f38c9657946ce15856153 Mon Sep 17 00:00:00 2001 From: panlinlin <648540858@qq.com> Date: 星期五, 26 三月 2021 18:32:36 +0800 Subject: [PATCH] 添加获取直播流的api --- src/main/java/com/genersoft/iot/vmp/storager/impl/RedisCatchStorageImpl.java | 31 ++++++++++++++++++++++++++++--- 1 files changed, 28 insertions(+), 3 deletions(-) diff --git a/src/main/java/com/genersoft/iot/vmp/storager/impl/RedisCatchStorageImpl.java b/src/main/java/com/genersoft/iot/vmp/storager/impl/RedisCatchStorageImpl.java index 3feb347..c5e31d6 100644 --- a/src/main/java/com/genersoft/iot/vmp/storager/impl/RedisCatchStorageImpl.java +++ b/src/main/java/com/genersoft/iot/vmp/storager/impl/RedisCatchStorageImpl.java @@ -1,5 +1,6 @@ package com.genersoft.iot.vmp.storager.impl; +import com.genersoft.iot.vmp.common.RealVideo; import com.genersoft.iot.vmp.common.StreamInfo; import com.genersoft.iot.vmp.common.VideoManagerConstants; import com.genersoft.iot.vmp.conf.MediaServerConfig; @@ -10,9 +11,7 @@ import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; -import java.util.HashMap; -import java.util.List; -import java.util.Map; +import java.util.*; @Component public class RedisCatchStorageImpl implements IRedisCatchStorage { @@ -251,4 +250,30 @@ } } + + /** + * 鏇存柊濯掍綋娴佸垪琛� + * @param mediaList + */ + @Override + public void updateMediaList(List<RealVideo> mediaList) { + String key = VideoManagerConstants.MEDIA_STREAM_PREFIX; + redis.del(key); + for (int i = 0; i < mediaList.size(); i++) { + RealVideo realVideo = mediaList.get(i); + redis.zAdd(key, realVideo, realVideo.getCreateStamp()); + } + } + + + /** + * 鑾峰彇褰撳墠濯掍綋娴佸垪琛� + * @return List<RealVideo> + */ + @Override + public List<Object> getMediaList(int start, int end) { + String key = VideoManagerConstants.MEDIA_STREAM_PREFIX; + Set<Object> realVideos = redis.ZRange(key, start, end); + return new ArrayList(realVideos); + } } -- Gitblit v1.8.0