使用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。