Android平台GB28181设备接入端实现实时快照

简介: Android平台GB28181设计开发的时候,有个功能必不可少的:实时快照,特别是用于执法记录仪等场景下,用于图像留底或分析等考量。

Android平台GB28181设计开发的时候,有个功能必不可少的:实时快照,特别是用于执法记录仪等场景下,用于图像留底或分析等考量。


实时快照的实现并不难,目前实现有两种方式,一种是拿到数据(比如摄像头数据)后,直接上层编码,存取快照;另一种模式是,数据投递到JNI层,底层针对投递过来的编码前数据,做png编码,并保存到设定的目录下,今天我们主要探讨第二种实现模式。


我们在publisher实例初始化的时候,设置是否启用快照:

private void InitAndSetConfig() {
  int audio_opt = 1;
  int fps = 18;
  int gop = fps * 2;
  Log.i(TAG, "InitAndSetConfig video_width: " + video_width_ + " cur_video_height" + video_height_ + " imageRotationDegree:" + cameraImageRotationDegree_);
  publisherHandle = libPublisher.SmartPublisherOpen(context_, audio_opt, 3,  video_width_, video_height_);
  if (publisherHandle == 0) {
    Log.e(TAG, "sdk open failed!");
    return;
  }
  Log.i(TAG, "publisherHandle=" + publisherHandle);
  if(videoEncodeType == 1)  {
    int h264HWKbps = setHardwareEncoderKbps(true, video_width_, video_height_);
    h264HWKbps = h264HWKbps*fps/25;
    Log.i(TAG, "h264HWKbps: " + h264HWKbps);
    int isSupportH264HWEncoder = libPublisher
        .SetSmartPublisherVideoHWEncoder(publisherHandle, h264HWKbps);
    if (isSupportH264HWEncoder == 0) {
      libPublisher.SetNativeMediaNDK(publisherHandle, 1);
      Log.i(TAG, "Great, it supports h.264 hardware encoder!");
    }
  }
  else if (videoEncodeType == 2) {
    int hevcHWKbps = setHardwareEncoderKbps(false, video_width_, video_height_);
    hevcHWKbps = hevcHWKbps*fps/25;
    Log.i(TAG, "hevcHWKbps: " + hevcHWKbps);
    int isSupportHevcHWEncoder = libPublisher
        .SetSmartPublisherVideoHevcHWEncoder(publisherHandle, hevcHWKbps);
    if (isSupportHevcHWEncoder == 0) {
      libPublisher.SetNativeMediaNDK(publisherHandle, 1);
      Log.i(TAG, "Great, it supports hevc hardware encoder!");
    }
  }
  boolean is_sw_vbr_mode = true;
  if(is_sw_vbr_mode)  //H.264 software encoder
  {
    int is_enable_vbr = 1;
    int video_quality = CalVideoQuality(video_width_, video_height_, true);
    int vbr_max_bitrate = CalVbrMaxKBitRate(video_width_, video_height_);
    libPublisher.SmartPublisherSetSwVBRMode(publisherHandle, is_enable_vbr, video_quality, vbr_max_bitrate);
  }
  if (is_pcma_) {
    libPublisher.SmartPublisherSetAudioCodecType(publisherHandle, 3);
  } else {
    libPublisher.SmartPublisherSetAudioCodecType(publisherHandle, 1);
  }
  libPublisher.SetSmartPublisherEventCallbackV2(publisherHandle, new EventHandePublisherV2());
  libPublisher.SmartPublisherSetSWVideoEncoderProfile(publisherHandle, 3);
  libPublisher.SmartPublisherSetSWVideoEncoderSpeed(publisherHandle, 2);
  libPublisher.SmartPublisherSetGopInterval(publisherHandle, gop);
  libPublisher.SmartPublisherSetFPS(publisherHandle, fps);
  // libPublisher.SmartPublisherSetSWVideoBitRate(publisherHandle, 600, 1200);
  boolean is_noise_suppression = true;
  libPublisher.SmartPublisherSetNoiseSuppression(publisherHandle, is_noise_suppression ? 1 : 0);
  boolean is_agc = false;
  libPublisher.SmartPublisherSetAGC(publisherHandle, is_agc ? 1 : 0);
  int echo_cancel_delay = 0;
  libPublisher.SmartPublisherSetEchoCancellation(publisherHandle, 1, echo_cancel_delay);
  libPublisher.SmartPublisherSaveImageFlag(publisherHandle, 1);
}

记得留意最后一句:libPublisher.SmartPublisherSaveImageFlag(publisherHandle, 1);


相关接口说明如下:

 /**
  * Set if needs to save image during publishing stream(设置是否启用快照)
  *
  * @param is_save_image: if with 1, it will save current image via the interface of SmartPlayerSaveImage(), if with 0: does not it
  *
  * @return {0} if successful
  */
 public native int SmartPublisherSaveImageFlag(long handle,  int is_save_image);

设置后,页面有需要实时快照的数据时,点击“实时快照”按钮即可,需要注意的是,实时快照需要存储路径和保存下来的快照文件名称。具体实现如下:

class ButtonCaptureImageListener implements View.OnClickListener {
  @SuppressLint("SimpleDateFormat")
  public void onClick(View v) {
    if(isPushingRtmp || isRecording || isRTSPPublisherRunning || isGB28181StreamRunning)
    {
      String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
      String imageFileName = "dn_" + timeStamp;    //创建以时间命名的文件名称
      String imagePath = imageSavePath + "/" + imageFileName + ".png";
      Log.i(TAG, "imagePath:" + imagePath);
      libPublisher.SmartPublisherSaveCurImage(publisherHandle, imagePath);
    }
    else
    {
      Log.e(TAG, "快照失败,请确保在推送、录像、GB28181推送或内置RTSP服务发布状态..");
    }
  }
}

快照截取成功后,publisher实例会回调以下事件:

case NTSmartEventID.EVENT_DANIULIVE_ERC_PUBLISHER_CAPTURE_IMAGE:
  publisher_event = "快照: " + param1 + " 路径:" + param3;
  if (param1 == 0) {
    publisher_event = publisher_event + "截取快照成功..";
  } else {
    publisher_event = publisher_event + "截取快照失败..";
  }
  break;

由于实时快照,功能复杂度不高,而且也可以在上层实现,很容易被忽略,如果做的精细的话,还是需要开发者花费一定的心思。

相关文章
|
1月前
|
Java Android开发 Swift
安卓与iOS开发对比:平台选择对项目成功的影响
【10月更文挑战第4天】在移动应用开发的世界中,选择合适的平台是至关重要的。本文将深入探讨安卓和iOS两大主流平台的开发环境、用户基础、市场份额和开发成本等方面的差异,并分析这些差异如何影响项目的最终成果。通过比较这两个平台的优势与挑战,开发者可以更好地决定哪个平台更适合他们的项目需求。
109 1
|
2月前
|
IDE Android开发 iOS开发
探索Android与iOS开发的差异:平台选择对项目成功的影响
【9月更文挑战第27天】在移动应用开发的世界中,Android和iOS是两个主要的操作系统平台。每个系统都有其独特的开发环境、工具和用户群体。本文将深入探讨这两个平台的关键差异点,并分析这些差异如何影响应用的性能、用户体验和最终的市场表现。通过对比分析,我们将揭示选择正确的开发平台对于确保项目成功的重要作用。
|
29天前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
81 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
2月前
|
开发工具 Android开发 iOS开发
安卓与iOS开发环境对比:选择适合你的平台
【9月更文挑战第26天】在移动应用开发的广阔天地中,安卓和iOS是两大巨头。它们各自拥有独特的优势和挑战,影响着开发者的选择和决策。本文将深入探讨这两个平台的开发环境,帮助你理解它们的核心差异,并指导你根据个人或项目需求做出明智的选择。无论你是初学者还是资深开发者,了解这些平台的异同都至关重要。让我们一起探索,找到最适合你的那片开发天地。
|
2月前
|
Android开发 开发者
Android平台无纸化同屏如何实现实时录像功能
Android平台无纸化同屏,如果需要本地录像的话,实现难度不大,只要复用之前开发的录像模块的就可以,对我们来说,同屏采集这块,只是数据源不同而已,如果是自采集的其他数据,我们一样可以编码录像。
|
2月前
|
安全 API 开发工具
Android平台RTMP推送|轻量级RTSP服务如何实现麦克风|扬声器声音采集切换
Android平台扬声器播放声音的采集,在无纸化同屏等场景下,意义很大,早期低版本的Android设备,是没法直接采集扬声器audio的(从Android 10开始支持),所以,如果需要采集扬声器audio,需要先做系统版本判断,添加相应的权限。
|
2月前
|
编解码 开发工具 Android开发
Android平台实现屏幕录制(屏幕投影)|音频播放采集|麦克风采集并推送RTMP或轻量级RTSP服务
Android平台屏幕采集、音频播放声音采集、麦克风采集编码打包推送到RTMP和轻量级RTSP服务的相关技术实现,做成高稳定低延迟的同屏系统,还需要有配套好的RTMP、RTSP直播播放器
|
Android开发
Android平台设计规范整理(尺寸+组成元素+字体+滑块)
转自:http://www.ui.cn/project.php?id=12394
720 0