[MPlayer-cvslog] CVS: main/libmpdemux tv.c,1.77,1.78
Alban Bedel CVS
syncmail at mplayerhq.hu
Tue Mar 14 01:45:09 CET 2006
CVS change done by Alban Bedel CVS
Update of /cvsroot/mplayer/main/libmpdemux
In directory mail:/var2/tmp/cvs-serv1708/libmpdemux
Modified Files:
tv.c
Log Message:
Try several formats instead of only YV12 if no format was explicitly
requested. Patch from Benjamin Zores <ben -at- geexbox -dot- org> with
a few whitespace changes.
Index: tv.c
===================================================================
RCS file: /cvsroot/mplayer/main/libmpdemux/tv.c,v
retrieving revision 1.77
retrieving revision 1.78
diff -u -r1.77 -r1.78
--- tv.c 11 Dec 2005 17:21:02 -0000 1.77
+++ tv.c 14 Mar 2006 00:45:06 -0000 1.78
@@ -53,7 +53,7 @@
int tv_param_width = -1;
int tv_param_height = -1;
int tv_param_input = 0; /* used in v4l and bttv */
-int tv_param_outfmt = IMGFMT_YV12;
+int tv_param_outfmt = -1;
float tv_param_fps = -1.0;
char **tv_param_channels = NULL;
int tv_param_audio_id = 0;
@@ -165,6 +165,16 @@
{
int i;
tvi_functions_t *funcs = tvh->functions;
+ int tv_fmt_list[] = {
+ IMGFMT_YV12,
+ IMGFMT_I420,
+ IMGFMT_UYVY,
+ IMGFMT_YUY2,
+ IMGFMT_RGB32,
+ IMGFMT_RGB24,
+ IMGFMT_RGB16,
+ IMGFMT_RGB15
+ };
if (funcs->control(tvh->priv, TVI_CONTROL_IS_VIDEO, 0) != TVI_CONTROL_TRUE)
{
@@ -172,6 +182,16 @@
return 0;
}
+ if (tv_param_outfmt == -1)
+ for (i = 0; i < sizeof (tv_fmt_list) / sizeof (*tv_fmt_list); i++)
+ {
+ tv_param_outfmt = tv_fmt_list[i];
+ if (funcs->control (tvh->priv, TVI_CONTROL_VID_SET_FORMAT,
+ &tv_param_outfmt) == TVI_CONTROL_TRUE)
+ break;
+ }
+ else
+ {
switch(tv_param_outfmt)
{
case IMGFMT_YV12:
@@ -194,6 +214,7 @@
mp_msg(MSGT_TV, MSGL_ERR, "==================================================================\n");
}
funcs->control(tvh->priv, TVI_CONTROL_VID_SET_FORMAT, &tv_param_outfmt);
+ }
/* set some params got from cmdline */
funcs->control(tvh->priv, TVI_CONTROL_SPC_SET_INPUT, &tv_param_input);
More information about the MPlayer-cvslog
mailing list