* Implemented calculating the correct display aspect ratio.
* Removed some dead code. * Fixed a style violation. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@31479 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
f9aac21f11
commit
0f3f344fb4
@ -256,12 +256,6 @@ AVFormatReader::StreamCookie::Init(int32 virtualIndex)
|
||||
|
||||
// Get a pointer to the AVCodecContext for the stream at streamIndex.
|
||||
AVCodecContext* codecContext = fStream->codec;
|
||||
// NOTE: Experimenting with opening the AVCodec to see if I get more
|
||||
// AVCodecContext fields filled out. Doesn't seem to make a difference
|
||||
// for extradata for example.
|
||||
// AVCodec* codec = avcodec_find_decoder(codecContext->codec_id);
|
||||
// bool codecOpened = avcodec_open(codecContext, codec) == 0;
|
||||
// TRACE(" codec opened: %d\n", codecOpened);
|
||||
AVStream* stream = fStream;
|
||||
|
||||
// initialize the media_format for this stream
|
||||
@ -352,7 +346,8 @@ AVFormatReader::StreamCookie::Init(int32 virtualIndex)
|
||||
// codecTag = 0x2000;
|
||||
// break;
|
||||
default:
|
||||
fprintf(stderr, "ffmpeg codecTag is null, codec_id unknown 0x%lx\n", codecContext->codec_id);
|
||||
fprintf(stderr, "ffmpeg codecTag is null, codec_id "
|
||||
"unknown 0x%x\n", codecContext->codec_id);
|
||||
// TODO: Add more...
|
||||
break;
|
||||
}
|
||||
@ -475,16 +470,33 @@ AVFormatReader::StreamCookie::Init(int32 virtualIndex)
|
||||
format->u.encoded_video.output.orientation
|
||||
= B_VIDEO_TOP_LEFT_RIGHT;
|
||||
|
||||
// TODO: Implement aspect ratio for real
|
||||
// Calculate the display aspect ratio
|
||||
AVRational displayAspectRatio;
|
||||
if (codecContext->sample_aspect_ratio.num != 0) {
|
||||
// TODO: Maybe it would be more useful to change the meaning
|
||||
// of pixel_width/height_aspect to mean the pixel width
|
||||
// scale...
|
||||
av_reduce(&displayAspectRatio.num, &displayAspectRatio.den,
|
||||
codecContext->width
|
||||
* codecContext->sample_aspect_ratio.num,
|
||||
codecContext->height
|
||||
* codecContext->sample_aspect_ratio.den,
|
||||
1024 * 1024);
|
||||
TRACE(" pixel aspect ratio: %d/%d, "
|
||||
"display aspect ratio: %d/%d\n",
|
||||
codecContext->sample_aspect_ratio.num,
|
||||
codecContext->sample_aspect_ratio.den,
|
||||
displayAspectRatio.num, displayAspectRatio.den);
|
||||
} else {
|
||||
av_reduce(&displayAspectRatio.num, &displayAspectRatio.den,
|
||||
codecContext->width, codecContext->height, 1024 * 1024);
|
||||
TRACE(" no display aspect ratio (%d/%d)\n",
|
||||
displayAspectRatio.num, displayAspectRatio.den);
|
||||
}
|
||||
format->u.encoded_video.output.pixel_width_aspect
|
||||
= 1;//stream->sample_aspect_ratio.num;
|
||||
= displayAspectRatio.num;
|
||||
format->u.encoded_video.output.pixel_height_aspect
|
||||
= 1;//stream->sample_aspect_ratio.den;
|
||||
|
||||
TRACE(" pixel width/height aspect: %d/%d or %.4f\n",
|
||||
stream->sample_aspect_ratio.num,
|
||||
stream->sample_aspect_ratio.den,
|
||||
av_q2d(stream->sample_aspect_ratio));
|
||||
= displayAspectRatio.den;
|
||||
|
||||
format->u.encoded_video.output.display.format
|
||||
= pixfmt_to_colorspace(codecContext->pix_fmt);
|
||||
@ -516,9 +528,6 @@ AVFormatReader::StreamCookie::Init(int32 virtualIndex)
|
||||
TRACE(" get_buffer(): %p\n", codecContext->get_buffer);
|
||||
TRACE(" release_buffer(): %p\n", codecContext->release_buffer);
|
||||
|
||||
// if (codecOpened)
|
||||
// avcodec_close(codecContext);
|
||||
|
||||
#ifdef TRACE_AVFORMAT_READER
|
||||
char formatString[512];
|
||||
if (string_for_format(*format, formatString, sizeof(formatString)))
|
||||
|
Loading…
Reference in New Issue
Block a user