YUF420P到JPEG由ffmpeg

时间:2012-04-10 15:43:25

标签: c++ ffmpeg jpeg yuv

我的任务: 通过ffmpeg将YUV帧数据转换为jpeg图像。 是)我有的: 每个平面的数据和每个平面的线条大小;

我尝试使用此信息创建空AVFrame并填充其数据和线条化,但在使用CODEC_ID_MJPEG编解码器对图像进行编码并将其保存到文件后,还没有获得正确的jpeg。

获取图像需要做些什么?

2 个答案:

答案 0 :(得分:0)

也许你应该使用jpeglib来做到这一点。这是我的代码

FILE *outfile = fopen(path, "wb+");

if (!outfile)
    return 1;
h &= ~15;

struct jpeg_compress_struct cinfo;
struct jpeg_error_mgr jerr;

cinfo.err = jpeg_std_error(&jerr);
jpeg_create_compress(&cinfo);
jpeg_stdio_dest(&cinfo, outfile);

cinfo.image_width = w; 
cinfo.image_height = h;
cinfo.input_components = 3;        
cinfo.in_color_space = JCS_YCbCr;

jpeg_set_defaults(&cinfo);
jpeg_set_quality(&cinfo, 90, TRUE);
cinfo.dct_method = JDCT_FASTEST; 

cinfo.raw_data_in = TRUE;
cinfo.comp_info[0].h_samp_factor = 2; 
cinfo.comp_info[0].v_samp_factor = 2; 
cinfo.comp_info[1].h_samp_factor = 1; 
cinfo.comp_info[1].v_samp_factor = 1; 
cinfo.comp_info[2].h_samp_factor = 1; 
cinfo.comp_info[2].v_samp_factor = 1; 

int i, j;
JSAMPROW y[16], cb[16], cr[16];
JSAMPARRAY p[3];

jpeg_start_compress(&cinfo, TRUE);
p[0] = y;
p[2] = cb;
p[1] = cr;

for (j = 0; j < cinfo.image_height; j += 16) {
    for (i = 0; i < 16; i++) {
        y[i] = data[0] + line[0]*(i+j);
        cr[i/2] = data[1] + line[1]*((i+j)/2);
        cb[i/2] = data[2] + line[2]*((i+j)/2);
    }
    jpeg_write_raw_data(&cinfo, p, 16);
}

jpeg_finish_compress(&cinfo);
fclose(outfile);
jpeg_destroy_compress(&cinfo);

其中data是YUV平面数据,line是线条大小。

答案 1 :(得分:-1)

您需要使用`libswscale缩放图像以获取正确的JPEG文件。我的一个answer可以帮助你解决这个问题。选择适当的 PIXEL FORMAT