使用FFmpeg将多幅图像压缩为H264视频流

使用FFmpeg是进行视频或图像处理开发的利器,如何将多幅图像压缩成H264视频流是本文讨论的内容。FFmpeg配置请参照http://blog.csdn.net/wootengxjj/article/details/51758621。

本文参考了文章http://blog.csdn.net/weixinhum/article/details/37705253中的内容,根据FFmpeg的版本对其中的压缩类进行修改。

主函数的代码如下:

int _tmain(int argc, _TCHAR* argv[])
{
	MyEncoder myencoder;
	myencoder.Ffmpeg_Encoder_Init();//初始化编码器  
	myencoder.Ffmpeg_Encoder_Setpara(AV_CODEC_ID_H264, 800, 600);//设置编码器参数  

	//图象编码  
	FILE *f = NULL;
	char * filename = "myData.h264";
	fopen_s(&f, filename, "wb");//打开文件存储编码完成数据  

	IplImage* img = NULL;//OpenCV图像数据结构指针    
	IplImage* resizeimg = NULL;//尺寸  
	int picturecount = 1;
	while (picturecount != 9)
	{
		/**此部分用的是OpenCV读入图像对象并取得图像的数据区,也可以用别的方法获得图像数据区**/
		char chpicname[100];
		sprintf(chpicname, "FishEye%d.jpg", picturecount);//获得图片路径  
		//sprintf(chpicname, "1.jpg", picturecount);//获得图片路径  
		img = cvLoadImage(chpicname, 1);//打开图像  
		//由于OpenCV图像数据区是以BGR排列的,所以要将其数据转换为正常的RGB排列才能做进一步的压缩,不然压出来的视频颜色会不正确  
		uchar* data = (uchar*)(img->imageData);
		uchar mid = 0;
		for (int row = 0; row < img->height; row++)
		for (int cols = 0; cols < img->width; cols++)
		{
			mid = data[row*img->widthStep / sizeof(uchar)+cols*img->nChannels + 0];//G     
			data[row*img->widthStep / sizeof(uchar)+cols*img->nChannels + 0] = data[row*img->widthStep / sizeof(uchar)+cols*img->nChannels + 2];
			data[row*img->widthStep / sizeof(uchar)+cols*img->nChannels + 2] = mid;
		}
		resizeimg = cvCreateImage(cvSize(800, 600), 8, 3);
		cvResize(img, resizeimg, CV_INTER_LINEAR);//调整图像大小  
		/**此部分用的是OpenCV读入图像对象并取得图像的数据区,也可以用别的方法获得图像数据区**/

		myencoder.Ffmpeg_Encoder_Encode(f, (uchar*)resizeimg->imageData);//编码  

		cvReleaseImage(&img);//释放图像数据结构指针对像所指内容   
		cvReleaseImage(&resizeimg);
		picturecount++;
	}
	fclose(f);
	myencoder.Ffmpeg_Encoder_Close();
	return 0;
}

代码工程文件(2013): http://download.csdn.net/detail/wootengxjj/9559381。


你可能感兴趣的:(FFmpeg,FFmpeg,h264,压缩,多幅图像)