Properly report video track information.

Moved infromation gathering into AllocateCookie.
Report proper data in GetNextChunk media_header.


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@6421 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
beveloper 2004-01-29 23:32:10 +00:00
parent a6423eea41
commit e9fe0b2203
4 changed files with 80 additions and 32 deletions

View File

@ -25,11 +25,17 @@ struct avi_cookie
bool audio;
int64 frame_count;
bigtime_t duration;
media_format format;
int64 byte_pos;
uint32 bytes_per_sec_rate;
uint32 bytes_per_sec_scale;
uint32 frame_pos;
uint32 usec_per_frame;
uint32 line_count;
};
@ -108,38 +114,15 @@ aviReader::AllocateCookie(int32 streamNumber, void **_cookie)
cookie->buffer = 0;
cookie->buffer_size = 0;
return B_OK;
}
status_t
aviReader::FreeCookie(void *_cookie)
{
avi_cookie *cookie = (avi_cookie *)_cookie;
delete [] cookie->buffer;
delete cookie;
return B_OK;
}
status_t
aviReader::GetStreamInfo(void *_cookie, int64 *frameCount, bigtime_t *duration,
media_format *format, void **infoBuffer, int32 *infoSize)
{
avi_cookie *cookie = (avi_cookie *)_cookie;
*duration = fFile->Duration();
*infoBuffer = 0;
*infoSize = 0;
BMediaFormats formats;
media_format *format = &cookie->format;
media_format_description description;
const avi_stream_header *stream_header;
stream_header = fFile->StreamFormat(cookie->stream);
if (!stream_header) {
TRACE("aviReader::GetStreamInfo: stream %d has no header\n", cookie->stream);
delete cookie;
return B_ERROR;
}
@ -147,13 +130,16 @@ aviReader::GetStreamInfo(void *_cookie, int64 *frameCount, bigtime_t *duration,
const wave_format_ex *audio_format = fFile->AudioFormat(cookie->stream);
if (!audio_format) {
TRACE("aviReader::GetStreamInfo: audio stream %d has no format\n", cookie->stream);
delete cookie;
return B_ERROR;
}
if (audio_format->format_tag == 0x0001) // PCM
*frameCount = stream_header->length / ((stream_header->sample_size + 7) / 8);
cookie->frame_count = stream_header->length / ((stream_header->sample_size + 7) / 8);
else // not PCM
*frameCount = (stream_header->length * audio_format->frames_per_sec) / (stream_header->sample_size * audio_format->avg_bytes_per_sec);
cookie->frame_count = (stream_header->length * audio_format->frames_per_sec) / (stream_header->sample_size * audio_format->avg_bytes_per_sec);
cookie->duration = fFile->Duration();
cookie->audio = true;
cookie->byte_pos = 0;
@ -200,29 +186,75 @@ aviReader::GetStreamInfo(void *_cookie, int64 *frameCount, bigtime_t *duration,
const bitmap_info_header *video_format = fFile->VideoFormat(cookie->stream);
if (!video_format) {
TRACE("aviReader::GetStreamInfo: video stream %d has no format\n", cookie->stream);
delete cookie;
return B_ERROR;
}
*frameCount = fFile->FrameCount();
*duration = fFile->Duration();
cookie->frame_count = fFile->FrameCount();
cookie->duration = fFile->Duration();
cookie->audio = false;
cookie->frame_pos = 0;
cookie->usec_per_frame = fFile->AviMainHeader()->micro_sec_per_frame;
cookie->line_count = fFile->AviMainHeader()->height;
description.family = B_AVI_FORMAT_FAMILY;
description.u.avi.codec = 0;
description.u.avi.codec = stream_header->fourcc_handler;
if (B_OK != formats.GetFormatFor(description, format))
format->type = B_MEDIA_ENCODED_VIDEO;
format->user_data_type = B_CODEC_TYPE_INFO;
strncpy((char*)format->user_data, "DivX", 4);
*(uint32 *)format->user_data = stream_header->fourcc_handler; format->user_data[4] = 0;
format->u.encoded_video.output.field_rate = 1000000.0 / cookie->usec_per_frame;
format->u.encoded_video.output.interlace = 1; // 1: progressive
format->u.encoded_video.output.first_active = 0;
format->u.encoded_video.output.last_active = cookie->line_count - 1;
format->u.encoded_video.output.orientation = B_VIDEO_TOP_LEFT_RIGHT;
format->u.encoded_video.output.pixel_width_aspect = 1;
format->u.encoded_video.output.pixel_height_aspect = 1;
// format->u.encoded_video.output.display.format = 0;
format->u.encoded_video.output.display.line_width = fFile->AviMainHeader()->width;
format->u.encoded_video.output.display.line_count = cookie->line_count;
format->u.encoded_video.output.display.bytes_per_row = 0; // format->u.encoded_video.output.display.line_width * 4;
format->u.encoded_video.output.display.pixel_offset = 0;
format->u.encoded_video.output.display.line_offset = 0;
format->u.encoded_video.output.display.flags = 0;
return B_OK;
}
delete cookie;
return B_ERROR;
}
status_t
aviReader::FreeCookie(void *_cookie)
{
avi_cookie *cookie = (avi_cookie *)_cookie;
delete [] cookie->buffer;
delete cookie;
return B_OK;
}
status_t
aviReader::GetStreamInfo(void *_cookie, int64 *frameCount, bigtime_t *duration,
media_format *format, void **infoBuffer, int32 *infoSize)
{
avi_cookie *cookie = (avi_cookie *)_cookie;
*frameCount = cookie->frame_count;
*duration = cookie->duration;
*format = cookie->format;
*infoBuffer = 0;
*infoSize = 0;
return B_OK;
}
status_t
aviReader::Seek(void *cookie,
uint32 seekTo,
@ -252,9 +284,17 @@ aviReader::GetNextChunk(void *_cookie,
if (cookie->audio) {
mediaHeader->start_time = (cookie->byte_pos * 1000000ULL * cookie->bytes_per_sec_scale) / cookie->bytes_per_sec_rate;
mediaHeader->type = B_MEDIA_ENCODED_AUDIO;
mediaHeader->u.encoded_audio.buffer_flags = keyframe ? B_MEDIA_KEY_FRAME : 0;
cookie->byte_pos += size;
} else {
mediaHeader->start_time = cookie->frame_pos * cookie->usec_per_frame;
mediaHeader->type = B_MEDIA_ENCODED_VIDEO;
mediaHeader->u.encoded_video.field_flags = keyframe ? B_MEDIA_KEY_FRAME : 0;
mediaHeader->u.encoded_video.first_active_line = 0;
mediaHeader->u.encoded_video.line_count = cookie->line_count;
cookie->frame_pos += 1;
}

View File

@ -387,6 +387,12 @@ OpenDMLFile::IsAudio(int stream_index)
return fStreamData[stream_index].info->is_audio;
}
const avi_main_header *
OpenDMLFile::AviMainHeader()
{
return fParser->AviMainHeader();
}
const wave_format_ex *
OpenDMLFile::AudioFormat(int stream_index)
{

View File

@ -19,6 +19,8 @@ public:
bool IsVideo(int stream_index);
bool IsAudio(int stream_index);
const avi_main_header *AviMainHeader();
const wave_format_ex * AudioFormat(int stream_index);
const bitmap_info_header * VideoFormat(int stream_index);
const avi_stream_header * StreamFormat(int stream_index);

View File

@ -481,7 +481,7 @@ OpenDMLParser::ParseChunk_strf(uint64 start, uint32 size)
fCurrentStream->video_format_valid = true;
TRACE("audio_format:\n");
TRACE("video_format:\n");
TRACE("size = %lu\n", fCurrentStream->video_format.size);
TRACE("width = %lu\n", fCurrentStream->video_format.width);
TRACE("height = %lu\n", fCurrentStream->video_format.height);