[vlc-commits] commit: Used dvdnav_get_video_resolution to fix the AR of some dvd menus. ( Laurent Aimar )
git at videolan.org
git at videolan.org
Tue May 25 09:16:23 CEST 2010
vlc/vlc-1.1 | branch: master | Laurent Aimar <fenrir at videolan.org> | Mon May 24 23:55:07 2010 +0200| [5d434e61bb0f619da81430d8a512b6796f145740] | committer: Jean-Baptiste Kempf
Used dvdnav_get_video_resolution to fix the AR of some dvd menus.
(cherry picked from commit 93a85bdbb0ef55cbd491c4e9e6a4a4deb83c85da)
Signed-off-by: Jean-Baptiste Kempf <jb at videolan.org>
> http://git.videolan.org/gitweb.cgi/vlc/vlc-1.1.git/?a=commit;h=5d434e61bb0f619da81430d8a512b6796f145740
---
configure.ac | 3 +++
modules/access/dvdnav.c | 32 ++++++++++++++++++++++++++++++++
2 files changed, 35 insertions(+), 0 deletions(-)
diff --git a/configure.ac b/configure.ac
index e2024c7..c41577a 100644
--- a/configure.ac
+++ b/configure.ac
@@ -1951,6 +1951,9 @@ then
VLC_ADD_PLUGIN([dvdnav])
VLC_ADD_CFLAGS([dvdnav],[`${DVDNAV_CONFIG} --cflags`])
VLC_ADD_LIBS([dvdnav],[`${DVDNAV_CONFIG} --libs`])
+ AC_CHECK_LIB(dvdnav, dvdnav_get_video_resolution,
+ AC_DEFINE(HAVE_DVDNAV_GET_VIDEO_RESOLUTION, 1, [Define if you have dvdnav_get_video_resolution.]),
+ [], [${LIBS_dvdnav}])
fi
fi
diff --git a/modules/access/dvdnav.c b/modules/access/dvdnav.c
index 9985450..90d9155 100644
--- a/modules/access/dvdnav.c
+++ b/modules/access/dvdnav.c
@@ -137,6 +137,12 @@ struct demux_sys_t
uint8_t palette[4][4];
bool b_spu_change;
+ /* Aspect ration */
+ struct {
+ unsigned i_num;
+ unsigned i_den;
+ } sar;
+
/* */
int i_title;
input_title_t **title;
@@ -229,6 +235,8 @@ static int Open( vlc_object_t *p_this )
p_sys->b_reset_pcr = false;
ps_track_init( p_sys->tk );
+ p_sys->sar.i_num = 0;
+ p_sys->sar.i_den = 0;
p_sys->i_mux_rate = 0;
p_sys->i_pgc_length = 0;
p_sys->b_spu_change = false;
@@ -742,6 +750,28 @@ static int Demux( demux_t *p_demux )
tk->b_seen = false;
}
+#if defined(HAVE_DVDNAV_GET_VIDEO_RESOLUTION)
+ uint32_t i_width, i_height;
+ if( dvdnav_get_video_resolution( p_sys->dvdnav,
+ &i_width, &i_height ) )
+ i_width = i_height = 0;
+ switch( dvdnav_get_video_aspect( p_sys->dvdnav ) )
+ {
+ case 0:
+ p_sys->sar.i_num = 4 * i_height;
+ p_sys->sar.i_den = 3 * i_width;
+ break;
+ case 3:
+ p_sys->sar.i_num = 16 * i_height;
+ p_sys->sar.i_den = 9 * i_width;
+ break;
+ default:
+ p_sys->sar.i_num = 0;
+ p_sys->sar.i_den = 0;
+ break;
+ }
+#endif
+
if( dvdnav_current_title_info( p_sys->dvdnav, &i_title,
&i_part ) == DVDNAV_STATUS_OK )
{
@@ -1215,6 +1245,8 @@ static void ESNew( demux_t *p_demux, int i_id )
/* Add a new ES */
if( tk->fmt.i_cat == VIDEO_ES )
{
+ tk->fmt.video.i_sar_num = p_sys->sar.i_num;
+ tk->fmt.video.i_sar_den = p_sys->sar.i_den;
b_select = true;
}
else if( tk->fmt.i_cat == AUDIO_ES )
More information about the vlc-commits
mailing list