Commit 4e9f1e46 authored by Petri Hintukainen's avatar Petri Hintukainen Committed by Jean-Baptiste Kempf

Add INPUT_NAV_POPUP and DEMUX_NAV_POPUP for BluRay pop-up menu

Signed-off-by: default avatarJean-Baptiste Kempf <jb@videolan.org>
parent 265466c5
...@@ -268,6 +268,7 @@ enum demux_query_e ...@@ -268,6 +268,7 @@ enum demux_query_e
DEMUX_NAV_DOWN, /* res=can fail */ DEMUX_NAV_DOWN, /* res=can fail */
DEMUX_NAV_LEFT, /* res=can fail */ DEMUX_NAV_LEFT, /* res=can fail */
DEMUX_NAV_RIGHT, /* res=can fail */ DEMUX_NAV_RIGHT, /* res=can fail */
DEMUX_NAV_POPUP, /* res=can fail */
}; };
/************************************************************************* /*************************************************************************
......
...@@ -432,6 +432,7 @@ enum input_query_e ...@@ -432,6 +432,7 @@ enum input_query_e
INPUT_NAV_DOWN, INPUT_NAV_DOWN,
INPUT_NAV_LEFT, INPUT_NAV_LEFT,
INPUT_NAV_RIGHT, INPUT_NAV_RIGHT,
INPUT_NAV_POPUP,
/* Meta datas */ /* Meta datas */
INPUT_ADD_INFO, /* arg1= char* arg2= char* arg3=... res=can fail */ INPUT_ADD_INFO, /* arg1= char* arg2= char* arg3=... res=can fail */
......
...@@ -141,6 +141,7 @@ int input_vaControl( input_thread_t *p_input, int i_query, va_list args ) ...@@ -141,6 +141,7 @@ int input_vaControl( input_thread_t *p_input, int i_query, va_list args )
case INPUT_NAV_DOWN: case INPUT_NAV_DOWN:
case INPUT_NAV_LEFT: case INPUT_NAV_LEFT:
case INPUT_NAV_RIGHT: case INPUT_NAV_RIGHT:
case INPUT_NAV_POPUP:
input_ControlPush( p_input, i_query - INPUT_NAV_ACTIVATE input_ControlPush( p_input, i_query - INPUT_NAV_ACTIVATE
+ INPUT_CONTROL_NAV_ACTIVATE, NULL ); + INPUT_CONTROL_NAV_ACTIVATE, NULL );
return VLC_SUCCESS; return VLC_SUCCESS;
......
...@@ -1492,6 +1492,7 @@ static bool ControlIsSeekRequest( int i_type ) ...@@ -1492,6 +1492,7 @@ static bool ControlIsSeekRequest( int i_type )
case INPUT_CONTROL_NAV_DOWN: case INPUT_CONTROL_NAV_DOWN:
case INPUT_CONTROL_NAV_LEFT: case INPUT_CONTROL_NAV_LEFT:
case INPUT_CONTROL_NAV_RIGHT: case INPUT_CONTROL_NAV_RIGHT:
case INPUT_CONTROL_NAV_POPUP:
return true; return true;
default: default:
return false; return false;
...@@ -1970,6 +1971,7 @@ static bool Control( input_thread_t *p_input, ...@@ -1970,6 +1971,7 @@ static bool Control( input_thread_t *p_input,
case INPUT_CONTROL_NAV_DOWN: case INPUT_CONTROL_NAV_DOWN:
case INPUT_CONTROL_NAV_LEFT: case INPUT_CONTROL_NAV_LEFT:
case INPUT_CONTROL_NAV_RIGHT: case INPUT_CONTROL_NAV_RIGHT:
case INPUT_CONTROL_NAV_POPUP:
demux_Control( p_input->p->master->p_demux, i_type demux_Control( p_input->p->master->p_demux, i_type
- INPUT_CONTROL_NAV_ACTIVATE + DEMUX_NAV_ACTIVATE ); - INPUT_CONTROL_NAV_ACTIVATE + DEMUX_NAV_ACTIVATE );
break; break;
......
...@@ -199,6 +199,7 @@ enum input_control_e ...@@ -199,6 +199,7 @@ enum input_control_e
INPUT_CONTROL_NAV_DOWN, // INPUT_NAV_* and DEMUX_NAV_*. INPUT_CONTROL_NAV_DOWN, // INPUT_NAV_* and DEMUX_NAV_*.
INPUT_CONTROL_NAV_LEFT, INPUT_CONTROL_NAV_LEFT,
INPUT_CONTROL_NAV_RIGHT, INPUT_CONTROL_NAV_RIGHT,
INPUT_CONTROL_NAV_POPUP,
INPUT_CONTROL_SET_ES, INPUT_CONTROL_SET_ES,
INPUT_CONTROL_RESTART_ES, INPUT_CONTROL_RESTART_ES,
......
...@@ -112,6 +112,7 @@ static const vlc_input_callback_t p_input_navigation_callbacks[] = ...@@ -112,6 +112,7 @@ static const vlc_input_callback_t p_input_navigation_callbacks[] =
{ {
CALLBACK( "next-title", TitleCallback ), CALLBACK( "next-title", TitleCallback ),
CALLBACK( "prev-title", TitleCallback ), CALLBACK( "prev-title", TitleCallback ),
CALLBACK( "menu-popup", TitleCallback ),
CALLBACK( NULL, NULL ) CALLBACK( NULL, NULL )
}; };
...@@ -269,6 +270,13 @@ void input_ControlVarNavigation( input_thread_t *p_input ) ...@@ -269,6 +270,13 @@ void input_ControlVarNavigation( input_thread_t *p_input )
var_Change( p_input, "prev-title", VLC_VAR_SETTEXT, &text, NULL ); var_Change( p_input, "prev-title", VLC_VAR_SETTEXT, &text, NULL );
var_AddCallback( p_input, "prev-title", TitleCallback, NULL ); var_AddCallback( p_input, "prev-title", TitleCallback, NULL );
} }
if( var_Type( p_input, "menu-popup" ) == 0 ) {
var_Create( p_input, "menu-popup", VLC_VAR_VOID );
text.psz_string = _("Menu popup");
var_Change( p_input, "menu-popup", VLC_VAR_SETTEXT, &text, NULL );
var_AddCallback( p_input, "menu-popup", TitleCallback, NULL );
}
} }
/* Create titles and chapters */ /* Create titles and chapters */
...@@ -672,6 +680,10 @@ static int TitleCallback( vlc_object_t *p_this, char const *psz_cmd, ...@@ -672,6 +680,10 @@ static int TitleCallback( vlc_object_t *p_this, char const *psz_cmd,
if( val.i_int >= 0 ) if( val.i_int >= 0 )
var_Change( p_input, "title", VLC_VAR_SETVALUE, &val, NULL ); var_Change( p_input, "title", VLC_VAR_SETVALUE, &val, NULL );
} }
else if( !strcmp( psz_cmd, "menu-popup" ) )
{
input_ControlPush( p_input, INPUT_CONTROL_NAV_POPUP, NULL );
}
else else
{ {
input_ControlPush( p_input, INPUT_CONTROL_SET_TITLE, &newval ); input_ControlPush( p_input, INPUT_CONTROL_SET_TITLE, &newval );
......
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