android 硬编码h264,windows 平台 ffmeg h264 硬编码

本文讲述windows 平台下ffmpeg如何利用intel media SDK 进行 h264硬编码(测试版本为3.2.2)。

ffmeg硬编编码的流程与软件编码流程相同,唯一不同的地方在初始化encoder。软件编码基本流程前文有

介绍,本文不再赘述。下面介绍硬编编码初始化encoder代码。

int InitEncoderCodec( int iWidth, int iHeight)

{

AVCodec * pH264Codec = avcodec_find_encoder_by_name("h264_qsv");

//AVCodec * pH264Codec = avcodec_find_encoder_by_name("libx264");

//AVCodec * pH264Codec = avcodec_find_encoder(AV_CODEC_ID_H264);

if(NULL == pH264Codec)

{

printf("%s", "avcodec_find_encoder failed");

return -1;

}

outPutEncContext = avcodec_alloc_context3(pH264Codec);

outPutEncContext->gop_size = 12;

//outPutEncContext->framerate = 30;

//outPutEncContext->has_b_frames = 0;

outPutEncContext->max_b_frames = 0;

//outPutEncContext = avcodec_alloc_context3(pH264Codec);

outPutEncContext->codec_id = pH264Codec->id;

outPutEncContext->time_base.num =context->streams[0]->codec->time_base.num;

outPutEncContext->time_base.den = context->streams[0]->codec->time_base.den;

outPutEncContext->pix_fmt = *pH264Codec->pix_fmts;

outPutEncContext->width = iWidth;

outPutEncContext->height = iHeight;

//outPutEncContext->bit_rate = 4* 1024 * 1024;

AVDictionary *options = nullptr;

outPutEncContext->flags |= AV_CODEC_FLAG_GLOBAL_HEADER;;

//av_dict_set(&options,"preset","ultrafast",0); //"ultrafast"s

//av_dict_set(&options,"preset","veryfast",0);

//av_opt_set(outPutEncContext->priv_data,"tune","zerolatency",0);

//av_opt_set(outPutEncContext->priv_data,"profile","baseline",0);

int ret = avcodec_open2(outPutEncContext, pH264Codec, &options);

AVQSVContext *qsv = (AVQSVContext *)outPutEncContext->hwaccel_context;

if (ret < 0)

{

printf("%s", "open codec failed");

return ret;

}

return 1;

}

硬编码与软件编码性能对比(测试机器,I7 5500)

视频复杂度低的情况下(例如编码抓取桌面视频(桌面视频无明显变化) 1080p,25fps):

软件编码所占CPU 在30% -40%之间。硬件编码所在的cpu在18-25左右

视频负载度高的情况下(例如编码抓取桌面视频(桌面播放高清影视视频) 1080p,25fps)

软件编码所占CPU 在50% -70%之间。硬件编码所在的cpu在18-25左右

场景复杂度对软编的影响非常大,对硬编的影响不明显。

如有交流请加流媒体/Ffmpeg/音视频 127903734 ,或QQ350197870。

原文:http://www.cnblogs.com/wanggang123/p/6354485.html

### 如何在Qt中使用FFmpeg进行RTSP视频流的捕获与播放 #### 使用FFmpeg命令行工具处理RTSP流 对于通过TCP协议推送RTSP流的情况,可以利用`ffmpeg`命令来完成这一操作。具体来说,可以通过如下指令实现从文件到指定服务器地址的RTSP流传输[^1]: ```bash ffmpeg -re -i input.mp4 -c copy -rtsp_transport tcp -f rtsp rtsp://127.0.0.1:8554/stream ``` 此命令中的参数解释: - `-re`: 读取输入文件时按照原速度读入。 - `-i input.mp4`: 输入源为本地MP4文件。 - `-c copy`: 不重新编码,直接复制原始数据。 - `-rtsp_transport tcp`: 设置RTSP传输方式为TCP。 - `-f rtsp`: 输出格式设置为RTSP。 #### Qt集成FFmpeg库拉取并显示RTSP流 为了实现在Qt应用程序内部调用FFmpeg功能以获取来自网络摄像机(如海康威视或大华品牌设备)的实时视频流,并将其展示给用户界面,通常会涉及到以下几个方面的工作[^3]: ##### 初始化FFmpeg环境变量 首先,在程序启动之初应当初始化全局配置项以及注册所有可用组件,这一步骤可通过下面这段C++代码片段达成目的: ```cpp #include <QApplication> extern "C" { #include <libavformat/avformat.h> } int main(int argc, char *argv[]) { QApplication a(argc, argv); av_register_all(); // 注册所有的复用器、解码器和其他必要的模块 ... } ``` ##### 构建URL字符串连接至目标摄像头 根据不同厂商提供的API文档构建相应的访问路径。例如针对海康威视产品线下的某台IP Camera,其完整的RTSP URL可能形似于下述形式之一: ```cpp QString strFileNamePre = "rtsp://admin:password@192.168.1.64/h264/ch33/main/av_stream"; // 或者如果是子码流则可能是这样 QString strSubStreamUrl = "rtsp://admin:password@192.168.1.64/h264/ch33/sub/av_stream"; ``` 而对于某些特定型号的大华科技生产的监控装置而言,则应采用另外一种模式化的表达方法去拼接最终请求链接: ```cpp QString strDahuaCameraUrl = QString("rtsp://%1:%2@%3:%4/cam/realmonitor?channel=%5&subtype=%6") .arg("username").arg("passwd").arg("camera_ip_address").arg(554).arg(1).arg(0); ``` 这里需要注意的是实际部署环境中需替换掉上述模板里的占位符部分以便能够成功建立有效的媒体资源定位标识符。 ##### 创建自定义类封装核心逻辑 考虑到跨平台兼容性和可维护性的需求,建议开发者创建专门用于管理音视频采集过程的新类别对象。此类别不仅负责打开远程位置上的多媒体容器还承担着解析帧间结构信息的任务;与此同时它也提供了简单易懂的方法接口供外界调用来控制整个工作流程的状态转换(比如暂停/恢复播放)。以下是简化版伪代码示例说明如何设计这样一个实用型辅助函数集合体: ```cpp class FFmpegPlayer : public QObject { Q_OBJECT public: explicit FFmpegPlayer(QObject* parent=nullptr); signals: void frameReady(QImage img); // 当有新图像就绪时发出信号通知GUI层更新画面 private slots: void startPlaying(); void stopPlaying(); private: AVFormatContext* m_pFormatCtx; }; ``` 在此基础上进一步完善成员属性列表和关联的操作行为即可满足大多数应用场景的要求。 ##### 实现定时回调机制刷新UI界面上的内容呈现 为了让图形化窗口始终处于最新状态反映当前正在接收的数据包所携带的画面细节变化情况,可以在主事件循环里周期性触发重绘动作从而达到流畅观看体验的效果。借助于Qt框架自带的时间调度服务——即`QTimer`单件实例的帮助很容易就能做到这一点: ```cpp void MainWindow::setupUi() { ui->setupUi(this); QTimer *timer = new QTimer(this); connect(timer,SIGNAL(timeout()),this,SLOT(updateFrame())); timer->start(33); // 每隔约33毫秒执行一次槽函数updateFrame(),对应大约每秒30帧的速度 } void MainWindow::updateFrame() { QImage currentImg; if (m_player->getLatestFrame(currentImg)) ui->videoLabel->setPixmap(QPixmap::fromImage(currentImg)); } ``` 以上就是关于怎样基于Qt开发环境下运用FFmpeg技术栈高效稳定地抓取并通过软件界面直观展现RTSP直播频道的具体实施方案概述[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值