Commit bf61fa48 authored by Laurent Aimar's avatar Laurent Aimar

* all: - fixed non I420 input

        - added raw output support.(in a pure hack way but allow
        transcode{vcodec=I420} )
parent e16a703c
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* encoder.c: video and audio encoder using the ffmpeg library * encoder.c: video and audio encoder using the ffmpeg library
***************************************************************************** *****************************************************************************
* Copyright (C) 1999-2001 VideoLAN * Copyright (C) 1999-2001 VideoLAN
* $Id: encoder.c,v 1.14 2003/11/29 12:03:08 fenrir Exp $ * $Id: encoder.c,v 1.15 2003/11/29 13:12:11 fenrir Exp $
* *
* Authors: Laurent Aimar <fenrir@via.ecp.fr> * Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Gildas Bazin <gbazin@netcourrier.com> * Gildas Bazin <gbazin@netcourrier.com>
...@@ -98,8 +98,16 @@ int E_(OpenEncoder)( vlc_object_t *p_this ) ...@@ -98,8 +98,16 @@ int E_(OpenEncoder)( vlc_object_t *p_this )
if( !E_(GetFfmpegCodec)( p_enc->fmt_out.i_codec, &i_cat, &i_codec_id, if( !E_(GetFfmpegCodec)( p_enc->fmt_out.i_codec, &i_cat, &i_codec_id,
&psz_namecodec ) ) &psz_namecodec ) )
{ {
if( E_(GetFfmpegChroma)( p_enc->fmt_out.i_codec ) < 0 )
{
/* handed chroma output */
return VLC_EGENERIC; return VLC_EGENERIC;
} }
i_cat = VIDEO_ES;
i_codec_id = CODEC_ID_RAWVIDEO;
psz_namecodec = "Raw video";
}
if( p_enc->fmt_out.i_cat == VIDEO_ES && i_cat != VIDEO_ES ) if( p_enc->fmt_out.i_cat == VIDEO_ES && i_cat != VIDEO_ES )
{ {
...@@ -186,8 +194,7 @@ int E_(OpenEncoder)( vlc_object_t *p_this ) ...@@ -186,8 +194,7 @@ int E_(OpenEncoder)( vlc_object_t *p_this )
p_sys->p_buffer_out = malloc( AVCODEC_MAX_VIDEO_FRAME_SIZE ); p_sys->p_buffer_out = malloc( AVCODEC_MAX_VIDEO_FRAME_SIZE );
/* Ffmpeg does handle the conversion itself */ p_enc->fmt_in.i_codec = VLC_FOURCC('I','4','2','0');
//p_enc->fmt_in.i_codec = VLC_FOURCC('I','4','2','0');
if ( p_enc->b_strict_rc ) if ( p_enc->b_strict_rc )
{ {
...@@ -238,6 +245,8 @@ int E_(OpenEncoder)( vlc_object_t *p_this ) ...@@ -238,6 +245,8 @@ int E_(OpenEncoder)( vlc_object_t *p_this )
if( i_codec_id == CODEC_ID_RAWVIDEO ) if( i_codec_id == CODEC_ID_RAWVIDEO )
{ {
/* XXX: hack: Force same codec (will be handled by transcode) */
p_enc->fmt_in.i_codec = p_enc->fmt_out.i_codec;
p_context->pix_fmt = E_(GetFfmpegChroma)( p_enc->fmt_in.i_codec ); p_context->pix_fmt = E_(GetFfmpegChroma)( p_enc->fmt_in.i_codec );
} }
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* ffmpeg.c: video decoder using ffmpeg library * ffmpeg.c: video decoder using ffmpeg library
***************************************************************************** *****************************************************************************
* Copyright (C) 1999-2001 VideoLAN * Copyright (C) 1999-2001 VideoLAN
* $Id: ffmpeg.c,v 1.63 2003/11/28 23:40:09 gbazin Exp $ * $Id: ffmpeg.c,v 1.64 2003/11/29 13:12:11 fenrir Exp $
* *
* Authors: Laurent Aimar <fenrir@via.ecp.fr> * Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Gildas Bazin <gbazin@netcourrier.com> * Gildas Bazin <gbazin@netcourrier.com>
...@@ -673,7 +673,7 @@ int E_(GetFfmpegChroma)( vlc_fourcc_t i_chroma ) ...@@ -673,7 +673,7 @@ int E_(GetFfmpegChroma)( vlc_fourcc_t i_chroma )
case VLC_FOURCC( 'Y', 'U', 'Y', '2' ): case VLC_FOURCC( 'Y', 'U', 'Y', '2' ):
return PIX_FMT_YUV422; return PIX_FMT_YUV422;
default: default:
return 0; return -1;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment