API接入说明

步骤一:准备工作

1.开通阿里云 视频监控智能视觉。 2.登录智能视觉控制台,点击“授权管理”,查看“视频监控授权”,点击“去授权”。授权管理

步骤二:将监控流推/拉流至云端

用户需要首先在视频监控产品中创建空间,配置域名,添加监控设备,启动流,监控服务拉流到云端。

视频监控目前支持通过两种协议接入:
  • 通过RTMP协议进行设备推流,直接把监控设备的直播流推入到阿里云视频监控服务的接入点。

  • 通过国标GB/T28181协议进行设备拉流,拉流前需要进行设备国标注册。

接入前准备:

通过公网接入监控上云,需要您先准备好备案过的域名,详情请参见域名备案(如果使用RTMP协议接入,需准备备案过的推流和播流域名。如果使用国标协议接入,仅准备一个备案过的播流域名。)

通过阿里云管理控制台(或API接口)来完成视频监控接流的流程如下:
  1. 创建空间,进行空间配置(或使用API CreateGroup 创建空间)

  2. 配置域名并进行CNAME解析(或使用API DescribeVsDomainDetail获取CNAME解析地址,去域名产品控制台或者使用API AddDomainRecord配置域名解析)

  3. 配置URL鉴权(或通过SDK设置鉴权KEY和过期时间,得到鉴权URL地址)

  4. 添加国标设备,进行设备国标注册,成功后即可启动拉流(或使用API CreateDevice添加设备)

注:如果是国标协议接入,需要在摄像头或网络存储平台或视频管理平台进行设备国标注册,详细流程见设备国标注册。如果是RTMP协议接入,此时可直接使用推流的鉴权URL开始推流。

步骤三:开启智能视觉AI分析

系统模型ID:

  • 亮度异常:模型ID fb54025257b64461875aa9d7cc7e393f

  • 色度异常:模型ID cc8e32c4f2314a6ea77feb0b8b333ef0

  • 画面模糊:模型ID c0682d73aadb4db08028aae4adbcebe9

  • 摄像头遮挡:模型ID 8557e76bddae45f99e36dd179f7a2057

  • 花屏:模型ID aa799c31015941a38347731c894db265

回调内容

  • result表示检测结果:normal/dark/bright/bias/occlusion/blockness/blur

  • type表示检测类型:brightness/blur/colorBias/occlusion/blockness

  • score量化数值:不同算法score值意义不同,用户不需关心。

流程说明:

调用智能视觉API接口创建流预测并输入被预测流ID、模型ID以及MNS队列名称信息,启动流预测,从监控服务拉流进行预测处理,并将预测结果回调到用户指定的MNS队列。

  • 调用视频监控服务API: DescribeStream接口返回PlayDomain, App, Name三元组,按规则拼接产生streamId:rtmp://PlayDomain/App/Name

  • 调用智能视觉服务API:CreateStreamPredict接口,创建流预测任务:

CreateStreamPredictRequest request = new CreateStreamPredictRequest();
// 从视频监控服务DescribeStream接口获得拼接产生的 streamId
request.setStreamId(streamId);
// 直播类型,Live
request.setStreamType("Live");
// 输入明厨亮灶系统模型ID
request.setModelIds(modelId);
// 创建流预测时,是否自动开始预测,这里演示手动开始模式。
request.setAutoStart("false");
// 流预测时,保存结果有问题的地址前缀。
request.setOutput("http://ivison-test.oss-cn-beijing.aliyuncs.com/ivision-test/");
// 配置消息通知,当前只支持MNS队列。
JSONObject notify = new JSONObject();
notify.put("MNSQueue", "ivison-test-queue");
request.setNotify(notify.toJSONString());
CreateStreamPredictResponse response = vars.getClient().getAcsResponse(request);
String predictId = response.getPredictId();
  • 调用智能视觉API:StartStreamPredict接口,开启流预测:

StartStreamPredictRequest request = new StartStreamPredictRequest();
// 创建流预测时,返回的预测ID。
request.setPredictId(predictId);
StartStreamPredictResponse response = vars.getClient().getAcsResponse(request);
  • 接收流预测结果消息,具体的消息格式如下:

{
  "predictDatas": [
    {
      "dataUrl": "http://xxx/1.jpg", // 图片地址
      "modelId": "xxxx", // 模型ID
      "predictId": "xxx", // 预测任务ID
      "timestamp": 11111, // 流时间戳
      "predictTime": "2019-05-14T10:10:10:001Z", // 进行预测的UTC时间
      "status": "success", // 预测结果,success,fail
      //预测结果
      "predictResult": "{\"colorBias\": {\"result\": \"normal\", \"score\": -3.2410464286804199, \"type\": \"colorBias\"}}"
    }
  ]
}
说明

predictResult是一个JSON字符串:

{
    "colorBias": {
        "result": "normal",
        "score": -3.24104642868042,
        "type": "colorBias"
    }
}
// 收到的消息,转换为列表
JSONArray resultArray = JSONObject.parseArray(message.getMessageBodyAsString());
  • 调用智能视觉API:StopStreamPredict 接口停止流预测任务

StopStreamPredictRequest request = new StopStreamPredictRequest();
request.setPredictId(predictId);
StopStreamPredictResponse response = vars.getClient().getAcsResponse(request);
  • 调用智能视觉API: DeleteStreamPredict 删除流预测任务

DeleteStreamPredictRequest request = new DeleteStreamPredictRequest();
request.setPredictId(predictId);
DeleteStreamPredictResponse response = vars.getClient().getAcsResponse(request);
  • 调用智能视觉API:DescribeStreamPredicts 查询流预测任务列表

DescribeStreamPredictsRequest request = new DescribeStreamPredictsRequest();
request.setPredictIds(predictId);
DescribeStreamPredictsResponse response = vars.getClient().getAcsResponse(request);
List<DescribeStreamPredictsResponse.StreamPredict> streamPredicts = response.getStreamPredicts();
for (DescribeStreamPredictsResponse.StreamPredict streamPredict : streamPredicts) {
    System.out.println(JSON.toJSONString(streamPredict));
}