aboutsummaryrefslogtreecommitdiffhomepage
path: root/Gui/mplayer
diff options
context:
space:
mode:
Diffstat (limited to 'Gui/mplayer')
-rw-r--r--Gui/mplayer/gtk/fs.c409
-rw-r--r--Gui/mplayer/gtk/fs.h6
-rw-r--r--Gui/mplayer/mw.h6
-rw-r--r--Gui/mplayer/play.h3
-rw-r--r--Gui/mplayer/psignal.c16
-rw-r--r--Gui/mplayer/widgets.h2
6 files changed, 263 insertions, 179 deletions
diff --git a/Gui/mplayer/gtk/fs.c b/Gui/mplayer/gtk/fs.c
index 085dabc9d1..49250e0f74 100644
--- a/Gui/mplayer/gtk/fs.c
+++ b/Gui/mplayer/gtk/fs.c
@@ -32,20 +32,37 @@
gchar * fsSelectedFile = NULL;
gchar * fsSelectedDirectory = NULL;
unsigned char * fsThatDir = ".";
-gchar * fsFilter = NULL;
+gchar fsFilter[8] = "*";
int fsPressed = 0;
-#define fsLastFilterNames 6
-unsigned char * fsFilterNames[fsLastFilterNames+1][2] =
- { { "MPEG files( *.mpg )", "*.mpg" },
- { "VOB files( *.vob )", "*.vob" },
- { "AVI files( *.avi )", "*.avi" },
- { "QT files( *.mov )", "*.mov" },
- { "ASF files( *.asf )", "*.asf" },
- { "VIVO files( *.viv )", "*.viv" },
- { "All files( * )", "*" } };
-
-// .avi .mpg .vob .mov .viv .asf
+int fsMessage = -1;
+int fsType = 0;
+
+#define fsNumberOfVideoFilterNames 6
+char * fsVideoFilterNames[fsNumberOfVideoFilterNames+1][2] =
+ { { "MPEG files ( *.mpg )", "*.mpg" },
+ { "VOB files ( *.vob )", "*.vob" },
+ { "AVI files ( *.avi )", "*.avi" },
+ { "QT files ( *.mov )", "*.mov" },
+ { "ASF files ( *.asf )", "*.asf" },
+ { "VIVO files ( *.viv )", "*.viv" },
+ { "All files ( * )", "*" } };
+
+#define fsNumberOfSubtitleFilterNames 8
+char * fsSubtitleFilterNames[fsNumberOfSubtitleFilterNames+1][2] =
+ { { "UTF ( *.utf )", "*.utf" },
+ { "SUB ( *.sub )", "*.sub" },
+ { "SRT ( *.srt )", "*.str" },
+ { "SMI ( *.smi )", "*.smi" },
+ { "RT ( *.rt )", "*.rt" },
+ { "TXT ( *.txt )", "*.txt" },
+ { "SSA ( *.ssa )", "*.ssa" },
+ { "AQT ( *.aqt )", "*.aqt" },
+ { "All files ( * )", "*" } };
+
+#define fsNumberOfOtherFilterNames 0
+char * fsOtherFilterNames[fsNumberOfOtherFilterNames+1][2] =
+ { { "All types", "*" } };
GtkWidget * fsFileNamesList;
GtkWidget * fsFNameList;
@@ -55,78 +72,134 @@ GtkWidget * fsOk;
GtkWidget * fsUp;
GtkWidget * fsCancel;
GtkWidget * fsCombo4;
-GtkWidget * fsComboEntry2;
+GtkWidget * fsPathCombo;
GList * fsList_items = NULL;
GList * fsTopList_items = NULL;
+GtkWidget * List;
+GtkWidget * fsFilterCombo;
-void CheckDir( GtkWidget * list,unsigned char * directory )
+
+GtkStyle * style;
+GdkPixmap * dpixmap;
+GdkPixmap * fpixmap;
+GdkBitmap * dmask;
+GdkBitmap * fmask;
+
+void CheckDir( GtkWidget * list,char * directory )
{
struct stat fs;
int i,c=2;
gchar * str[1][2];
- GdkPixmap * dpixmap,*fpixmap,*pixmap;
- GdkBitmap * dmask,*fmask,*mask;
- GtkStyle * style;
+ GdkPixmap * pixmap;
+ GdkBitmap * mask;
glob_t gg;
+ if ( !fsFilter[0] ) return;
+
gtk_widget_hide( list );
+ gtk_clist_clear( GTK_CLIST( list ) );
str[0][0]=NULL;
- style=gtk_widget_get_style( fsFileSelect );
- dpixmap=gdk_pixmap_colormap_create_from_xpm_d( fsFileSelect->window,fsColorMap,&dmask,&style->bg[GTK_STATE_NORMAL],(gchar **)dir_xpm );
- fpixmap=gdk_pixmap_colormap_create_from_xpm_d( fsFileSelect->window,fsColorMap,&fmask,&style->bg[GTK_STATE_NORMAL],(gchar **)file_xpm );
+
pixmap=dpixmap; mask=dmask;
str[0][0]=NULL; str[0][1]=(gchar *)malloc( 3 );
- strcpy( str[0][1],"." );
- gtk_clist_append( GTK_CLIST( list ),str[0] ); gtk_clist_set_pixmap( GTK_CLIST( list ),0,0,pixmap,mask );
- strcpy( str[0][1],".." );
- gtk_clist_append( GTK_CLIST( list ),str[0] ); gtk_clist_set_pixmap( GTK_CLIST( list ),1,0,pixmap,mask );
+ strcpy( str[0][1],"." ); gtk_clist_append( GTK_CLIST( list ),str[0] ); gtk_clist_set_pixmap( GTK_CLIST( list ),0,0,pixmap,mask );
+ strcpy( str[0][1],".." ); gtk_clist_append( GTK_CLIST( list ),str[0] ); gtk_clist_set_pixmap( GTK_CLIST( list ),1,0,pixmap,mask );
free( str[0][0] );
- glob( "*",GLOB_NOSORT,NULL,&gg );
+ glob( "*",0,NULL,&gg );
// glob( ".*",GLOB_NOSORT | GLOB_APPEND,NULL,&gg );
for( i=0;i<gg.gl_pathc;i++ )
{
- if( !strcmp( gg.gl_pathv[i],"." ) || !strcmp( gg.gl_pathv[i],".." ) ) continue;
stat( gg.gl_pathv[i],&fs );
- if( S_ISDIR( fs.st_mode ) )
- {
- str[0][1]=(gchar *)malloc( strlen( gg.gl_pathv[i] ) + 2 );
- strcpy( str[0][1],"" );
- strcat( str[0][1],gg.gl_pathv[i] );
- pixmap=dpixmap; mask=dmask;
- gtk_clist_append( GTK_CLIST( list ),str[0] );
- gtk_clist_set_pixmap( GTK_CLIST( list ),c,0,pixmap,mask );
- free( str[0][1] );
- c++;
- }
+ if( !S_ISDIR( fs.st_mode ) ) continue;
+
+ str[0][1]=(gchar *)malloc( strlen( gg.gl_pathv[i] ) + 1 );
+ strcpy( str[0][1],gg.gl_pathv[i] );
+ pixmap=dpixmap; mask=dmask;
+ gtk_clist_append( GTK_CLIST( list ),str[0] );
+ gtk_clist_set_pixmap( GTK_CLIST( list ),c++,0,pixmap,mask );
+ free( str[0][1] );
}
globfree( &gg );
- glob( fsFilter,GLOB_NOSORT,NULL,&gg );
+
+ glob( fsFilter,0,NULL,&gg );
+
+#if 0
+ if ( !strcmp( fsFilter,"*" ) )
+ {
+ char * f = strdup( fsFilter );
+ int i;
+ for( i=0;i<strlen( f );i++ )
+ if ( ( f[i] >= 'A' )&&( f[i] <= 'Z' ) ) f[i]+=32;
+ glob( f,GLOB_APPEND,NULL,&gg );
+
+ for( i=0;i<strlen( f );i++ )
+ if ( ( f[i] >= 'a' )&&( f[i] <= 'z' ) ) f[i]-=32;
+ glob( f,GLOB_APPEND,NULL,&gg );
+ free( f );
+ }
+#endif
+
// glob( ".*",GLOB_NOSORT | GLOB_APPEND,NULL,&gg );
pixmap=fpixmap; mask=fmask;
for( i=0;i<gg.gl_pathc;i++ )
{
- if( !strcmp( gg.gl_pathv[i],"." ) || !strcmp( gg.gl_pathv[i],".." ) ) continue;
stat( gg.gl_pathv[i],&fs );
if( S_ISDIR( fs.st_mode ) ) continue;
- str[0][1]=(gchar *)malloc( strlen( gg.gl_pathv[i] ) + 2 );
- strcpy( str[0][1],"" ); strcat( str[0][1],gg.gl_pathv[i] );
+
+ str[0][1]=(gchar *)malloc( strlen( gg.gl_pathv[i] ) + 1 );
+ strcpy( str[0][1],gg.gl_pathv[i] );
gtk_clist_append( GTK_CLIST( list ),str[0] );
- gtk_clist_set_pixmap( GTK_CLIST( list ),c,0,pixmap,mask );
+ gtk_clist_set_pixmap( GTK_CLIST( list ),c++,0,pixmap,mask );
free( str[0][1] );
- c++;
}
globfree( &gg );
- gtk_clist_set_sort_type( GTK_CLIST( list ),GTK_SORT_ASCENDING );
- gtk_clist_set_compare_func( GTK_CLIST( list ),NULL );
- gtk_clist_set_sort_column( GTK_CLIST( list ),1 );
- gtk_clist_sort( GTK_CLIST( list ) );
gtk_clist_set_column_width( GTK_CLIST( list ),0,17 );
gtk_clist_select_row( GTK_CLIST( list ),0,1 );
gtk_widget_show( list );
}
+void ShowFileSelect( int type )
+{
+ int i;
+ if ( gtkVisibleFileSelect ) gtk_widget_hide( FileSelect );
+ fsType=type;
+ switch ( type )
+ {
+ case fsVideoSelector:
+ fsMessage=evFileLoaded;
+ gtk_window_set_title( GTK_WINDOW( fsFileSelect ),MSGTR_FileSelect );
+ fsList_items=NULL;
+ for( i=0;i<fsNumberOfVideoFilterNames + 1;i++ )
+ fsList_items=g_list_append( fsList_items,fsVideoFilterNames[i][0] );
+ gtk_combo_set_popdown_strings( GTK_COMBO( List ),fsList_items );
+ g_list_free( fsList_items );
+ gtk_entry_set_text( GTK_ENTRY( fsFilterCombo ),fsVideoFilterNames[fsNumberOfVideoFilterNames][0] );
+ break;
+ case fsSubtitleSelector:
+ gtk_window_set_title( GTK_WINDOW( fsFileSelect ),MSGTR_SubtitleSelect );
+ fsList_items=NULL;
+ for( i=0;i<fsNumberOfSubtitleFilterNames + 1;i++ )
+ fsList_items=g_list_append( fsList_items,fsSubtitleFilterNames[i][0] );
+ gtk_combo_set_popdown_strings( GTK_COMBO( List ),fsList_items );
+ g_list_free( fsList_items );
+ gtk_entry_set_text( GTK_ENTRY( fsFilterCombo ),fsSubtitleFilterNames[fsNumberOfSubtitleFilterNames][0] );
+ break;
+ case fsOtherSelector:
+ gtk_window_set_title( GTK_WINDOW( fsFileSelect ),MSGTR_OtherSelect );
+ fsList_items=NULL;
+ for( i=0;i<fsNumberOfSubtitleFilterNames + 1;i++ )
+ fsList_items=g_list_append( fsList_items,fsOtherFilterNames[i][0] );
+ gtk_combo_set_popdown_strings( GTK_COMBO( List ),fsList_items );
+ g_list_free( fsList_items );
+ gtk_entry_set_text( GTK_ENTRY( fsFilterCombo ),fsOtherFilterNames[fsNumberOfOtherFilterNames][0] );
+ break;
+ }
+ gtk_widget_show( FileSelect );
+ gtkVisibleFileSelect=1;
+}
+
void HideFileSelect( void )
{
gtk_widget_hide( fsFileSelect );
@@ -138,83 +211,74 @@ void HideFileSelect( void )
void fs_fsFileSelect_destroy( GtkObject * object,gpointer user_data )
{ HideFileSelect(); }
-void fs_combo_entry1_activate( GtkEditable * editable,gpointer user_data )
+void fs_fsFilterCombo_activate( GtkEditable * editable,gpointer user_data )
{
- unsigned char * str;
-
- str=gtk_entry_get_text( GTK_ENTRY(user_data ) );
- gtk_clist_clear( GTK_CLIST( fsFNameList ) );
- if( fsFilter ) free( fsFilter );
- if( ( fsFilter=(unsigned char *)malloc( strlen( str ) + 1 ) ) == NULL )
- {
- dbprintf( 0,"[gtk] not enough memory.\n" );
- exit( 0 );
- }
- strcpy( fsFilter,str );
- CheckDir( fsFNameList,(unsigned char *)get_current_dir_name() );
+ strcpy( fsFilter,gtk_entry_get_text( GTK_ENTRY( user_data ) ) );
+ CheckDir( fsFNameList,get_current_dir_name() );
}
-void fs_combo_entry1_changed( GtkEditable * editable,gpointer user_data )
+void fs_fsFilterCombo_changed( GtkEditable * editable,gpointer user_data )
{
- unsigned char * str;
- int i;
+ char * str;
+ int i;
str=gtk_entry_get_text( GTK_ENTRY(user_data ) );
-
- for( i=0;i<fsLastFilterNames+1;i++ )
+
+ switch ( fsType )
{
- if( !strcmp( str,fsFilterNames[i][0] ) )
- {
- if( fsFilter ) free( fsFilter );
- if( ( fsFilter=(unsigned char *)malloc( 6 ) ) == NULL )
- {
- dbprintf( 0,"[gtk] not enough memory.\n" );
- exit( 0 );
- }
- strcpy( fsFilter,fsFilterNames[i][1] );
- }
+ case fsVideoSelector:
+ for( i=0;i<fsNumberOfVideoFilterNames+1;i++ )
+ if( !strcmp( str,fsVideoFilterNames[i][0] ) )
+ {
+ strcpy( fsFilter,fsVideoFilterNames[i][1] );
+ CheckDir( fsFNameList,get_current_dir_name() );
+ break;
+ }
+ break;
+ case fsSubtitleSelector:
+ for( i=0;i<fsNumberOfSubtitleFilterNames+1;i++ )
+ if( !strcmp( str,fsSubtitleFilterNames[i][0] ) )
+ {
+ strcpy( fsFilter,fsSubtitleFilterNames[i][1] );
+ CheckDir( fsFNameList,get_current_dir_name() );
+ break;
+ }
+ break;
+ case fsOtherSelector:
+ for( i=0;i<fsNumberOfOtherFilterNames+1;i++ )
+ if( !strcmp( str,fsOtherFilterNames[i][0] ) )
+ {
+ strcpy( fsFilter,fsOtherFilterNames[i][1] );
+ CheckDir( fsFNameList,get_current_dir_name() );
+ break;
+ }
+ break;
}
- gtk_clist_clear( GTK_CLIST( fsFNameList ) );
- CheckDir( fsFNameList,(unsigned char *)get_current_dir_name() );
}
-void fs_fsComboEntry2_activate( GtkEditable * editable,gpointer user_data )
+void fs_fsPathCombo_activate( GtkEditable * editable,gpointer user_data )
{
unsigned char * str;
str=gtk_entry_get_text( GTK_ENTRY( user_data ) );
- if ( chdir( str ) != -1 )
- {
- gtk_clist_clear( GTK_CLIST( fsFNameList ) );
- CheckDir( fsFNameList,(unsigned char *)get_current_dir_name() );
- }
+ if ( chdir( str ) != -1 ) CheckDir( fsFNameList,get_current_dir_name() );
}
-void fs_fsComboEntry2_changed( GtkEditable * editable,gpointer user_data )
+void fs_fsPathCombo_changed( GtkEditable * editable,gpointer user_data )
{
unsigned char * str;
str=gtk_entry_get_text( GTK_ENTRY( user_data ) );
fsPressed=2;
-// if (
-// tmp=(unsigned char *)malloc( strlen( fsSelectedDirectory ) + 5 );
-// strcpy( tmp,fsSelectedDirectory ); strcat( tmp,"/*" );
-// fprintf( stderr,"str: %s\n",tmp );
-// free( tmp );
- if ( chdir( str ) != -1 )
- {
- gtk_clist_clear( GTK_CLIST( fsFNameList ) );
- CheckDir( fsFNameList,(unsigned char *)get_current_dir_name() );
- }
+ if ( chdir( str ) != -1 ) CheckDir( fsFNameList,get_current_dir_name() );
}
void fs_Up_released( GtkButton * button,gpointer user_data )
{
chdir( ".." );
fsSelectedFile=fsThatDir;
- gtk_clist_clear( GTK_CLIST( user_data ) );
- CheckDir( fsFNameList,(unsigned char *)get_current_dir_name() );
- gtk_entry_set_text( GTK_ENTRY( fsComboEntry2 ),(unsigned char *)get_current_dir_name() );
+ CheckDir( fsFNameList,get_current_dir_name() );
+ gtk_entry_set_text( GTK_ENTRY( fsPathCombo ),(unsigned char *)get_current_dir_name() );
return;
}
@@ -238,9 +302,8 @@ void fs_Ok_released( GtkButton * button,gpointer user_data )
{
chdir( fsSelectedFile );
fsSelectedFile=fsThatDir;
- if( fsFNameList != NULL ) gtk_clist_clear( GTK_CLIST( fsFNameList ) );
- CheckDir( fsFNameList,(unsigned char *)get_current_dir_name() );
- gtk_entry_set_text( GTK_ENTRY( fsComboEntry2 ),(unsigned char *)get_current_dir_name() );
+ CheckDir( fsFNameList,get_current_dir_name() );
+ gtk_entry_set_text( GTK_ENTRY( fsPathCombo ),(unsigned char *)get_current_dir_name() );
return;
}
@@ -250,18 +313,18 @@ void fs_Ok_released( GtkButton * button,gpointer user_data )
{
case 1:
fsSelectedDirectory=(unsigned char *)get_current_dir_name();
- printf("[gtk-fs] 1-fsSelectedFile: %s\n",fsSelectedFile);
- #ifdef DEBUG
- dbprintf( 1,"[gtk-fs] fsSelectedFile: %s\n",fsSelectedFile );
- #endif
+// printf("[gtk-fs] 1-fsSelectedFile: %s\n",fsSelectedFile);
+// #ifdef DEBUG
+// dbprintf( 1,"[gtk-fs] fsSelectedFile: %s\n",fsSelectedFile );
+// #endif
break;
case 2:
- str=gtk_entry_get_text( GTK_ENTRY( fsComboEntry2 ) );
+ str=gtk_entry_get_text( GTK_ENTRY( fsPathCombo ) );
fsSelectedFile=str;
- printf("[gtk-fs] 2-fsSelectedFile: '%s' \n",fsSelectedFile);
- #ifdef DEBUG
- dbprintf( 1,"[gtk-fs] fsSelectedFile: %s\n",fsSelectedFile );
- #endif
+// printf("[gtk-fs] 2-fsSelectedFile: '%s' \n",fsSelectedFile);
+// #ifdef DEBUG
+// dbprintf( 1,"[gtk-fs] fsSelectedFile: %s\n",fsSelectedFile );
+// #endif
if ( !fsFileExist( fsSelectedFile ) ) return;
fsSelectedDirectory=fsSelectedFile;
size=strlen( fsSelectedDirectory );
@@ -274,16 +337,33 @@ void fs_Ok_released( GtkButton * button,gpointer user_data )
break;
}
}
- printf("[gtk-fs-xxx] fsSelectedFile: '%s' \n",fsSelectedFile);
- printf("[gtk-fs-xxx] fsSelectedDirectory: '%s' \n",fsSelectedDirectory);
+// printf("[gtk-fs-xxx] fsSelectedFile: '%s' \n",fsSelectedFile);
+// printf("[gtk-fs-xxx] fsSelectedDirectory: '%s' \n",fsSelectedDirectory);
break;
}
- strcpy( gtkShMem->fs.dir,fsSelectedDirectory );
- strcpy( gtkShMem->fs.filename,fsSelectedFile );
-printf( "----gtk---> directory: %s\n",fsSelectedDirectory );
-printf( "----gtk---> filename: %s\n",fsSelectedFile );
-printf( "----gtksm-> directory: %s\n",gtkShMem->fs.dir );
-printf( "----gtksm-> filename: %s\n",gtkShMem->fs.filename );
+// printf( "----gtk---> directory: %s\n",fsSelectedDirectory );
+// printf( "----gtk---> filename: %s\n",fsSelectedFile );
+ switch ( fsType )
+ {
+ case fsVideoSelector:
+ strcpy( gtkShMem->fs.dir,fsSelectedDirectory );
+ strcpy( gtkShMem->fs.filename,fsSelectedFile );
+// printf( "----gtksm-> directory: %s\n",gtkShMem->fs.dir );
+// printf( "----gtksm-> filename: %s\n",gtkShMem->fs.filename );
+ gtkSendMessage( evFileLoaded );
+ break;
+ case fsSubtitleSelector:
+ strcpy( gtkShMem->fs.subtitlename,fsSelectedDirectory );
+ strcat( gtkShMem->fs.subtitlename,"/" );
+ strcat( gtkShMem->fs.subtitlename,fsSelectedFile );
+ gtkSendMessage( evSubtitleLoaded );
+ break;
+ case fsOtherSelector:
+ strcpy( gtkShMem->fs.otherfilename,fsSelectedDirectory );
+ strcat( gtkShMem->fs.subtitlename,"/" );
+ strcat( gtkShMem->fs.otherfilename,fsSelectedFile );
+ break;
+ }
item=fsTopList_items;
while( item )
{
@@ -295,7 +375,6 @@ printf( "----gtksm-> filename: %s\n",gtkShMem->fs.filename );
fsTopList_items=g_list_prepend( fsTopList_items,(gchar *)get_current_dir_name() );
gtk_combo_set_popdown_strings( GTK_COMBO( user_data ),fsTopList_items );
}
- gtkSendMessage( evFileLoaded );
}
void fs_Cancel_released( GtkButton * button,gpointer user_data )
@@ -303,7 +382,7 @@ void fs_Cancel_released( GtkButton * button,gpointer user_data )
void fs_fsFNameList_select_row( GtkWidget * widget,gint row,gint column,GdkEventButton *bevent,gpointer user_data )
{
- gtk_clist_get_text( GTK_CLIST(widget ),row,1,&fsSelectedFile ); fsSelectedFile++;
+ gtk_clist_get_text( GTK_CLIST(widget ),row,1,&fsSelectedFile );
fsPressed=1;
if( !bevent ) return;
if( bevent->type == GDK_2BUTTON_PRESS ) gtk_button_released( GTK_BUTTON( fsOk ) );
@@ -340,29 +419,15 @@ GtkWidget * create_FileSelect( void )
GtkWidget * fsFNameListWindow;
GtkWidget * label1;
GtkWidget * hseparator2;
- GtkWidget * List;
- GtkWidget * combo_entry1;
GtkWidget * hseparator3;
GtkWidget * hbuttonbox3;
int i;
-// GtkWidget * okpixmapwid,*uppixmapwid,*cancelpixmapwid;
-// GdkPixmap * okpixmap,*uppixmap,*cancelpixmap;
-// GdkBitmap * okmask,*upmask,*cancelmask;
-// GtkStyle * okstyle,*upstyle,*cancelstyle;
-
GtkWidget * uppixmapwid;
GdkPixmap * uppixmap;
GdkBitmap * upmask;
GtkStyle * upstyle;
- if( ( fsFilter=(unsigned char *)malloc( 3 ) ) == NULL )
- {
- dbprintf( 0,"[gtk] not enough memory.\n" );
- exit( 0 );
- }
- strcpy( fsFilter,"*" );
-
fsFileSelect=gtk_window_new( GTK_WINDOW_DIALOG );
gtk_widget_set_name( fsFileSelect,"fsFileSelect" );
gtk_object_set_data( GTK_OBJECT( fsFileSelect ),"fsFileSelect",fsFileSelect );
@@ -374,6 +439,10 @@ GtkWidget * create_FileSelect( void )
gtk_window_set_policy( GTK_WINDOW( fsFileSelect ),FALSE,FALSE,TRUE );
fsColorMap=gdk_colormap_get_system();
+ style=gtk_widget_get_style( fsFileSelect );
+ dpixmap=gdk_pixmap_colormap_create_from_xpm_d( fsFileSelect->window,fsColorMap,&dmask,&style->bg[GTK_STATE_NORMAL],(gchar **)dir_xpm );
+ fpixmap=gdk_pixmap_colormap_create_from_xpm_d( fsFileSelect->window,fsColorMap,&fmask,&style->bg[GTK_STATE_NORMAL],(gchar **)file_xpm );
+
FSFrame=gtk_frame_new( NULL );
gtk_widget_set_name( FSFrame,"FSFrame" );
gtk_widget_ref( FSFrame );
@@ -444,12 +513,12 @@ GtkWidget * create_FileSelect( void )
fsTopList_items=g_list_append( fsTopList_items,"/" );
gtk_combo_set_popdown_strings( GTK_COMBO( fsCombo4 ),fsTopList_items );
- fsComboEntry2=GTK_COMBO( fsCombo4 )->entry;
- gtk_widget_set_name( fsComboEntry2,"fsComboEntry2" );
- gtk_widget_ref( fsComboEntry2 );
- gtk_object_set_data_full( GTK_OBJECT( fsFileSelect ),"fsComboEntry2",fsComboEntry2,( GtkDestroyNotify ) gtk_widget_unref );
- gtk_widget_show( fsComboEntry2 );
- gtk_widget_set_usize( fsComboEntry2,-2,20 );
+ fsPathCombo=GTK_COMBO( fsCombo4 )->entry;
+ gtk_widget_set_name( fsPathCombo,"fsPathCombo" );
+ gtk_widget_ref( fsPathCombo );
+ gtk_object_set_data_full( GTK_OBJECT( fsFileSelect ),"fsPathCombo",fsPathCombo,( GtkDestroyNotify ) gtk_widget_unref );
+ gtk_widget_show( fsPathCombo );
+ gtk_widget_set_usize( fsPathCombo,-2,20 );
vseparator1=gtk_vseparator_new();
gtk_widget_set_name( vseparator1,"vseparator1" );
@@ -508,7 +577,7 @@ GtkWidget * create_FileSelect( void )
gtk_clist_set_selection_mode( GTK_CLIST( fsFNameList ),GTK_SELECTION_BROWSE );
gtk_clist_column_titles_hide( GTK_CLIST( fsFNameList ) );
gtk_clist_set_shadow_type( GTK_CLIST( fsFNameList ),GTK_SHADOW_ETCHED_OUT );
- CheckDir( fsFNameList,(unsigned char *)get_current_dir_name() );
+ CheckDir( fsFNameList,get_current_dir_name() );
label1=gtk_label_new( "label1" );
gtk_widget_set_name( label1,"label1" );
@@ -536,18 +605,19 @@ GtkWidget * create_FileSelect( void )
gtk_box_pack_start( GTK_BOX( vbox4 ),List,FALSE,FALSE,0 );
gtk_widget_set_usize( List,-2,20 );
fsList_items=NULL;
- for( i=0;i<fsLastFilterNames + 1;i++ )
- fsList_items=g_list_append( fsList_items,fsFilterNames[i][0] );
+ for( i=0;i<fsNumberOfVideoFilterNames + 1;i++ )
+ fsList_items=g_list_append( fsList_items,fsVideoFilterNames[i][0] );
gtk_combo_set_popdown_strings( GTK_COMBO( List ),fsList_items );
g_list_free( fsList_items );
- combo_entry1=GTK_COMBO( List )->entry;
- gtk_widget_set_name( combo_entry1,"combo_entry1" );
- gtk_widget_ref( combo_entry1 );
- gtk_object_set_data_full( GTK_OBJECT( fsFileSelect ),"combo_entry1",combo_entry1,
+ fsFilterCombo=GTK_COMBO( List )->entry;
+ gtk_widget_set_name( fsFilterCombo,"fsFilterCombo" );
+ gtk_widget_ref( fsFilterCombo );
+ gtk_object_set_data_full( GTK_OBJECT( fsFileSelect ),"fsFilterCombo",fsFilterCombo,
( GtkDestroyNotify ) gtk_widget_unref );
- gtk_widget_show( combo_entry1 );
- gtk_entry_set_text( GTK_ENTRY( combo_entry1 ),fsFilterNames[fsLastFilterNames][0] );
+ gtk_widget_show( fsFilterCombo );
+ gtk_entry_set_editable (GTK_ENTRY( fsFilterCombo ),FALSE );
+ gtk_entry_set_text( GTK_ENTRY( fsFilterCombo ),fsVideoFilterNames[fsNumberOfVideoFilterNames][0] );
hseparator3=gtk_hseparator_new();
gtk_widget_set_name( hseparator3,"hseparator3" );
@@ -570,15 +640,6 @@ GtkWidget * create_FileSelect( void )
gtk_button_box_set_child_size( GTK_BUTTON_BOX( hbuttonbox3 ),85,20 );
gtk_button_box_set_child_ipadding( GTK_BUTTON_BOX( hbuttonbox3 ),0,0 );
-// okstyle=gtk_widget_get_style( fsFileSelect );
-// okpixmap=gdk_pixmap_colormap_create_from_xpm_d( fsFileSelect->window,fsColorMap,&okmask,&okstyle->bg[GTK_STATE_NORMAL],(gchar **)ok_xpm );
-// okpixmapwid=gtk_pixmap_new( okpixmap,okmask );
-// gtk_widget_show( okpixmapwid );
-// fsOk=gtk_button_new();
-// gtk_container_add( GTK_CONTAINER(fsOk ),okpixmapwid );
-// gtk_container_add( GTK_CONTAINER( hbuttonbox3 ),fsOk );
-// gtk_widget_show( fsOk );
-
fsOk=gtk_button_new_with_label( MSGTR_Ok );
gtk_widget_set_name( fsOk,MSGTR_Ok );
gtk_widget_ref( fsOk );
@@ -586,16 +647,6 @@ GtkWidget * create_FileSelect( void )
gtk_container_add( GTK_CONTAINER( hbuttonbox3 ),fsOk );
gtk_widget_show( fsOk );
-// cancelstyle=gtk_widget_get_style( fsFileSelect );
-// cancelpixmap=gdk_pixmap_colormap_create_from_xpm_d( fsFileSelect->window,fsColorMap,&cancelmask,&cancelstyle->bg[GTK_STATE_NORMAL],(gchar **)cancel_xpm );
-// cancelpixmapwid=gtk_pixmap_new( cancelpixmap,cancelmask );
-// gtk_widget_show( cancelpixmapwid );
-// fsCancel=gtk_button_new();
-// gtk_widget_show( fsCancel );
-// gtk_container_add( GTK_CONTAINER( fsCancel ),cancelpixmapwid );
-// gtk_container_add( GTK_CONTAINER( hbuttonbox3 ),fsCancel );
-// gtk_widget_show( fsCancel );
-
fsCancel=gtk_button_new_with_label( MSGTR_Cancel );
gtk_widget_set_name( fsCancel,MSGTR_Cancel );
gtk_widget_ref( fsCancel );
@@ -609,18 +660,18 @@ GtkWidget * create_FileSelect( void )
gtk_signal_connect( GTK_OBJECT( fsFileSelect ),"key_release_event",
GTK_SIGNAL_FUNC( on_FileSelect_key_release_event ),
NULL );
- gtk_signal_connect( GTK_OBJECT( combo_entry1 ),"changed",
- GTK_SIGNAL_FUNC( fs_combo_entry1_changed ),
- combo_entry1 );
- gtk_signal_connect( GTK_OBJECT( combo_entry1 ),"activate",
- GTK_SIGNAL_FUNC( fs_combo_entry1_activate ),
- combo_entry1 );
- gtk_signal_connect( GTK_OBJECT( fsComboEntry2 ),"changed",
- GTK_SIGNAL_FUNC( fs_fsComboEntry2_changed ),
- fsComboEntry2 );
- gtk_signal_connect( GTK_OBJECT( fsComboEntry2 ),"activate",
- GTK_SIGNAL_FUNC( fs_fsComboEntry2_activate ),
- fsComboEntry2 );
+ gtk_signal_connect( GTK_OBJECT( fsFilterCombo ),"changed",
+ GTK_SIGNAL_FUNC( fs_fsFilterCombo_changed ),
+ fsFilterCombo );
+ gtk_signal_connect( GTK_OBJECT( fsFilterCombo ),"activate",
+ GTK_SIGNAL_FUNC( fs_fsFilterCombo_activate ),
+ fsFilterCombo );
+ gtk_signal_connect( GTK_OBJECT( fsPathCombo ),"changed",
+ GTK_SIGNAL_FUNC( fs_fsPathCombo_changed ),
+ fsPathCombo );
+ gtk_signal_connect( GTK_OBJECT( fsPathCombo ),"activate",
+ GTK_SIGNAL_FUNC( fs_fsPathCombo_activate ),
+ fsPathCombo );
gtk_signal_connect( GTK_OBJECT( fsUp ),"released",
GTK_SIGNAL_FUNC( fs_Up_released ),
fsFNameList );
diff --git a/Gui/mplayer/gtk/fs.h b/Gui/mplayer/gtk/fs.h
index b7449a448d..660dff8b4e 100644
--- a/Gui/mplayer/gtk/fs.h
+++ b/Gui/mplayer/gtk/fs.h
@@ -3,7 +3,13 @@
#include <gtk/gtk.h>
+#define fsVideoSelector 0
+#define fsSubtitleSelector 1
+#define fsOtherSelector 2
+
extern void HideFileSelect( void );
+extern void ShowFileSelect( int type );
+
extern GtkWidget * create_FileSelect( void );
#endif
diff --git a/Gui/mplayer/mw.h b/Gui/mplayer/mw.h
index 9958ad2f8a..75326d42ec 100644
--- a/Gui/mplayer/mw.h
+++ b/Gui/mplayer/mw.h
@@ -264,6 +264,10 @@ NoPause:
mplMainRender=1;
gtkSendMessage( evLoad );
break;
+ case evLoadSubtitle:
+ mplMainRender=1;
+ gtkSendMessage( evLoadSubtitle );
+ break;
case evPrev:
IZE("evPrev");
mplMainRender=1;
@@ -560,6 +564,8 @@ void mplMainKeyHandle( int State,int Type,int Key )
case wsF: msg=evFullScreen; break;
case wsl:
case wsL: msg=evLoad; break;
+ case wsu:
+ case wsU: msg=evLoadSubtitle; break;
case wsm:
case wsM: msg=evMute; break;
case wss:
diff --git a/Gui/mplayer/play.h b/Gui/mplayer/play.h
index 37b9949d36..1694313346 100644
--- a/Gui/mplayer/play.h
+++ b/Gui/mplayer/play.h
@@ -77,6 +77,9 @@ typedef struct
char Filename[4096];
int FilenameChanged;
+ char Subtitlename[4096];
+ int SubtitleChanged;
+
int SkinChange;
} mplCommStruct;
diff --git a/Gui/mplayer/psignal.c b/Gui/mplayer/psignal.c
index 49511b2736..3df63f7a9a 100644
--- a/Gui/mplayer/psignal.c
+++ b/Gui/mplayer/psignal.c
@@ -7,6 +7,7 @@
#include "widgets.h"
#include "play.h"
+#include "gtk/fs.h"
#include "../app.h"
@@ -83,16 +84,26 @@ void gtkSigHandler( int s )
gtkShow( evPlayList );
break;
case evLoad:
+ ShowFileSelect( fsVideoSelector );
+#if 0
if ( gtkVisibleFileSelect ) gtk_widget_hide( FileSelect );
gtk_widget_show( FileSelect );
gtkVisibleFileSelect=1;
gtkShow( evPlay );
+#endif
break;
case evFirstLoad:
+ ShowFileSelect( fsVideoSelector );
+#if 0
if ( gtkVisibleFileSelect ) gtk_widget_hide( FileSelect );
gtk_widget_show( FileSelect );
gtkVisibleFileSelect=1;
gtkShow( evFirstLoad );
+#endif
+ break;
+ case evLoadSubtitle:
+ ShowFileSelect( fsSubtitleSelector );
+// gtkShow( evPlay );
break;
case evMessageBox:
gtk_label_set_text( gtkMessageBoxText,(char *)gtkShMem->mb.str );
@@ -189,6 +200,11 @@ void mplMainSigHandler( int s )
mplShMem->StreamType=STREAMTYPE_FILE;
if ( mplMainAutoPlay ) mplGeneralTimer=1;
break;
+ case evSubtitleLoaded:
+ printf("*** gtkShMem->fs.subtitlename == '%s' \n",gtkShMem->fs.subtitlename );
+ strcpy( mplShMem->Subtitlename,gtkShMem->fs.subtitlename );
+ mplShMem->SubtitleChanged=1;
+ break;
case evShowPopUpMenu:
fprintf( stderr,"[psignal] PopUpMenu: %d param: %d\n",gtkShMem->popupmenu,gtkShMem->popupmenuparam );
mplMiddleMenu=1; mplGeneralTimer=1;
diff --git a/Gui/mplayer/widgets.h b/Gui/mplayer/widgets.h
index d82e7cafb9..0d55f1168c 100644
--- a/Gui/mplayer/widgets.h
+++ b/Gui/mplayer/widgets.h
@@ -19,6 +19,8 @@ typedef struct
{
char dir[ 2048 ];
char filename[ 2048 ];
+ char subtitlename[ 4096 ];
+ char otherfilename[ 4096 ];
} gtkFileSelectorStruct;
typedef struct