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

来源:互联网 发布:windows10下载不了软件 编辑:程序博客网 时间:2024/05/01 02:37

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


0 0
原创粉丝点击