summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-03-28 20:40:21 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-03-28 20:40:21 +0000
commit5475823f41bfe971bec6dd2208dd7c01bc11edd8 (patch)
tree69fec4aa970acebcae084d086f6a7846f5b669f2
parente55db72e97eb5f652db237cb16abb79d4f2c927d (diff)
downloadmpv-5475823f41bfe971bec6dd2208dd7c01bc11edd8.tar.bz2
mpv-5475823f41bfe971bec6dd2208dd7c01bc11edd8.tar.xz
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@5381 b3059339-0415-0410-9bf9-f77b7e298cf2
-rw-r--r--cfg-common.h3
-rwxr-xr-xconfigure32
-rw-r--r--input/input.c13
-rw-r--r--input/input.h8
-rw-r--r--libmpdemux/open.c26
-rw-r--r--libmpdemux/stream.c99
-rw-r--r--libmpdemux/stream.h2
-rw-r--r--mplayer.c40
8 files changed, 220 insertions, 3 deletions
diff --git a/cfg-common.h b/cfg-common.h
index 7174a457b4..632dde9486 100644
--- a/cfg-common.h
+++ b/cfg-common.h
@@ -12,6 +12,9 @@
#else
{"vcd", "VCD support is NOT available on this system!\n", CONF_TYPE_PRINT, CONF_NOCFG, 0, 0, NULL},
#endif
+#ifdef USE_DVDNAV
+ {"dvdnav", &dvd_nav, CONF_TYPE_FLAG, 0, 0, 1},
+#endif
#ifdef USE_DVDREAD
{"dvd-device", &dvd_device, CONF_TYPE_STRING, 0, 0, 0, NULL},
{"dvd", &dvd_title, CONF_TYPE_INT, CONF_RANGE, 1, 99, NULL},
diff --git a/configure b/configure
index 4acba25aed..afeaf420f1 100755
--- a/configure
+++ b/configure
@@ -207,6 +207,7 @@ Use these options if autodetection fails:
--with-csslibdir=DIR libcss in DIR
--with-madlibdir=DIR libmad (libmad shared lib.) in DIR
--with-mlibdir=DIR libmlib (MLIB support) in DIR (Solaris only)
+ --with-libdvdnav=DIR libdvdnav in DIR
--with-win32libdir=DIR W*ndows DLL files in DIR
--with-xanimlibdir=DIR XAnim DLL files in DIR
--with-xvidcore=PATH path to XviD libcore.a (e.g: /opt/lib/libcore.a)
@@ -787,6 +788,7 @@ _mad=auto
_vorbis=auto
_faad=auto
_css=auto
+_dvdnav=no
_dvdread=auto
_xanim=auto
_xinerama=auto
@@ -970,6 +972,10 @@ for ac_option do
--language=*)
LINGUAS=`echo $ac_option | cut -d '=' -f 2`
;;
+ --with-libdvdnav=*)
+ _dvdnavdir=`echo $ac_option | cut -d '=' -f 2`
+ _dvdnav=yes
+ ;;
--with-win32libdir=*)
_win32libdir=`echo $ac_option | cut -d '=' -f 2`
@@ -2414,7 +2420,6 @@ else
echores "no"
fi
-
echocheck "DVD support (libdvdread - new style)"
if test "$_dvdread" = auto ; then
cat > $TMPC << EOF
@@ -2443,6 +2448,28 @@ else
echores "no"
fi
+echocheck "libdvdnav"
+if test "$_dvdnav" = yes ; then
+ cat > $TMPC <<EOF
+#include <dvdnav.h>
+int main(void) { dvdnav_t *dvd=0; return 0; }
+EOF
+ _dvdnav=no
+ cc_check $_inc_extra -I$_dvdnavdir $_ld_css -L$_dvdnavdir/.libs -ldvdnav && _dvdnav=yes
+fi
+if test "$_dvdnav" = yes ; then
+ _largefiles=yes
+ _def_dvdnav='#define USE_DVDNAV 1'
+ _ld_css="$_ld_css -L$_dvdnavdir/.libs -ldvdnav"
+ _inc_extra="$_inc_extra -I$_dvdnavdir"
+ _inputmodules="dvdnav $_inputmodules"
+ echores "yes"
+else
+ _def_dvdnav='#undef USE_DVDNAV'
+ _noinputmodules="dvdnav $_noinputmodules"
+ echores "no"
+fi
+
echocheck "zlib"
cat > $TMPC << EOF
#include <zlib.h>
@@ -3466,6 +3493,9 @@ $_def_lirc
/* DeCSS support using libcss */
$_def_css
+/* DVD navigation support using libdvdnav */
+$_def_dvdnav
+
/* Define this to enable MPEG 1/2 image postprocessing (requires FAST cpu!) */
#define MPEG12_POSTPROC 1
diff --git a/input/input.c b/input/input.c
index cb74313223..37a3872b0e 100644
--- a/input/input.c
+++ b/input/input.c
@@ -75,6 +75,10 @@ static mp_cmd_t mp_cmds[] = {
{ MP_CMD_GUI_PREFERENCES, "gui_preferences", 0, { {-1,{0}} } },
{ MP_CMD_GUI_SKINBROWSER, "gui_skinbrowser", 0, { {-1,{0}} } },
#endif
+
+#ifdef USE_DVDNAV
+ { MP_CMD_DVDNAV, "dvdnav", 1, { {MP_CMD_ARG_INT,{0}}, {-1,{0}} } },
+#endif
{ 0, NULL, 0, {} }
};
@@ -159,6 +163,15 @@ static mp_cmd_bind_t def_cmd_binds[] = {
{ { MOUSE_BTN5, 0 }, "volume 1" },
{ { MOUSE_BTN6, 0 }, "volume -1" },
+#ifdef USE_DVDNAV
+ { { 'K', 0 }, "dvdnav 1" }, // up
+ { { 'J', 0 }, "dvdnav 2" }, // down
+ { { 'H', 0 }, "dvdnav 3" }, // left
+ { { 'L', 0 }, "dvdnav 4" }, // right
+ { { 'M', 0 }, "dvdnav 5" }, // menu
+ { { 'S', 0 }, "dvdnav 6" }, // select
+#endif
+
{ { KEY_RIGHT, 0 }, "seek 10" },
{ { KEY_LEFT, 0 }, "seek -10" },
{ { KEY_UP, 0 }, "seek 60" },
diff --git a/input/input.h b/input/input.h
index 2d7cacfd84..5e254f9887 100644
--- a/input/input.h
+++ b/input/input.h
@@ -24,6 +24,7 @@
#define MP_CMD_TV_STEP_CHANNEL_LIST 19
#define MP_CMD_VO_FULLSCREEN 20
#define MP_CMD_SUB_POS 21
+#define MP_CMD_DVDNAV 22
#define MP_CMD_GUI_EVENTS 5000
#define MP_CMD_GUI_LOADFILE 5001
@@ -36,6 +37,13 @@
#define MP_CMD_GUI_FULLSCREEN 5008
#define MP_CMD_GUI_SKINBROWSER 5009
+#define MP_CMD_DVDNAV_UP 1
+#define MP_CMD_DVDNAV_DOWN 2
+#define MP_CMD_DVDNAV_LEFT 3
+#define MP_CMD_DVDNAV_RIGHT 4
+#define MP_CMD_DVDNAV_MENU 5
+#define MP_CMD_DVDNAV_SELECT 6
+
// The args types
#define MP_CMD_ARG_INT 0
#define MP_CMD_ARG_FLOAT 1
diff --git a/libmpdemux/open.c b/libmpdemux/open.c
index 2e8f55d6de..ce37aa1d45 100644
--- a/libmpdemux/open.c
+++ b/libmpdemux/open.c
@@ -31,6 +31,11 @@ int dvd_last_chapter=0;
int dvd_angle=1;
char* dvd_device=NULL;
char* cdrom_device=NULL;
+int dvd_nav=0;
+
+#ifdef USE_DVDNAM
+#include <dvdnav.h>
+#endif
#ifdef USE_DVDREAD
@@ -110,10 +115,29 @@ if(vcd_track){
#endif
//============ Open DVD title ==============
+#ifdef USE_DVDNAV
+if(dvd_nav){
+ dvdnav_t *dvdnav;
+ int event,len,tmplen=0;
+ if(!filename) filename=DEFAULT_DVD_DEVICE;
+ if(dvdnav_open(&dvdnav,filename)!=DVDNAV_STATUS_OK) {
+ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_CantOpenDVD,filename);
+ return NULL;
+ }
+
+ stream=new_stream(-1,STREAMTYPE_DVDNAV);
+ if (!stream) {
+ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_Exit_error);
+ return NULL;
+ }
+ stream->priv=(void*)dvdnav;
+ return stream;
+}
+#endif
#ifdef USE_DVDREAD
if(dvd_title){
// int ret,ret2;
- dvd_priv_t *d;
+ dvd_priv_t *d;
int ttn,pgc_id,pgn;
dvd_reader_t *dvd;
dvd_file_t *title;
diff --git a/libmpdemux/stream.c b/libmpdemux/stream.c
index 7247f588e7..402c9a1cf8 100644
--- a/libmpdemux/stream.c
+++ b/libmpdemux/stream.c
@@ -28,6 +28,13 @@ extern int verbose; // defined in mplayer.c
#endif
+#ifdef USE_DVDNAV
+#include <dvdnav.h>
+#include <../linux/timer.h>
+static int still_sleep_until;
+static int sleeping=0;
+static int stillen=0;
+#endif
#ifdef USE_DVDREAD
int dvd_read_sector(void* d,void* p2);
void dvd_seek(void* d,off_t pos);
@@ -59,6 +66,98 @@ int stream_fill_buffer(stream_t *s){
len=vcd_read(s->fd,s->buffer);break;
#endif
#endif
+#ifdef USE_DVDNAV
+ case STREAMTYPE_DVDNAV: {
+ int event = DVDNAV_NOP;
+ if(sleeping)
+ {
+ dvdnav_still_skip(s->priv);
+ if(sleeping==1) if(GetTimer()>=still_sleep_until) sleeping = 0;
+ len = stillen;
+ }
+ if(dvdnav_get_next_block(s->priv,s->buffer,&event,&len)!=DVDNAV_STATUS_OK)
+ printf( "Error getting next block from DVD (%s)\n",dvdnav_err_to_string(s->priv) );
+ else switch(event) {
+ case DVDNAV_BLOCK_OK: {
+ /* be silent about this one */
+ break;
+ }
+ case DVDNAV_HIGHLIGHT: {
+ dvdnav_highlight_event_t *hevent = (dvdnav_highlight_event_t*)(s->buffer);
+ if (!hevent) {
+ printf("Highlight event broken\n");
+ break;
+ }
+
+ if (hevent->display)
+ {
+ printf( "Highlight (%u,%u)-(%u,%u) (button %d)\n",
+ hevent->sx,hevent->sy,
+ hevent->ex,hevent->ey,
+ hevent->buttonN );
+ }
+ else {
+ printf("Highlight Hide\n");
+ }
+ break;
+ }
+ case DVDNAV_STILL_FRAME: {
+ printf( "Still Frame\n" );
+ dvdnav_still_event_t *still_event = (dvdnav_still_event_t*)(s->buffer);
+ if(still_event->length==0xff) { printf( "Sleeping indefinately\n" ); sleeping=2; }
+ else {
+ InitTimer();
+ still_sleep_until = GetTimer() + still_event->length*1000000;
+ printf( "Sleeping %d sec(s)\n", still_event->length );
+ sleeping=1;
+ }
+ stillen = len;
+ break;
+ }
+ case DVDNAV_STOP: {
+ printf( "Nav Stop\n" );
+ len=0;
+ break;
+ }
+ case DVDNAV_NOP: {
+ printf("Nav NOP\n");
+ break;
+ }
+ case DVDNAV_SPU_STREAM_CHANGE: {
+ printf("Nav SPU Stream Change\n");
+ break;
+ }
+ case DVDNAV_AUDIO_STREAM_CHANGE: {
+ printf("Nav Audio Stream Change\n");
+ break;
+ }
+ case DVDNAV_VTS_CHANGE: {
+ printf("Nav VTS Change\n");
+ break;
+ }
+ case DVDNAV_CELL_CHANGE: {
+ printf("Nav Cell Change\n");
+ break;
+ }
+ case DVDNAV_NAV_PACKET: {
+ // printf("Nav Packet\n");
+ break;
+ }
+ case DVDNAV_SPU_CLUT_CHANGE: {
+ printf("Nav SPU CLUT Change\n");
+ break;
+ }
+ case DVDNAV_SEEK_DONE: {
+ printf("Nav Seek Done\n");
+ break;
+ }
+ default:
+ printf("Weird nav event %d\n",event);
+ break;
+ }
+ break;
+ }
+#endif
#ifdef USE_DVDREAD
case STREAMTYPE_DVD: {
off_t pos=dvd_read_sector(s->priv,s->buffer);
diff --git a/libmpdemux/stream.h b/libmpdemux/stream.h
index 404bfac4d6..4426ef0e05 100644
--- a/libmpdemux/stream.h
+++ b/libmpdemux/stream.h
@@ -16,6 +16,7 @@
#define STREAMTYPE_PLAYLIST 6
#define STREAMTYPE_MF 7
#define STREAMTYPE_DS 8
+#define STREAMTYPE_DVDNAV 9
#define VCD_SECTOR_SIZE 2352
#define VCD_SECTOR_OFFS 24
@@ -197,6 +198,7 @@ extern int dvd_title;
extern int dvd_chapter;
extern int dvd_last_chapter;
extern int dvd_angle;
+extern int dvd_nav;
int dvd_parse_chapter_range(struct config*, const char*);
//#endif
diff --git a/mplayer.c b/mplayer.c
index 2e4052ee7b..1ad9608c6a 100644
--- a/mplayer.c
+++ b/mplayer.c
@@ -48,6 +48,9 @@ extern void* mDisplay; // Display* mDisplay;
#include "codec-cfg.h"
#include "dvdauth.h"
+#ifdef USE_DVDNAV
+#include <dvdnav.h>
+#endif
#ifdef USE_DVDREAD
#include "spudec.h"
#endif
@@ -627,7 +630,7 @@ if(!parse_codec_cfg(get_path("codecs.conf"))){
}
- if(!filename && !vcd_track && !dvd_title && !tv_param_on){
+ if(!filename && !vcd_track && !dvd_title && !dvd_nav && !tv_param_on){
if(!use_gui){
// no file/vcd/dvd -> show HELP:
mp_msg(MSGT_CPLAYER, MSGL_INFO, help_text);
@@ -1962,6 +1965,13 @@ if(step_sec>0) {
break;
// quit
case KEY_ESC: // ESC
+#ifdef USE_DVDNAV
+ if(dvd_nav) {
+ printf("menu\n");
+ dvdnav_menu_call(stream->priv,DVD_MENU_Root);
+ break;
+ }
+#endif
case 'q':
exit_player(MSGTR_Exit_quit);
case KEY_ENTER: // ESC
@@ -2437,6 +2447,34 @@ if(step_sec>0) {
if(sub_pos >100) sub_pos=100;
if(sub_pos <0) sub_pos=0;
} break;
+#ifdef USE_DVDNAV
+ case MP_CMD_DVDNAV: {
+ switch (cmd->args[0].v.i) {
+ case MP_CMD_DVDNAV_UP:
+ dvdnav_upper_button_select(stream->priv);
+ break;
+ case MP_CMD_DVDNAV_DOWN:
+ dvdnav_lower_button_select(stream->priv);
+ break;
+ case MP_CMD_DVDNAV_LEFT:
+ dvdnav_left_button_select(stream->priv);
+ break;
+ case MP_CMD_DVDNAV_RIGHT:
+ dvdnav_right_button_select(stream->priv);
+ break;
+ case MP_CMD_DVDNAV_MENU:
+ dvdnav_menu_call(stream->priv,DVD_MENU_Root);
+ break;
+ case MP_CMD_DVDNAV_SELECT:
+ dvdnav_button_activate(stream->priv);
+ break;
+ default:
+ mp_msg(MSGT_CPLAYER, MSGL_V, "Weird DVD Nav cmd %d\n",cmd->args[0].v.i);
+ break;
+ }
+ break;
+ }
+#endif
default : {
#ifdef HAVE_NEW_GUI
if ( ( use_gui )&&( cmd->id > MP_CMD_GUI_EVENTS ) ) guiGetEvent( guiIEvent,(char *)cmd->id );