视频编码技术——Linux下ffmpeg编程实现摄像头捕捉

Posted 赵新政

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了视频编码技术——Linux下ffmpeg编程实现摄像头捕捉相关的知识,希望对你有一定的参考价值。

1 打开设备

对于FFMpeg编程,首先要打开相关设备,这里我们打开的是linux下的webCam,也就是笔记本摄像头 。在Linux下的ffmpeg里面,需要梳理两个东西:

a  Video4linux2(简称V4L2),是linux中关于视频设备的内核驱动

b  /dev/video0  /dev/video1 都是代表目标录制设备

其中帧率跟图像大小都是需要进行设置的,然后按照如下代码进行设备打开。

static AVFormatContext* open_dev() {
	//注册所有设备
	avdevice_register_all();
	//获得格式
	const AVInputFormat* iformat = av_find_input_format("video4linux2");

	//打开设备
	AVFormatContext* fmt_ctx = NULL;
	//const char* device_name = "hw:0,0";//这个是音频
	const char* device_name = "/dev/video0";
	AVDictionary* options = NULL;

	//视频就需要做options了
	av_dict_set(&options, "video_size", "640*480", 0);
	av_dict_set(&options, "framerate", "30", 0);

	int ret = avformat_open_input(&fmt_ctx, device_name, iformat, &options);
	
	//判断是否成功
	char errors[1024] = {0, };
	if(ret < 0) {
		av_strerror(ret, errors, 1024);
		std::cout << "Faile to open Device : " <<errors<<std::endl;
		return NULL;
	}
	std::cout<<"Success open Device"<<std::endl;
	return fmt_ctx;
}

2 进行录制保存

其中注意,在linux下直接用pkt的size是可以的。但是在很多系统上,比如mac,pkt的size会有些许变动,每个平台的实现都有不同,所以在遇到很多问题的时候,需要自己注意这点,可以用计算的每一帧数据大小代替

 

void record_video(AVFormatContext* fmt_ctx) {
int ret = -1;
	//准备好文件
	FILE* out_file = fopen("video.yuv", "wb+");
	//读取数据
	AVPacket pkt;
	int count = 0;
	av_init_packet(&pkt);
	while((ret = av_read_frame(fmt_ctx, &pkt)) == 0) {
		
		std::cout<<pkt.size<<std::endl;
		av_log(NULL, AV_LOG_INFO, "packet size is %d(%p), count = %d\\n", 
				pkt.size, pkt.data, count);
		//写入文件
		fwrite(pkt.data, pkt.size, 1, out_file);
		//将文件缓冲区当中数据直接刷进去
		fflush(out_file);
		//每一次读取都会生成空间,所以需要release
		av_packet_unref(&pkt);
		if(count++ > 8000) {
			break;
		}
	}
	
	fclose(out_file);
}

 

以上是关于视频编码技术——Linux下ffmpeg编程实现摄像头捕捉的主要内容,如果未能解决你的问题,请参考以下文章

视频编码技术——Linux下ffmpeg编程实现摄像头捕捉

Linux系统安装ffmpeg + h264视频编码

Android平台FFmpeg实现rtmp推流-C++的实现

Qt之FFMpeg 实现视频解码编码转码流程详解

视频转码:linux下ffmpeg 实现视频转码

ffmpeg中怎么编程实现获取视频中某指定的一帧