Mercurial > mplayer.hg
changeset 8477:b5dce4fa1c48
support for exotic norms
author | henry |
---|---|
date | Mon, 16 Dec 2002 17:05:49 +0000 |
parents | 650dda2e4bbb |
children | 7988573021e8 |
files | libmpdemux/tv.c libmpdemux/tv.h libmpdemux/tvi_v4l.c |
diffstat | 3 files changed, 43 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/libmpdemux/tv.c Mon Dec 16 10:43:07 2002 +0000 +++ b/libmpdemux/tv.c Mon Dec 16 17:05:49 2002 +0000 @@ -159,6 +159,18 @@ tvh->norm = TV_NORM_NTSC; else if (!strcasecmp(tv_param_norm, "secam")) tvh->norm = TV_NORM_SECAM; + else if (!strcasecmp(tv_param_norm, "palnc")) + tvh->norm = TV_NORM_PALNC; + else if (!strcasecmp(tv_param_norm, "palm")) + tvh->norm = TV_NORM_PALM; + else if (!strcasecmp(tv_param_norm, "paln")) + tvh->norm = TV_NORM_PALN; + else if (!strcasecmp(tv_param_norm, "ntscjp")) + tvh->norm = TV_NORM_NTSCJP; + else { + mp_msg(MSGT_TV, MSGL_V, "Bogus norm parameter, setting PAL.\n"); + tvh->norm = TV_NORM_PAL; + } mp_msg(MSGT_TV, MSGL_V, "Selected norm: %s\n", tv_param_norm); funcs->control(tvh->priv, TVI_CONTROL_TUN_SET_NORM, &tvh->norm);
--- a/libmpdemux/tv.h Mon Dec 16 10:43:07 2002 +0000 +++ b/libmpdemux/tv.h Mon Dec 16 17:05:49 2002 +0000 @@ -154,6 +154,10 @@ #define TV_NORM_PAL 1 #define TV_NORM_NTSC 2 #define TV_NORM_SECAM 3 +#define TV_NORM_PALNC 4 +#define TV_NORM_PALM 5 +#define TV_NORM_PALN 6 +#define TV_NORM_NTSCJP 7 #endif /* USE_TV */
--- a/libmpdemux/tvi_v4l.c Mon Dec 16 10:43:07 2002 +0000 +++ b/libmpdemux/tvi_v4l.c Mon Dec 16 17:05:49 2002 +0000 @@ -980,15 +980,21 @@ { int req_mode = (int)*(void **)arg; - if ((req_mode != TV_NORM_PAL) && (req_mode != TV_NORM_NTSC) && (req_mode != TV_NORM_SECAM)) { + if ((req_mode != TV_NORM_PAL) && (req_mode != TV_NORM_NTSC) && (req_mode != TV_NORM_SECAM) + && (req_mode != TV_NORM_PALNC) && (req_mode != TV_NORM_PALM) && (req_mode != TV_NORM_PALN) + && (req_mode != TV_NORM_NTSCJP)) { mp_msg(MSGT_TV, MSGL_ERR, "Unknown norm!\n"); return(TVI_CONTROL_FALSE); } if (priv->channels[priv->act_channel].flags & VIDEO_VC_TUNER) { control(priv, TVI_CONTROL_TUN_GET_TUNER, 0); - if (((req_mode == TV_NORM_PAL) && !(priv->tuner.flags & VIDEO_TUNER_PAL)) || - ((req_mode == TV_NORM_NTSC) && !(priv->tuner.flags & VIDEO_TUNER_NTSC)) || + if (((req_mode == TV_NORM_PAL + || req_mode == TV_NORM_PALNC + || req_mode == TV_NORM_PALN) && !(priv->tuner.flags & VIDEO_TUNER_PAL)) || + ((req_mode == TV_NORM_NTSC + || req_mode == TV_NORM_NTSCJP + || req_mode == TV_NORM_PALM) && !(priv->tuner.flags & VIDEO_TUNER_NTSC)) || ((req_mode == TV_NORM_SECAM) && !(priv->tuner.flags & VIDEO_TUNER_SECAM))) { mp_msg(MSGT_TV, MSGL_ERR, "Tuner isn't capable to set norm!\n"); @@ -997,9 +1003,13 @@ switch(req_mode) { case TV_NORM_PAL: + case TV_NORM_PALNC: + case TV_NORM_PALN: priv->tuner.mode = VIDEO_MODE_PAL; break; case TV_NORM_NTSC: + case TV_NORM_NTSCJP: + case TV_NORM_PALM: priv->tuner.mode = VIDEO_MODE_NTSC; break; case TV_NORM_SECAM: @@ -1023,6 +1033,18 @@ case TV_NORM_SECAM: priv->channels[priv->act_channel].norm = VIDEO_MODE_SECAM; break; + case TV_NORM_PALNC: + priv->channels[priv->act_channel].norm = 3; + break; + case TV_NORM_PALM: + priv->channels[priv->act_channel].norm = 4; + break; + case TV_NORM_PALN: + priv->channels[priv->act_channel].norm = 5; + break; + case TV_NORM_NTSCJP: + priv->channels[priv->act_channel].norm = 6; + break; } if (ioctl(priv->video_fd, VIDIOCSCHAN, &priv->channels[priv->act_channel]) == -1) { @@ -1035,11 +1057,11 @@ return(TVI_CONTROL_FALSE); } - if(req_mode == TV_NORM_PAL || req_mode == TV_NORM_SECAM) { + if(req_mode == TV_NORM_PAL || req_mode == TV_NORM_SECAM || req_mode == TV_NORM_PALN || req_mode == TV_NORM_PALNC) { priv->fps = PAL_FPS; } - if(req_mode == TV_NORM_NTSC) { + if(req_mode == TV_NORM_NTSC || req_mode == TV_NORM_NTSCJP || req_mode == TV_NORM_PALM) { priv->fps = NTSC_FPS; }