• EasyRTMP实现内网摄像头RTSP拉流转码RTMP推流到RTMP服务器EasyRTMPAndroid视频采集流程是什么?


    背景分析

    RTMP是Real Time Messaging Protocol(实时消息传输协议)的首字母缩写,该协议基于TCP,是一个协议族,包括RTMP基本协议及RTMP/RTMPS/RTMPE等多种变种。RTMP是一种设计用来进行实时数据通信的网络下ieyi,主要用来在Flash/AIR平台和支持RTMP协议的流媒体/交互服务器之间进行音视频和数据通信。
    RTMP推流,就是将直播内容推送到服务器的过程。

    关于RTMP推流组件

    EasyRTMP是一套调用简单、功能完善、运行高效稳定的RTMP推流功能组件,经过多年客户实战和线上运行打造,支持RTMP推送断线重连、环形缓冲、智能丢帧、网络事件回调,支持Windows、Linux、ARM、Android、iOS平台,支持市面上绝大部分的RTMP流媒体服务器,能够完美应用于各种行业的直播需求,手机直播、桌面直播、摄像机直播、课堂直播等方面。结合EasyDSS流媒体服务器,为开发者提供专业、稳定的直播推流、转码、分发服务,全面满足低超低延迟、超高画质、超大并发访问量的要求。

    EasyRTMP-Android 视频采集

    解决问题

    EasyRTMP-Android推流,使用手机相机来采集视频数据:

    1、声明相机权限和相机特征权限

    <uses-feature android:name="android.hardware.camera" />
    <uses-permission android:name="android.permission.CAMERA" />
    

    2、初始化创建Camera实例对象

    mCamera = Camera.open(mCameraId);// 初始化创建Camera实例对象
    mCamera.setErrorCallback((i, camera) -> {
        throw new IllegalStateException("Camera Error:" + i);
    });
    

    3、继承SurfaceView创建预览的View并且传入上面创建的Camera对象

    try {
        // TextureView的
        SurfaceTexture holder = mSurfaceHolderRef.get();
    
        // SurfaceView传入上面创建的Camera对象
        if (holder != null) {
            mCamera.setPreviewTexture(holder);
            Log.i(TAG, "setPreviewTexture");
        }
    } catch (IOException e) {
        e.printStackTrace();
    }
    
    mCamera.startPreview();
    

    4、初始化相机设置参数

    Camera.Parameters parameters = mCamera.getParameters();
    
    //查看支持的预览尺寸
    List<Camera.Size> sizeList = parameters.getSupportedPictureSizes();
    if(sizeList.size() > 1){
        Iterator<Camera.Size> iterator = sizeList.iterator();
        while (iterator.hasNext()){
            Camera.Size size = iterator.next();
        }
    }
    //设置预览尺寸
    parameters.setPreviewSize(width, height);// 设置预览尺寸
    

    5、获取采集的视频数据

    previewCallback = (data, camera) -> {
        if (data == null)
            return;
    
        int result;
    
        if (camInfo.facing == Camera.CameraInfo.CAMERA_FACING_FRONT) {
            result = (camInfo.orientation + displayRotationDegree) % 360;
        } else {  // back-facing
            result = (camInfo.orientation - displayRotationDegree + 360) % 360;
        }
    
        if (i420_buffer == null || i420_buffer.length != data.length) {
            i420_buffer = new byte[data.length];
        }
    
        JNIUtil.ConvertToI420(data,i420_buffer,width,height,0,0,width,height,result % 360, 2);
        System.arraycopy(i420_buffer, 0, data, 0, data.length);
    
        if (mRecordVC != null) {
            mRecordVC.onVideo(i420_buffer, 0);
        }
    
        mVC.onVideo(data, 0);
        mCamera.addCallbackBuffer(data);
    };
  • 相关阅读:
    Apache Phoenix系列 | 从入门到精通(转载)
    Phoenix 简单介绍
    ES 调优查询亿级数据毫秒级返回!怎么做到的?--文件系统缓存
    Linux 文件系统缓存 -针对不同数据库有不同作用
    Hive 调优
    clickhouse 中文论坛
    从0到N建立高性价比的大数据平台(转载)
    ClickHouse 分布式高可用集群搭建(转载)
    Hive 模式设计
    Oracle 分区表中本地索引和全局索引的适用场景
  • 原文地址:https://www.cnblogs.com/TSINGSEE/p/11806089.html
Copyright © 2020-2023  润新知