java对接海康威视摄像头

@Service
@Slf4j
public class HikVisionServiceImp {

    private String secret;


    @Resource
    ServiceBin serviceBin;

    @Value("${media.zlmediakit_domain}")
    String domain;



    /***
     *                  /ISAPI/Streaming/Channels/101
     * @param ip
     * @param port
     * @param account
     * @param password
     * @param deviceType
     * @param channel
     * @param isMasterStream  是否是主码流-高清(反之为模糊画质,但不是所有设备都支持模糊画质)
     * @return
     */


    public LiveCreateResponse createLive(String ip, String port, String account, String password, String deviceType, Integer channel, boolean isMasterStream) {
        String rtsp = "rtsp://";
        // app 和 stream 都是任意指定的名字,用于区分不同摄像头的直播
        String app = ip.replaceAll("\\.", "");
        String stream = port;


        if (!StringUtils.isEmpty(account) && !StringUtils.isEmpty(password)) {
            rtsp += account + ":" + password + "@";
        }

        if (StringUtils.isEmpty(ip)) {
            return LiveCreateResponse.wrong("无效 ip");
        } else {
            rtsp += ip;
        }
        if (!StringUtils.isEmpty(port)) {
            rtsp += ":" + port;
        }
        if (deviceType.equals(MediaSourceType.NVR)) {
            stream += channel;
            rtsp += "/ISAPI/Streaming/Channels/" + channel
            + (isMasterStream ? "01" : "02");
        }

        log.info("rtsp=======" + rtsp );

        String result1 = serviceBin.getZlMediaKitFeign().addStreamProxy(app, stream, rtsp, "1");
        log.info(result1);
        LiveCreateResponse result = JSONObject.parseObject(result1, LiveCreateResponse.class);

        if (result.getCode() == 0) {
            String uri = domain + "/" + app + "/" + stream;
            result.setHls("http://" + uri + "/hls.m3u8");
            result.setHttpFlv("http://" + uri + ".flv");
            result.setWsFlv("ws://" + uri + ".flv");
        }
        return result;
    }

 上面是通过fegin远程调用流媒体服务器进行创建直播流  rtsp地址格式

@FeignClient(name = "zlmediakit", url = "${media.zlmediakit_domain}", configuration = {ZLMediaKitFeignClientInterceptor.class}, contextId = "mediaKitFeign")
public interface ZLMediaKitFeign {

    @GetMapping("/index/api/addStreamProxy")
    String addStreamProxy(@RequestParam(value = "app") String app,
                                      @RequestParam(value = "stream") String stream,
                                      @RequestParam(value = "url") String url,
                                      @RequestParam(value = "enable_hls") String enable_hls);
}
media:
  ##要带端口号
  zlmediakit_domain: 自己的流媒体服务器地址
  zlmediakit_secret: 自己的密钥
  defaultVhost: __defaultVhost__

### 海康威视摄像头 Java SDK 对接 示例代码 使用教程 #### 准备工作 为了使用海康威视摄像头Java SDK,需完成如下准备工作: - 下载并安装Java开发环境以及海康威视Java SDK[^1]。 #### 导入库文件 确保已正确安装必要库文件,并将其加入项目中。主要涉及的是海康威视SDK和OpenCV库[^3]。 #### 初始化与登录 初始化海康威视SDK并通过`NET_DVR_Login()`函数登录至目标摄像机设备。 ```java // 初始化SDK if (!HCNetSDK.getInstance().NET_DVR_Init()) { System.out.println("Initialize failed"); } // 登录设备 int userId = HCNetSDK.getInstance().NET_DVR_Login(strIpAddr, nPort, strUserid, strPassword); if (userId < 0) { System.out.println("Login failed"); } ``` #### 实时预览视频流 通过调用`NET_DVR_RealPlay_V30()`启动实时预览功能。 ```java HCNetSDK.NET_DVR_PREVIEWINFO previewInfo = new HCNetSDK.NET_DVR_PREVIEWINFO(); previewInfo.lChannel = channel; previewInfo.dwStreamType = streamType; int playHandle = HCNetSDK.getInstance().NET_DVR_RealPlay_V30(userId, previewInfo, null); if (playHandle < 0) { System.out.println("Real Play Failed"); } else { // 成功开启实时播放窗口... } ``` #### 抓取图片 利用`NET_DVR_CaptureJPEGPicture()`来捕获当前画面作为JPEG格式的照片保存下来。 ```java String filePath = "path/to/save/image.jpg"; boolean result = HCNetSDK.getInstance().NET_DVR_CaptureJPEGPicture(userId, startChan, strJpeg, filePath); if(result){ System.out.println("Capture Success!"); }else{ System.out.println("Capture Fail..."); } ``` 需要注意的是,在实际操作过程中可能遇到不同情况下的错误提示,这时可以适当调整参数设置以适应具体的网络状况和其他因素的影响[^5]。
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值