Mercurial > mplayer.hg
changeset 8048:c3d790e4c600
rename
author | pontscho |
---|---|
date | Sat, 02 Nov 2002 17:25:06 +0000 (2002-11-02) |
parents | e7d1cde8ad0e |
children | a3bc99f2860d |
files | Gui/mplayer/menu.c Gui/mplayer/menu.h Gui/mplayer/mw.c Gui/mplayer/mw.h Gui/mplayer/sw.c Gui/mplayer/sw.h |
diffstat | 6 files changed, 911 insertions(+), 911 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Gui/mplayer/menu.c Sat Nov 02 17:25:06 2002 +0000 @@ -0,0 +1,146 @@ + +unsigned char * mplMenuDrawBuffer = NULL; +int mplMenuRender = 1; +int mplMenuItem = -1; +int mplOldMenuItem = -1; +int mplMenuX,mplMenuY; + +void mplHideMenu( int mx,int my,int w ); + +void mplMenuDraw( wsParamDisplay ) +{ + uint32_t * buf = NULL; + uint32_t * drw = NULL; + int x,y,tmp; + + if ( !appMPlayer.menuBase.Bitmap.Image ) return; + if ( !mplMenuRender && !appMPlayer.menuWindow.Visible ) return; + + if ( mplMenuRender || mplMenuItem != mplOldMenuItem ) + { + memcpy( mplMenuDrawBuffer,appMPlayer.menuBase.Bitmap.Image,appMPlayer.menuBase.Bitmap.ImageSize ); +// --- + if ( mplMenuItem != -1 ) + { + buf=(uint32_t *)mplMenuDrawBuffer; + drw=(uint32_t *)appMPlayer.menuSelected.Bitmap.Image; + for ( y=appMPlayer.MenuItems[ mplMenuItem ].y; y < appMPlayer.MenuItems[ mplMenuItem ].y + appMPlayer.MenuItems[ mplMenuItem ].height; y++ ) + for ( x=appMPlayer.MenuItems[ mplMenuItem ].x; x < appMPlayer.MenuItems[ mplMenuItem ].x + appMPlayer.MenuItems[ mplMenuItem ].width; x++ ) + { + tmp=drw[ y * appMPlayer.menuSelected.width + x ]; + if ( tmp != 0x00ff00ff ) buf[ y * appMPlayer.menuBase.width + x ]=tmp; + } + } + mplOldMenuItem=mplMenuItem; +// --- + wsConvert( &appMPlayer.menuWindow,mplMenuDrawBuffer,appMPlayer.menuBase.Bitmap.ImageSize ); + mplMenuRender=0; + } + wsPutImage( &appMPlayer.menuWindow ); +} + +void mplMenuMouseHandle( int X,int Y,int RX,int RY ) +{ + int x,y,i; + + if ( !appMPlayer.menuBase.Bitmap.Image ) return; + + mplMenuItem=-1; + x=RX - appMPlayer.menuWindow.X; + y=RY - appMPlayer.menuWindow.Y; + if ( ( x < 0 ) || ( y < 0 ) || ( x > appMPlayer.menuBase.width ) || ( y > appMPlayer.menuBase.height ) ) + { + wsPostRedisplay( &appMPlayer.menuWindow ); + return; + } + + for( i=0;i<=appMPlayer.NumberOfMenuItems;i++ ) + { + if ( wgIsRect( x,y, + appMPlayer.MenuItems[i].x,appMPlayer.MenuItems[i].y, + appMPlayer.MenuItems[i].x+appMPlayer.MenuItems[i].width,appMPlayer.MenuItems[i].y+appMPlayer.MenuItems[i].height ) ) { mplMenuItem=i; break; } + } + wsPostRedisplay( &appMPlayer.menuWindow ); +} + +void mplShowMenu( int mx,int my ) +{ + int x,y; + + if ( !appMPlayer.menuBase.Bitmap.Image ) return; + + x=mx; + if ( x + appMPlayer.menuWindow.Width > wsMaxX ) x=wsMaxX - appMPlayer.menuWindow.Width - 1; + y=my; + if ( y + appMPlayer.menuWindow.Height > wsMaxY ) y=wsMaxY - appMPlayer.menuWindow.Height - 1; + + mplMenuX=x; mplMenuY=y; + + mplMenuItem = 0; + + wsMoveWindow( &appMPlayer.menuWindow,False,x,y ); + wsMoveTopWindow( wsDisplay,appMPlayer.menuWindow.WindowID ); + wsSetLayer( wsDisplay,appMPlayer.menuWindow.WindowID,1 ); + mplMenuRender=1; + wsVisibleWindow( &appMPlayer.menuWindow,wsShowWindow ); + wsPostRedisplay( &appMPlayer.menuWindow ); +} + +void mplHideMenu( int mx,int my,int w ) +{ + int x,y,i=mplMenuItem; + + if ( !appMPlayer.menuBase.Bitmap.Image ) return; + + x=mx-mplMenuX; + y=my-mplMenuY; +// x=RX - appMPlayer.menuWindow.X; +// y=RY - appMPlayer.menuWindow.Y; + + wsVisibleWindow( &appMPlayer.menuWindow,wsHideWindow ); + + if ( ( x < 0 ) || ( y < 0 ) ) return; + +// printf( "---------> %d %d,%d\n",i,x,y ); +// printf( "--------> mi: %d,%d %dx%d\n",appMPlayer.MenuItems[i].x,appMPlayer.MenuItems[i].y,appMPlayer.MenuItems[i].width,appMPlayer.MenuItems[i].height ); + if ( wgIsRect( x,y, + appMPlayer.MenuItems[i].x,appMPlayer.MenuItems[i].y, + appMPlayer.MenuItems[i].x+appMPlayer.MenuItems[i].width, + appMPlayer.MenuItems[i].y+appMPlayer.MenuItems[i].height ) ) + { + mplEventHandling( appMPlayer.MenuItems[i].msg,(float)w ); + } +} + +void mplMenuInit( void ) +{ + + if ( !appMPlayer.menuBase.Bitmap.Image ) return; + + appMPlayer.menuBase.x=0; + appMPlayer.menuBase.y=0; + + if ( ( mplMenuDrawBuffer = calloc( 1,appMPlayer.menuBase.Bitmap.ImageSize ) ) == NULL ) + { + #ifdef DEBUG + mp_msg( MSGT_GPLAYER,MSGL_DBG2,"[menu.h] %s",MSGTR_NEMFMR ); + #endif + gtkMessageBox( GTK_MB_FATAL,MSGTR_NEMFMR ); + return; + } + + wsCreateWindow( &appMPlayer.menuWindow, + appMPlayer.menuBase.x,appMPlayer.menuBase.y,appMPlayer.menuBase.width,appMPlayer.menuBase.height, + wsNoBorder,wsShowMouseCursor|wsHandleMouseButton|wsHandleMouseMove,wsOverredirect|wsHideFrame|wsMaxSize|wsMinSize|wsHideWindow,"MPlayer menu" ); + + wsSetShape( &appMPlayer.menuWindow,appMPlayer.menuBase.Mask.Image ); + + #ifdef DEBUG + mp_msg( MSGT_GPLAYER,MSGL_DBG2,"[menu.h] menu: 0x%x\n",(int)appMPlayer.menuWindow.WindowID ); + #endif + + appMPlayer.menuWindow.ReDraw=mplMenuDraw; +// appMPlayer.menuWindow.MouseHandler=mplMenuMouseHandle; +// appMPlayer.menuWindow.KeyHandler=mplMainKeyHandle; + mplMenuRender=1; wsPostRedisplay( &appMPlayer.menuWindow ); +}
--- a/Gui/mplayer/menu.h Sat Nov 02 17:22:09 2002 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,146 +0,0 @@ - -unsigned char * mplMenuDrawBuffer = NULL; -int mplMenuRender = 1; -int mplMenuItem = -1; -int mplOldMenuItem = -1; -int mplMenuX,mplMenuY; - -void mplHideMenu( int mx,int my,int w ); - -void mplMenuDraw( wsParamDisplay ) -{ - uint32_t * buf = NULL; - uint32_t * drw = NULL; - int x,y,tmp; - - if ( !appMPlayer.menuBase.Bitmap.Image ) return; - if ( !mplMenuRender && !appMPlayer.menuWindow.Visible ) return; - - if ( mplMenuRender || mplMenuItem != mplOldMenuItem ) - { - memcpy( mplMenuDrawBuffer,appMPlayer.menuBase.Bitmap.Image,appMPlayer.menuBase.Bitmap.ImageSize ); -// --- - if ( mplMenuItem != -1 ) - { - buf=(uint32_t *)mplMenuDrawBuffer; - drw=(uint32_t *)appMPlayer.menuSelected.Bitmap.Image; - for ( y=appMPlayer.MenuItems[ mplMenuItem ].y; y < appMPlayer.MenuItems[ mplMenuItem ].y + appMPlayer.MenuItems[ mplMenuItem ].height; y++ ) - for ( x=appMPlayer.MenuItems[ mplMenuItem ].x; x < appMPlayer.MenuItems[ mplMenuItem ].x + appMPlayer.MenuItems[ mplMenuItem ].width; x++ ) - { - tmp=drw[ y * appMPlayer.menuSelected.width + x ]; - if ( tmp != 0x00ff00ff ) buf[ y * appMPlayer.menuBase.width + x ]=tmp; - } - } - mplOldMenuItem=mplMenuItem; -// --- - wsConvert( &appMPlayer.menuWindow,mplMenuDrawBuffer,appMPlayer.menuBase.Bitmap.ImageSize ); - mplMenuRender=0; - } - wsPutImage( &appMPlayer.menuWindow ); -} - -void mplMenuMouseHandle( int X,int Y,int RX,int RY ) -{ - int x,y,i; - - if ( !appMPlayer.menuBase.Bitmap.Image ) return; - - mplMenuItem=-1; - x=RX - appMPlayer.menuWindow.X; - y=RY - appMPlayer.menuWindow.Y; - if ( ( x < 0 ) || ( y < 0 ) || ( x > appMPlayer.menuBase.width ) || ( y > appMPlayer.menuBase.height ) ) - { - wsPostRedisplay( &appMPlayer.menuWindow ); - return; - } - - for( i=0;i<=appMPlayer.NumberOfMenuItems;i++ ) - { - if ( wgIsRect( x,y, - appMPlayer.MenuItems[i].x,appMPlayer.MenuItems[i].y, - appMPlayer.MenuItems[i].x+appMPlayer.MenuItems[i].width,appMPlayer.MenuItems[i].y+appMPlayer.MenuItems[i].height ) ) { mplMenuItem=i; break; } - } - wsPostRedisplay( &appMPlayer.menuWindow ); -} - -void mplShowMenu( int mx,int my ) -{ - int x,y; - - if ( !appMPlayer.menuBase.Bitmap.Image ) return; - - x=mx; - if ( x + appMPlayer.menuWindow.Width > wsMaxX ) x=wsMaxX - appMPlayer.menuWindow.Width - 1; - y=my; - if ( y + appMPlayer.menuWindow.Height > wsMaxY ) y=wsMaxY - appMPlayer.menuWindow.Height - 1; - - mplMenuX=x; mplMenuY=y; - - mplMenuItem = 0; - - wsMoveWindow( &appMPlayer.menuWindow,False,x,y ); - wsMoveTopWindow( wsDisplay,appMPlayer.menuWindow.WindowID ); - wsSetLayer( wsDisplay,appMPlayer.menuWindow.WindowID,1 ); - mplMenuRender=1; - wsVisibleWindow( &appMPlayer.menuWindow,wsShowWindow ); - wsPostRedisplay( &appMPlayer.menuWindow ); -} - -void mplHideMenu( int mx,int my,int w ) -{ - int x,y,i=mplMenuItem; - - if ( !appMPlayer.menuBase.Bitmap.Image ) return; - - x=mx-mplMenuX; - y=my-mplMenuY; -// x=RX - appMPlayer.menuWindow.X; -// y=RY - appMPlayer.menuWindow.Y; - - wsVisibleWindow( &appMPlayer.menuWindow,wsHideWindow ); - - if ( ( x < 0 ) || ( y < 0 ) ) return; - -// printf( "---------> %d %d,%d\n",i,x,y ); -// printf( "--------> mi: %d,%d %dx%d\n",appMPlayer.MenuItems[i].x,appMPlayer.MenuItems[i].y,appMPlayer.MenuItems[i].width,appMPlayer.MenuItems[i].height ); - if ( wgIsRect( x,y, - appMPlayer.MenuItems[i].x,appMPlayer.MenuItems[i].y, - appMPlayer.MenuItems[i].x+appMPlayer.MenuItems[i].width, - appMPlayer.MenuItems[i].y+appMPlayer.MenuItems[i].height ) ) - { - mplEventHandling( appMPlayer.MenuItems[i].msg,(float)w ); - } -} - -void mplMenuInit( void ) -{ - - if ( !appMPlayer.menuBase.Bitmap.Image ) return; - - appMPlayer.menuBase.x=0; - appMPlayer.menuBase.y=0; - - if ( ( mplMenuDrawBuffer = calloc( 1,appMPlayer.menuBase.Bitmap.ImageSize ) ) == NULL ) - { - #ifdef DEBUG - mp_msg( MSGT_GPLAYER,MSGL_DBG2,"[menu.h] %s",MSGTR_NEMFMR ); - #endif - gtkMessageBox( GTK_MB_FATAL,MSGTR_NEMFMR ); - return; - } - - wsCreateWindow( &appMPlayer.menuWindow, - appMPlayer.menuBase.x,appMPlayer.menuBase.y,appMPlayer.menuBase.width,appMPlayer.menuBase.height, - wsNoBorder,wsShowMouseCursor|wsHandleMouseButton|wsHandleMouseMove,wsOverredirect|wsHideFrame|wsMaxSize|wsMinSize|wsHideWindow,"MPlayer menu" ); - - wsSetShape( &appMPlayer.menuWindow,appMPlayer.menuBase.Mask.Image ); - - #ifdef DEBUG - mp_msg( MSGT_GPLAYER,MSGL_DBG2,"[menu.h] menu: 0x%x\n",(int)appMPlayer.menuWindow.WindowID ); - #endif - - appMPlayer.menuWindow.ReDraw=mplMenuDraw; -// appMPlayer.menuWindow.MouseHandler=mplMenuMouseHandle; -// appMPlayer.menuWindow.KeyHandler=mplMainKeyHandle; - mplMenuRender=1; wsPostRedisplay( &appMPlayer.menuWindow ); -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Gui/mplayer/mw.c Sat Nov 02 17:25:06 2002 +0000 @@ -0,0 +1,691 @@ + +// main window + +#include "../../libmpdemux/stream.h" +#include "../../mixer.h" +#include "../../libvo/sub.h" +#include "../../mplayer.h" + +extern unsigned int GetTimerMS( void ); + +unsigned char * mplDrawBuffer = NULL; +int mplMainRender = 1; + +int mplMainAutoPlay = 0; +int mplMiddleMenu = 0; + +int mainVisible = 1; + +int boxMoved = 0; +int sx = 0,sy = 0; +int i,pot = 0; + +inline void TranslateFilename( int c,char * tmp ) +{ + int i; + switch ( guiIntfStruct.StreamType ) + { + case STREAMTYPE_STREAM: + strcpy( tmp,guiIntfStruct.Filename ); + break; + case STREAMTYPE_FILE: + if ( ( guiIntfStruct.Filename )&&( guiIntfStruct.Filename[0] ) ) + { + if ( strrchr( guiIntfStruct.Filename,'/' ) ) strcpy( tmp,strrchr( guiIntfStruct.Filename,'/' ) + 1 ); + else strcpy( tmp,guiIntfStruct.Filename ); + if ( tmp[strlen( tmp ) - 4] == '.' ) tmp[strlen( tmp ) - 4]=0; + if ( tmp[strlen( tmp ) - 5] == '.' ) tmp[strlen( tmp ) - 5]=0; + } else strcpy( tmp,MSGTR_NoFileLoaded ); + break; +#ifdef USE_DVDREAD + case STREAMTYPE_DVD: + if ( guiIntfStruct.DVD.current_chapter ) sprintf( tmp,MSGTR_Chapter,guiIntfStruct.DVD.current_chapter ); + else strcat( tmp,MSGTR_NoChapter ); + break; +#endif +#ifdef HAVE_VCD + case STREAMTYPE_VCD: + sprintf( tmp,MSGTR_VCDTrack,guiIntfStruct.Track ); + break; +#endif + default: strcpy( tmp,MSGTR_NoMediaOpened ); + } + if ( c ) + { + for ( i=0;i < (int)strlen( tmp );i++ ) + { + int t=0; + if ( c == 1 ) { if ( ( tmp[i] >= 'A' )&&( tmp[i] <= 'Z' ) ) t=32; } + if ( c == 2 ) { if ( ( tmp[i] >= 'a' )&&( tmp[i] <= 'z' ) ) t=-32; } + tmp[i]=(char)( tmp[i] + t ); + } + } +} + +char * Translate( char * str ) +{ + static char trbuf[512]; + char tmp[512]; + int i,c; + int t; + memset( trbuf,0,512 ); + memset( tmp,0,128 ); + for ( c=0,i=0;i < (int)strlen( str );i++ ) + { + if ( str[i] != '$' ) { trbuf[c++]=str[i]; trbuf[c]=0; } + else + { + switch ( str[++i] ) + { + case 't': sprintf( tmp,"%02d",guiIntfStruct.Track ); strcat( trbuf,tmp ); break; + case 'o': TranslateFilename( 0,tmp ); strcat( trbuf,tmp ); break; + case 'f': TranslateFilename( 1,tmp ); strcat( trbuf,tmp ); break; + case 'F': TranslateFilename( 2,tmp ); strcat( trbuf,tmp ); break; + case '6': t=guiIntfStruct.LengthInSec; goto calclengthhhmmss; + case '1': t=guiIntfStruct.TimeSec; +calclengthhhmmss: + sprintf( tmp,"%02d:%02d:%02d",t/3600,t/60%60,t%60 ); strcat( trbuf,tmp ); + break; + case '7': t=guiIntfStruct.LengthInSec; goto calclengthmmmmss; + case '2': t=guiIntfStruct.TimeSec; +calclengthmmmmss: + sprintf( tmp,"%04d:%02d",t/60,t%60 ); strcat( trbuf,tmp ); + break; + case '3': sprintf( tmp,"%02d",guiIntfStruct.TimeSec / 3600 ); strcat( trbuf,tmp ); break; + case '4': sprintf( tmp,"%02d",( ( guiIntfStruct.TimeSec / 60 ) % 60 ) ); strcat( trbuf,tmp ); break; + case '5': sprintf( tmp,"%02d",guiIntfStruct.TimeSec % 60 ); strcat( trbuf,tmp ); break; + case '8': sprintf( tmp,"%01d:%02d:%02d",guiIntfStruct.TimeSec / 3600,( guiIntfStruct.TimeSec / 60 ) % 60,guiIntfStruct.TimeSec % 60 ); strcat( trbuf,tmp ); break; + case 'v': sprintf( tmp,"%3.2f%%",guiIntfStruct.Volume ); strcat( trbuf,tmp ); break; + case 'V': sprintf( tmp,"%3.1f",guiIntfStruct.Volume ); strcat( trbuf,tmp ); break; + case 'b': sprintf( tmp,"%3.2f%%",guiIntfStruct.Balance ); strcat( trbuf,tmp ); break; + case 'B': sprintf( tmp,"%3.1f",guiIntfStruct.Balance ); strcat( trbuf,tmp ); break; + case 'd': sprintf( tmp,"%d",guiIntfStruct.FrameDrop ); strcat( trbuf,tmp ); break; + case 's': if ( guiIntfStruct.Playing == 0 ) strcat( trbuf,"s" ); break; + case 'l': if ( guiIntfStruct.Playing == 1 ) strcat( trbuf,"p" ); break; + case 'e': if ( guiIntfStruct.Playing == 2 ) strcat( trbuf,"e" ); break; + case 'a': + if ( muted ) { strcat( trbuf,"n" ); break; } + switch ( guiIntfStruct.AudioType ) + { + case 0: strcat( trbuf,"n" ); break; + case 1: strcat( trbuf,"m" ); break; + case 2: strcat( trbuf,"t" ); break; + } + break; + case 'T': + switch ( guiIntfStruct.StreamType ) + { + case STREAMTYPE_FILE: strcat( trbuf,"f" ); break; +#ifdef HAVE_VCD + case STREAMTYPE_VCD: strcat( trbuf,"v" ); break; +#endif + case STREAMTYPE_STREAM: strcat( trbuf,"u" ); break; +#ifdef USE_DVDREAD + case STREAMTYPE_DVD: strcat( trbuf,"d" ); break; +#endif + default: strcat( trbuf," " ); break; + } + break; + case '$': strcat( trbuf,"$" ); break; + default: continue; + } + c=strlen( trbuf ); + } + } + return trbuf; +} + +inline void PutImage( txSample * bf,int x,int y,int max,int ofs ) +{ + int i=0,ix,iy; + uint32_t * buf = NULL; + uint32_t * drw = NULL; + uint32_t tmp; + + if ( ( !bf )||( bf->Image == NULL ) ) return; + + i=( bf->Width * ( bf->Height / max ) ) * ofs; + buf=(uint32_t *)mplDrawBuffer; + drw=(uint32_t *)bf->Image; + + for ( iy=y;iy < (int)(y+bf->Height / max);iy++ ) + for ( ix=x;ix < (int)(x+bf->Width);ix++ ) + { + tmp=drw[i++]; + if ( tmp != 0x00ff00ff ) + buf[ iy*appMPlayer.main.Bitmap.Width+ix ]=tmp; + } +} + +void mplMainDraw( wsParamDisplay ) +{ + wItem * item; + txSample * image = NULL; + int i; + + if ( appMPlayer.mainWindow.State == wsWindowClosed ) exit_player( MSGTR_Exit_quit ); + + if ( appMPlayer.mainWindow.Visible == wsWindowNotVisible || + !mainVisible ) return; +// !appMPlayer.mainWindow.Mapped ) return; + + btnModify( evSetMoviePosition,guiIntfStruct.Position ); + btnModify( evSetVolume,guiIntfStruct.Volume ); + + if ( mplMainRender && appMPlayer.mainWindow.State == wsWindowExpose ) + { + memcpy( mplDrawBuffer,appMPlayer.main.Bitmap.Image,appMPlayer.main.Bitmap.ImageSize ); + for( i=0;i < appMPlayer.NumberOfItems + 1;i++ ) + { + item=&appMPlayer.Items[i]; + switch( item->type ) + { + case itButton: + PutImage( &item->Bitmap,item->x,item->y,3,item->pressed ); + break; + case itPotmeter: + PutImage( &item->Bitmap,item->x,item->y,item->phases,( item->phases - 1 ) * ( item->value / 100.0f ) ); + break; + case itHPotmeter: + PutImage( &item->Bitmap,item->x,item->y,item->phases,item->phases * ( item->value / 100.0f ) ); + PutImage( &item->Mask,item->x + (int)( ( item->width - item->psx ) * item->value / 100.0f ),item->y,3,item->pressed ); + break; + case itSLabel: + image=fntRender( item->fontid,0,item->width,"%s",item->label ); + goto drawrenderedtext; + case itDLabel: + { + char * t = Translate( item->label ); + int l = fntTextWidth( item->fontid,t ); + image=fntRender( item->fontid,(GetTimerMS() / 20)%(l?l:item->width),item->width,"%s",t ); + } +drawrenderedtext: + if ( image ) + { + PutImage( image,item->x,item->y,1,0 ); + if ( image->Image ) free( image->Image ); + free( image ); + } + break; + } + } + wsConvert( &appMPlayer.mainWindow,mplDrawBuffer,appMPlayer.main.Bitmap.ImageSize ); + mplMainRender=0; + } + wsPutImage( &appMPlayer.mainWindow ); +// XFlush( wsDisplay ); +} + +extern void exit_player(char* how); +extern int audio_id; +extern int dvdsub_id; +extern char * dvd_device; +extern int vcd_track; +extern char * cdrom_device; +extern int osd_visible; + +void mplEventHandling( int msg,float param ) +{ + int j; + + switch( msg ) + { +// --- user events + case evExit: + exit_player( "Exit" ); + break; + + case evPlayNetwork: + if ( guiIntfStruct.Subtitlename ) { free( guiIntfStruct.Subtitlename ); guiIntfStruct.Subtitlename=NULL; } + if ( guiIntfStruct.AudioFile ) { free( guiIntfStruct.AudioFile ); guiIntfStruct.AudioFile=NULL; } + guiIntfStruct.StreamType=STREAMTYPE_STREAM; + goto play; + case evSetURL: + gtkShow( evPlayNetwork,NULL ); + break; + +#ifdef HAVE_VCD + case evSetVCDTrack: + guiIntfStruct.Track=(int)param; + case evPlayVCD: + gtkSet( gtkClearStruct,0,(void *)guiALL ); + guiIntfStruct.StreamType=STREAMTYPE_VCD; + goto play; +#endif +#ifdef USE_DVDREAD + case evPlayDVD: + guiIntfStruct.DVD.current_title=1; + guiIntfStruct.DVD.current_chapter=1; + guiIntfStruct.DVD.current_angle=1; +play_dvd_2: + gtkSet( gtkClearStruct,0,(void *)(guiALL - guiDVD) ); + guiIntfStruct.StreamType=STREAMTYPE_DVD; +#endif + case evPlay: + case evPlaySwitchToPause: +play: + + if ( ( msg == evPlaySwitchToPause )&&( guiIntfStruct.Playing == 2 ) ) goto NoPause; + + vcd_track=0; + dvd_title=0; + + if ( gtkSet( gtkGetCurrPlItem,0,NULL ) &&( guiIntfStruct.StreamType == STREAMTYPE_FILE ) ) + { + plItem * next = gtkSet( gtkGetCurrPlItem,0,NULL ); + plLastPlayed=next; + guiSetDF( guiIntfStruct.Filename,next->path,next->name ); + guiIntfStruct.StreamType=STREAMTYPE_FILE; + guiIntfStruct.FilenameChanged=1; + gfree( (void **)&guiIntfStruct.AudioFile ); + gfree( (void **)&guiIntfStruct.Subtitlename ); + } + + switch ( guiIntfStruct.StreamType ) + { + case STREAMTYPE_STREAM: + case STREAMTYPE_FILE: + gtkSet( gtkClearStruct,0,(void *)(guiALL - guiFilenames) ); + break; +#ifdef HAVE_VCD + case STREAMTYPE_VCD: + gtkSet( gtkClearStruct,0,(void *)(guiALL - guiVCD - guiFilenames) ); + if ( !cdrom_device ) cdrom_device=DEFAULT_CDROM_DEVICE; + mplSetFileName( NULL,cdrom_device,STREAMTYPE_VCD ); + if ( guiIntfStruct.Playing != 2 ) + { + if ( !guiIntfStruct.Track ) + { + if ( guiIntfStruct.VCDTracks == 1 ) guiIntfStruct.Track=1; + else guiIntfStruct.Track=2; + } + vcd_track=guiIntfStruct.Track; + guiIntfStruct.DiskChanged=1; + } + break; +#endif +#ifdef USE_DVDREAD + case STREAMTYPE_DVD: + gtkSet( gtkClearStruct,0,(void *)(guiALL - guiDVD - guiFilenames) ); + if ( !dvd_device ) dvd_device=DEFAULT_DVD_DEVICE; + mplSetFileName( NULL,dvd_device,STREAMTYPE_DVD ); + if ( guiIntfStruct.Playing != 2 ) + { + dvd_title=guiIntfStruct.DVD.current_title; + dvd_angle=guiIntfStruct.DVD.current_angle; + dvd_chapter=guiIntfStruct.DVD.current_chapter; + guiIntfStruct.DiskChanged=1; + } + break; +#endif + } + mplPlay(); + break; +#ifdef USE_DVDREAD + case evSetDVDSubtitle: + dvdsub_id=(int)param; + goto play_dvd_2; + break; + case evSetDVDAudio: + audio_id=(int)param; + goto play_dvd_2; + break; + case evSetDVDChapter: + guiIntfStruct.DVD.current_chapter=(int)param; + goto play_dvd_2; + break; + case evSetDVDTitle: + guiIntfStruct.DVD.current_title=(int)param; + guiIntfStruct.DVD.current_chapter=1; + guiIntfStruct.DVD.current_angle=1; + goto play_dvd_2; + break; +#endif + + case evPause: + case evPauseSwitchToPlay: +NoPause: + mplPause(); + break; + + case evStop: guiIntfStruct.Playing=guiSetStop; break; + + case evLoadPlay: + mplMainAutoPlay=1; +// guiIntfStruct.StreamType=STREAMTYPE_FILE; + case evLoad: + gtkSet( gtkDelPl,0,NULL ); + gtkShow( evLoad,NULL ); + break; + case evLoadSubtitle: gtkShow( evLoadSubtitle,NULL ); break; + case evDropSubtitle: + gfree( (void **)&guiIntfStruct.Subtitlename ); + guiLoadSubtitle( NULL ); + break; + case evLoadAudioFile: gtkShow( evLoadAudioFile,NULL ); break; + case evPrev: mplPrev(); break; + case evNext: mplNext(); break; + + case evPlayList: gtkShow( evPlayList,NULL ); break; + case evSkinBrowser: gtkShow( evSkinBrowser,skinName ); break; + case evAbout: gtkShow( evAbout,NULL ); break; + case evPreferences: gtkShow( evPreferences,NULL ); break; + case evEqualizer: gtkShow( evEqualizer,NULL ); break; + + case evForward1min: mplRelSeek( 60 ); break; + case evBackward1min: mplRelSeek( -60 ); break; + case evForward10sec: mplRelSeek( 10 ); break; + case evBackward10sec: mplRelSeek( -10 ); break; + case evSetMoviePosition: mplAbsSeek( param ); break; + + case evIncVolume: vo_x11_putkey( wsGrayMul ); break; + case evDecVolume: vo_x11_putkey( wsGrayDiv ); break; + case evMute: mixer_mute(); break; + + case evSetVolume: + guiIntfStruct.Volume=param; + goto set_volume; + case evSetBalance: + guiIntfStruct.Balance=param; +set_volume: + { + float l = guiIntfStruct.Volume * ( ( 100.0 - guiIntfStruct.Balance ) / 50.0 ); + float r = guiIntfStruct.Volume * ( ( guiIntfStruct.Balance ) / 50.0 ); + if ( l > guiIntfStruct.Volume ) l=guiIntfStruct.Volume; + if ( r > guiIntfStruct.Volume ) r=guiIntfStruct.Volume; +// printf( "!!! v: %.2f b: %.2f -> %.2f x %.2f\n",guiIntfStruct.Volume,guiIntfStruct.Balance,l,r ); + mixer_setvolume( l,r ); + } +#ifdef USE_OSD + if ( osd_level ) + { + osd_visible=vo_mouse_timer_const; + vo_osd_progbar_type=OSD_VOLUME; + vo_osd_progbar_value=( ( guiIntfStruct.Volume ) * 256.0 ) / 100.0; + vo_osd_changed( OSDTYPE_PROGBAR ); + } +#endif + break; + + + case evIconify: + switch ( (int)param ) + { + case 0: wsIconify( appMPlayer.mainWindow ); break; + case 1: wsIconify( appMPlayer.subWindow ); break; + } + break; + case evDoubleSize: + if ( guiIntfStruct.Playing ) + { + appMPlayer.subWindow.isFullScreen=True; + appMPlayer.subWindow.OldX=( wsMaxX - guiIntfStruct.MovieWidth * 2 ) / 2; + appMPlayer.subWindow.OldY=( wsMaxY - guiIntfStruct.MovieHeight * 2 ) / 2; + appMPlayer.subWindow.OldWidth=guiIntfStruct.MovieWidth * 2; appMPlayer.subWindow.OldHeight=guiIntfStruct.MovieHeight * 2; + wsFullScreen( &appMPlayer.subWindow ); + vo_fs=0; + } + break; + case evNormalSize: + if ( guiIntfStruct.Playing ) + { + appMPlayer.subWindow.isFullScreen=True; + appMPlayer.subWindow.OldX=( wsMaxX - guiIntfStruct.MovieWidth ) / 2; + appMPlayer.subWindow.OldY=( wsMaxY - guiIntfStruct.MovieHeight ) / 2; + appMPlayer.subWindow.OldWidth=guiIntfStruct.MovieWidth; appMPlayer.subWindow.OldHeight=guiIntfStruct.MovieHeight; + wsFullScreen( &appMPlayer.subWindow ); + vo_fs=0; + break; + } else if ( !appMPlayer.subWindow.isFullScreen ) break; + case evFullScreen: + for ( j=0;j<appMPlayer.NumberOfItems + 1;j++ ) + { + if ( appMPlayer.Items[j].msg == evFullScreen ) + { + appMPlayer.Items[j].tmp=!appMPlayer.Items[j].tmp; + appMPlayer.Items[j].pressed=appMPlayer.Items[j].tmp; + } + } + mplFullScreen(); + break; + + case evSetAspect: + switch ( (int)param ) + { + case 2: movie_aspect=16.0f / 9.0f; break; + case 3: movie_aspect=4.0f / 3.0f; break; + case 4: movie_aspect=2.35; break; + case 1: + default: movie_aspect=-1; + } + wsClearWindow( appMPlayer.subWindow ); +#ifdef USE_DVDREAD + if ( guiIntfStruct.StreamType == STREAMTYPE_DVD ) goto play_dvd_2; + else +#endif + guiIntfStruct.FilenameChanged=1; + break; + +// --- timer events + case evRedraw: + mplMainRender=1; + wsPostRedisplay( &appMPlayer.mainWindow ); + mplRedrawTimer=mplRedrawTimerConst; + break; +// --- system events +#ifdef MP_DEBUG + case evNone: + mp_msg( MSGT_GPLAYER,MSGL_STATUS,"[mw] event none received.\n" ); + break; + default: + mp_msg( MSGT_GPLAYER,MSGL_STATUS,"[mw] unknown event received ( %d,%.2f ).\n",msg,param ); + break; +#endif + } +} + +#define itPLMButton (itNULL - 1) +#define itPRMButton (itNULL - 2) + +void mplMainMouseHandle( int Button,int X,int Y,int RX,int RY ) +{ + static int itemtype = 0; + int i; + wItem * item = NULL; + float value = 0.0f; + + static int SelectedItem = -1; + int currentselected = -1; + + for ( i=0;i < appMPlayer.NumberOfItems + 1;i++ ) + if ( ( appMPlayer.Items[i].pressed != btnDisabled )&& + ( wgIsRect( X,Y,appMPlayer.Items[i].x,appMPlayer.Items[i].y,appMPlayer.Items[i].x+appMPlayer.Items[i].width,appMPlayer.Items[i].y+appMPlayer.Items[i].height ) ) ) + { currentselected=i; break; } + + switch ( Button ) + { + case wsPMMouseButton: + gtkShow( evHidePopUpMenu,NULL ); + mplShowMenu( RX,RY ); + itemtype=itPRMButton; + break; + case wsRMMouseButton: + mplHideMenu( RX,RY,0 ); + break; + + case wsPLMouseButton: + gtkShow( evHidePopUpMenu,NULL ); + sx=X; sy=Y; boxMoved=1; itemtype=itPLMButton; // if move the main window + SelectedItem=currentselected; + if ( SelectedItem == -1 ) break; // yeees, i'm move the fucking window + boxMoved=0; //mplMainRender=1; // No, not move the window, i'm pressed one button + item=&appMPlayer.Items[SelectedItem]; + itemtype=item->type; + item->pressed=btnPressed; + switch( item->type ) + { + case itButton: + if ( ( SelectedItem > -1 ) && + ( ( ( appMPlayer.Items[SelectedItem].msg == evPlaySwitchToPause && item->msg == evPauseSwitchToPlay ) ) || + ( ( appMPlayer.Items[SelectedItem].msg == evPauseSwitchToPlay && item->msg == evPlaySwitchToPause ) ) ) ) + { appMPlayer.Items[SelectedItem].pressed=btnDisabled; } + break; + } + break; + case wsRLMouseButton: + boxMoved=0; + item=&appMPlayer.Items[SelectedItem]; + item->pressed=btnReleased; + SelectedItem=-1; + if ( currentselected == - 1 ) { itemtype=0; break; } + value=0; + switch( itemtype ) + { + case itPotmeter: + case itHPotmeter: + btnModify( item->msg,(float)( X - item->x ) / item->width * 100.0f ); + mplEventHandling( item->msg,item->value ); + value=item->value; + break; + } + mplEventHandling( item->msg,value ); +// mplMainRender=1; + itemtype=0; + break; + + case wsPRMouseButton: + gtkShow( evShowPopUpMenu,NULL ); + break; + +// --- rolled mouse ... de szar :))) + case wsP5MouseButton: value=-2.5f; goto rollerhandled; + case wsP4MouseButton: value= 2.5f; +rollerhandled: + item=&appMPlayer.Items[currentselected]; + if ( ( item->type == itHPotmeter )||( item->type == itVPotmeter )||( item->type == itPotmeter ) ) + { + item->value+=value; + btnModify( item->msg,item->value ); + mplEventHandling( item->msg,item->value ); + } + break; + +// --- moving + case wsMoveMouse: + item=&appMPlayer.Items[SelectedItem]; + switch ( itemtype ) + { + case itPLMButton: + wsMoveWindow( &appMPlayer.mainWindow,False,RX - abs( sx ),RY - abs( sy ) ); + mplMainRender=0; + break; + case itPRMButton: + mplMenuMouseHandle( X,Y,RX,RY ); + break; + case itPotmeter: + item->value=(float)( X - item->x ) / item->width * 100.0f; + goto potihandled; + case itHPotmeter: + item->value=(float)( X - item->x ) / item->width * 100.0f; +potihandled: + if ( item->value > 100.0f ) item->value=100.0f; + if ( item->value < 0.0f ) item->value=0.0f; + mplEventHandling( item->msg,item->value ); + break; + } + break; + } +// if ( Button != wsMoveMouse ) wsPostRedisplay( &appMPlayer.mainWindow ); +} + +int keyPressed = 0; + +void mplMainKeyHandle( int KeyCode,int Type,int Key ) +{ + int msg = evNone; + + if ( Type != wsKeyPressed ) return; + + if ( !Key ) + { + switch ( KeyCode ) + { + case wsXFMMPrev: msg=evPrev; break; + case wsXFMMStop: msg=evStop; break; + case wsXFMMPlay: msg=evPlaySwitchToPause; break; + case wsXFMMNext: msg=evNext; break; + case wsXFMMVolUp: msg=evIncVolume; break; + case wsXFMMVolDown: msg=evDecVolume; break; + case wsXFMMMute: msg=evMute; break; + } + } + else + { + switch ( Key ) + { + case wsEnter: msg=evPlay; break; + case wsXF86LowerVolume: msg=evDecVolume; break; + case wsXF86RaiseVolume: msg=evIncVolume; break; + case wsXF86Mute: msg=evMute; break; + case wsXF86Play: msg=evPlaySwitchToPause; break; + case wsXF86Stop: msg=evStop; break; + case wsXF86Prev: msg=evPrev; break; + case wsXF86Next: msg=evNext; break; + case wsXF86Media: msg=evLoad; break; + + default: vo_x11_putkey( Key ); return; + } + } + if ( msg != evNone ) mplEventHandling( msg,0 ); +} + +/* this will be used to handle Drag&Drop files */ +void mplDandDHandler(int num,char** files) +{ + struct stat buf; + int f = 0; + + if (num <= 0) + return; + + /* clear playlist */ + gtkSet(gtkDelPl,0,NULL); + + /* now fill it with new items */ + for(f=0; f < num; f++){ + char* str = strdup( files[f] ); + plItem* item; + +#ifdef USE_ICONV + if ( strchr( str,'%' ) ) + { + char * tmp=gconvert_uri_to_filename( str ); + free( str ); str=tmp; + } +#endif + + if(stat(str,&buf) == 0 && S_ISDIR(buf.st_mode) == 0) { + /* this is not a directory so try to play it */ + printf("Received D&D %s\n",str); + item = calloc(1,sizeof(plItem)); + + /* FIXME: decompose file name ? */ + /* yes -- Pontscho */ + if ( strrchr( str,'/' ) ) + { + char * s = strrchr( str,'/' ); *s=0; s++; + item->name = gstrdup( s ); + item->path = gstrdup( str ); + } else { item->name = strdup(str); item->path = strdup(""); } + gtkSet(gtkAddPlItem,0,(void*)item); + } else { + printf("Received not a file: %s !\n",str); + } + free( str ); + } + + mplSetFileName( NULL,files[0],STREAMTYPE_FILE ); + if ( guiIntfStruct.Playing == 1 ) mplEventHandling( evStop,0 ); + mplEventHandling( evPlay,0 ); + +}
--- a/Gui/mplayer/mw.h Sat Nov 02 17:22:09 2002 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,691 +0,0 @@ - -// main window - -#include "../../libmpdemux/stream.h" -#include "../../mixer.h" -#include "../../libvo/sub.h" -#include "../../mplayer.h" - -extern unsigned int GetTimerMS( void ); - -unsigned char * mplDrawBuffer = NULL; -int mplMainRender = 1; - -int mplMainAutoPlay = 0; -int mplMiddleMenu = 0; - -int mainVisible = 1; - -int boxMoved = 0; -int sx = 0,sy = 0; -int i,pot = 0; - -inline void TranslateFilename( int c,char * tmp ) -{ - int i; - switch ( guiIntfStruct.StreamType ) - { - case STREAMTYPE_STREAM: - strcpy( tmp,guiIntfStruct.Filename ); - break; - case STREAMTYPE_FILE: - if ( ( guiIntfStruct.Filename )&&( guiIntfStruct.Filename[0] ) ) - { - if ( strrchr( guiIntfStruct.Filename,'/' ) ) strcpy( tmp,strrchr( guiIntfStruct.Filename,'/' ) + 1 ); - else strcpy( tmp,guiIntfStruct.Filename ); - if ( tmp[strlen( tmp ) - 4] == '.' ) tmp[strlen( tmp ) - 4]=0; - if ( tmp[strlen( tmp ) - 5] == '.' ) tmp[strlen( tmp ) - 5]=0; - } else strcpy( tmp,MSGTR_NoFileLoaded ); - break; -#ifdef USE_DVDREAD - case STREAMTYPE_DVD: - if ( guiIntfStruct.DVD.current_chapter ) sprintf( tmp,MSGTR_Chapter,guiIntfStruct.DVD.current_chapter ); - else strcat( tmp,MSGTR_NoChapter ); - break; -#endif -#ifdef HAVE_VCD - case STREAMTYPE_VCD: - sprintf( tmp,MSGTR_VCDTrack,guiIntfStruct.Track ); - break; -#endif - default: strcpy( tmp,MSGTR_NoMediaOpened ); - } - if ( c ) - { - for ( i=0;i < (int)strlen( tmp );i++ ) - { - int t=0; - if ( c == 1 ) { if ( ( tmp[i] >= 'A' )&&( tmp[i] <= 'Z' ) ) t=32; } - if ( c == 2 ) { if ( ( tmp[i] >= 'a' )&&( tmp[i] <= 'z' ) ) t=-32; } - tmp[i]=(char)( tmp[i] + t ); - } - } -} - -char * Translate( char * str ) -{ - static char trbuf[512]; - char tmp[512]; - int i,c; - int t; - memset( trbuf,0,512 ); - memset( tmp,0,128 ); - for ( c=0,i=0;i < (int)strlen( str );i++ ) - { - if ( str[i] != '$' ) { trbuf[c++]=str[i]; trbuf[c]=0; } - else - { - switch ( str[++i] ) - { - case 't': sprintf( tmp,"%02d",guiIntfStruct.Track ); strcat( trbuf,tmp ); break; - case 'o': TranslateFilename( 0,tmp ); strcat( trbuf,tmp ); break; - case 'f': TranslateFilename( 1,tmp ); strcat( trbuf,tmp ); break; - case 'F': TranslateFilename( 2,tmp ); strcat( trbuf,tmp ); break; - case '6': t=guiIntfStruct.LengthInSec; goto calclengthhhmmss; - case '1': t=guiIntfStruct.TimeSec; -calclengthhhmmss: - sprintf( tmp,"%02d:%02d:%02d",t/3600,t/60%60,t%60 ); strcat( trbuf,tmp ); - break; - case '7': t=guiIntfStruct.LengthInSec; goto calclengthmmmmss; - case '2': t=guiIntfStruct.TimeSec; -calclengthmmmmss: - sprintf( tmp,"%04d:%02d",t/60,t%60 ); strcat( trbuf,tmp ); - break; - case '3': sprintf( tmp,"%02d",guiIntfStruct.TimeSec / 3600 ); strcat( trbuf,tmp ); break; - case '4': sprintf( tmp,"%02d",( ( guiIntfStruct.TimeSec / 60 ) % 60 ) ); strcat( trbuf,tmp ); break; - case '5': sprintf( tmp,"%02d",guiIntfStruct.TimeSec % 60 ); strcat( trbuf,tmp ); break; - case '8': sprintf( tmp,"%01d:%02d:%02d",guiIntfStruct.TimeSec / 3600,( guiIntfStruct.TimeSec / 60 ) % 60,guiIntfStruct.TimeSec % 60 ); strcat( trbuf,tmp ); break; - case 'v': sprintf( tmp,"%3.2f%%",guiIntfStruct.Volume ); strcat( trbuf,tmp ); break; - case 'V': sprintf( tmp,"%3.1f",guiIntfStruct.Volume ); strcat( trbuf,tmp ); break; - case 'b': sprintf( tmp,"%3.2f%%",guiIntfStruct.Balance ); strcat( trbuf,tmp ); break; - case 'B': sprintf( tmp,"%3.1f",guiIntfStruct.Balance ); strcat( trbuf,tmp ); break; - case 'd': sprintf( tmp,"%d",guiIntfStruct.FrameDrop ); strcat( trbuf,tmp ); break; - case 's': if ( guiIntfStruct.Playing == 0 ) strcat( trbuf,"s" ); break; - case 'l': if ( guiIntfStruct.Playing == 1 ) strcat( trbuf,"p" ); break; - case 'e': if ( guiIntfStruct.Playing == 2 ) strcat( trbuf,"e" ); break; - case 'a': - if ( muted ) { strcat( trbuf,"n" ); break; } - switch ( guiIntfStruct.AudioType ) - { - case 0: strcat( trbuf,"n" ); break; - case 1: strcat( trbuf,"m" ); break; - case 2: strcat( trbuf,"t" ); break; - } - break; - case 'T': - switch ( guiIntfStruct.StreamType ) - { - case STREAMTYPE_FILE: strcat( trbuf,"f" ); break; -#ifdef HAVE_VCD - case STREAMTYPE_VCD: strcat( trbuf,"v" ); break; -#endif - case STREAMTYPE_STREAM: strcat( trbuf,"u" ); break; -#ifdef USE_DVDREAD - case STREAMTYPE_DVD: strcat( trbuf,"d" ); break; -#endif - default: strcat( trbuf," " ); break; - } - break; - case '$': strcat( trbuf,"$" ); break; - default: continue; - } - c=strlen( trbuf ); - } - } - return trbuf; -} - -inline void PutImage( txSample * bf,int x,int y,int max,int ofs ) -{ - int i=0,ix,iy; - uint32_t * buf = NULL; - uint32_t * drw = NULL; - uint32_t tmp; - - if ( ( !bf )||( bf->Image == NULL ) ) return; - - i=( bf->Width * ( bf->Height / max ) ) * ofs; - buf=(uint32_t *)mplDrawBuffer; - drw=(uint32_t *)bf->Image; - - for ( iy=y;iy < (int)(y+bf->Height / max);iy++ ) - for ( ix=x;ix < (int)(x+bf->Width);ix++ ) - { - tmp=drw[i++]; - if ( tmp != 0x00ff00ff ) - buf[ iy*appMPlayer.main.Bitmap.Width+ix ]=tmp; - } -} - -void mplMainDraw( wsParamDisplay ) -{ - wItem * item; - txSample * image = NULL; - int i; - - if ( appMPlayer.mainWindow.State == wsWindowClosed ) exit_player( MSGTR_Exit_quit ); - - if ( appMPlayer.mainWindow.Visible == wsWindowNotVisible || - !mainVisible ) return; -// !appMPlayer.mainWindow.Mapped ) return; - - btnModify( evSetMoviePosition,guiIntfStruct.Position ); - btnModify( evSetVolume,guiIntfStruct.Volume ); - - if ( mplMainRender && appMPlayer.mainWindow.State == wsWindowExpose ) - { - memcpy( mplDrawBuffer,appMPlayer.main.Bitmap.Image,appMPlayer.main.Bitmap.ImageSize ); - for( i=0;i < appMPlayer.NumberOfItems + 1;i++ ) - { - item=&appMPlayer.Items[i]; - switch( item->type ) - { - case itButton: - PutImage( &item->Bitmap,item->x,item->y,3,item->pressed ); - break; - case itPotmeter: - PutImage( &item->Bitmap,item->x,item->y,item->phases,( item->phases - 1 ) * ( item->value / 100.0f ) ); - break; - case itHPotmeter: - PutImage( &item->Bitmap,item->x,item->y,item->phases,item->phases * ( item->value / 100.0f ) ); - PutImage( &item->Mask,item->x + (int)( ( item->width - item->psx ) * item->value / 100.0f ),item->y,3,item->pressed ); - break; - case itSLabel: - image=fntRender( item->fontid,0,item->width,"%s",item->label ); - goto drawrenderedtext; - case itDLabel: - { - char * t = Translate( item->label ); - int l = fntTextWidth( item->fontid,t ); - image=fntRender( item->fontid,(GetTimerMS() / 20)%(l?l:item->width),item->width,"%s",t ); - } -drawrenderedtext: - if ( image ) - { - PutImage( image,item->x,item->y,1,0 ); - if ( image->Image ) free( image->Image ); - free( image ); - } - break; - } - } - wsConvert( &appMPlayer.mainWindow,mplDrawBuffer,appMPlayer.main.Bitmap.ImageSize ); - mplMainRender=0; - } - wsPutImage( &appMPlayer.mainWindow ); -// XFlush( wsDisplay ); -} - -extern void exit_player(char* how); -extern int audio_id; -extern int dvdsub_id; -extern char * dvd_device; -extern int vcd_track; -extern char * cdrom_device; -extern int osd_visible; - -void mplEventHandling( int msg,float param ) -{ - int j; - - switch( msg ) - { -// --- user events - case evExit: - exit_player( "Exit" ); - break; - - case evPlayNetwork: - if ( guiIntfStruct.Subtitlename ) { free( guiIntfStruct.Subtitlename ); guiIntfStruct.Subtitlename=NULL; } - if ( guiIntfStruct.AudioFile ) { free( guiIntfStruct.AudioFile ); guiIntfStruct.AudioFile=NULL; } - guiIntfStruct.StreamType=STREAMTYPE_STREAM; - goto play; - case evSetURL: - gtkShow( evPlayNetwork,NULL ); - break; - -#ifdef HAVE_VCD - case evSetVCDTrack: - guiIntfStruct.Track=(int)param; - case evPlayVCD: - gtkSet( gtkClearStruct,0,(void *)guiALL ); - guiIntfStruct.StreamType=STREAMTYPE_VCD; - goto play; -#endif -#ifdef USE_DVDREAD - case evPlayDVD: - guiIntfStruct.DVD.current_title=1; - guiIntfStruct.DVD.current_chapter=1; - guiIntfStruct.DVD.current_angle=1; -play_dvd_2: - gtkSet( gtkClearStruct,0,(void *)(guiALL - guiDVD) ); - guiIntfStruct.StreamType=STREAMTYPE_DVD; -#endif - case evPlay: - case evPlaySwitchToPause: -play: - - if ( ( msg == evPlaySwitchToPause )&&( guiIntfStruct.Playing == 2 ) ) goto NoPause; - - vcd_track=0; - dvd_title=0; - - if ( gtkSet( gtkGetCurrPlItem,0,NULL ) &&( guiIntfStruct.StreamType == STREAMTYPE_FILE ) ) - { - plItem * next = gtkSet( gtkGetCurrPlItem,0,NULL ); - plLastPlayed=next; - guiSetDF( guiIntfStruct.Filename,next->path,next->name ); - guiIntfStruct.StreamType=STREAMTYPE_FILE; - guiIntfStruct.FilenameChanged=1; - gfree( (void **)&guiIntfStruct.AudioFile ); - gfree( (void **)&guiIntfStruct.Subtitlename ); - } - - switch ( guiIntfStruct.StreamType ) - { - case STREAMTYPE_STREAM: - case STREAMTYPE_FILE: - gtkSet( gtkClearStruct,0,(void *)(guiALL - guiFilenames) ); - break; -#ifdef HAVE_VCD - case STREAMTYPE_VCD: - gtkSet( gtkClearStruct,0,(void *)(guiALL - guiVCD - guiFilenames) ); - if ( !cdrom_device ) cdrom_device=DEFAULT_CDROM_DEVICE; - mplSetFileName( NULL,cdrom_device,STREAMTYPE_VCD ); - if ( guiIntfStruct.Playing != 2 ) - { - if ( !guiIntfStruct.Track ) - { - if ( guiIntfStruct.VCDTracks == 1 ) guiIntfStruct.Track=1; - else guiIntfStruct.Track=2; - } - vcd_track=guiIntfStruct.Track; - guiIntfStruct.DiskChanged=1; - } - break; -#endif -#ifdef USE_DVDREAD - case STREAMTYPE_DVD: - gtkSet( gtkClearStruct,0,(void *)(guiALL - guiDVD - guiFilenames) ); - if ( !dvd_device ) dvd_device=DEFAULT_DVD_DEVICE; - mplSetFileName( NULL,dvd_device,STREAMTYPE_DVD ); - if ( guiIntfStruct.Playing != 2 ) - { - dvd_title=guiIntfStruct.DVD.current_title; - dvd_angle=guiIntfStruct.DVD.current_angle; - dvd_chapter=guiIntfStruct.DVD.current_chapter; - guiIntfStruct.DiskChanged=1; - } - break; -#endif - } - mplPlay(); - break; -#ifdef USE_DVDREAD - case evSetDVDSubtitle: - dvdsub_id=(int)param; - goto play_dvd_2; - break; - case evSetDVDAudio: - audio_id=(int)param; - goto play_dvd_2; - break; - case evSetDVDChapter: - guiIntfStruct.DVD.current_chapter=(int)param; - goto play_dvd_2; - break; - case evSetDVDTitle: - guiIntfStruct.DVD.current_title=(int)param; - guiIntfStruct.DVD.current_chapter=1; - guiIntfStruct.DVD.current_angle=1; - goto play_dvd_2; - break; -#endif - - case evPause: - case evPauseSwitchToPlay: -NoPause: - mplPause(); - break; - - case evStop: guiIntfStruct.Playing=guiSetStop; break; - - case evLoadPlay: - mplMainAutoPlay=1; -// guiIntfStruct.StreamType=STREAMTYPE_FILE; - case evLoad: - gtkSet( gtkDelPl,0,NULL ); - gtkShow( evLoad,NULL ); - break; - case evLoadSubtitle: gtkShow( evLoadSubtitle,NULL ); break; - case evDropSubtitle: - gfree( (void **)&guiIntfStruct.Subtitlename ); - guiLoadSubtitle( NULL ); - break; - case evLoadAudioFile: gtkShow( evLoadAudioFile,NULL ); break; - case evPrev: mplPrev(); break; - case evNext: mplNext(); break; - - case evPlayList: gtkShow( evPlayList,NULL ); break; - case evSkinBrowser: gtkShow( evSkinBrowser,skinName ); break; - case evAbout: gtkShow( evAbout,NULL ); break; - case evPreferences: gtkShow( evPreferences,NULL ); break; - case evEqualizer: gtkShow( evEqualizer,NULL ); break; - - case evForward1min: mplRelSeek( 60 ); break; - case evBackward1min: mplRelSeek( -60 ); break; - case evForward10sec: mplRelSeek( 10 ); break; - case evBackward10sec: mplRelSeek( -10 ); break; - case evSetMoviePosition: mplAbsSeek( param ); break; - - case evIncVolume: vo_x11_putkey( wsGrayMul ); break; - case evDecVolume: vo_x11_putkey( wsGrayDiv ); break; - case evMute: mixer_mute(); break; - - case evSetVolume: - guiIntfStruct.Volume=param; - goto set_volume; - case evSetBalance: - guiIntfStruct.Balance=param; -set_volume: - { - float l = guiIntfStruct.Volume * ( ( 100.0 - guiIntfStruct.Balance ) / 50.0 ); - float r = guiIntfStruct.Volume * ( ( guiIntfStruct.Balance ) / 50.0 ); - if ( l > guiIntfStruct.Volume ) l=guiIntfStruct.Volume; - if ( r > guiIntfStruct.Volume ) r=guiIntfStruct.Volume; -// printf( "!!! v: %.2f b: %.2f -> %.2f x %.2f\n",guiIntfStruct.Volume,guiIntfStruct.Balance,l,r ); - mixer_setvolume( l,r ); - } -#ifdef USE_OSD - if ( osd_level ) - { - osd_visible=vo_mouse_timer_const; - vo_osd_progbar_type=OSD_VOLUME; - vo_osd_progbar_value=( ( guiIntfStruct.Volume ) * 256.0 ) / 100.0; - vo_osd_changed( OSDTYPE_PROGBAR ); - } -#endif - break; - - - case evIconify: - switch ( (int)param ) - { - case 0: wsIconify( appMPlayer.mainWindow ); break; - case 1: wsIconify( appMPlayer.subWindow ); break; - } - break; - case evDoubleSize: - if ( guiIntfStruct.Playing ) - { - appMPlayer.subWindow.isFullScreen=True; - appMPlayer.subWindow.OldX=( wsMaxX - guiIntfStruct.MovieWidth * 2 ) / 2; - appMPlayer.subWindow.OldY=( wsMaxY - guiIntfStruct.MovieHeight * 2 ) / 2; - appMPlayer.subWindow.OldWidth=guiIntfStruct.MovieWidth * 2; appMPlayer.subWindow.OldHeight=guiIntfStruct.MovieHeight * 2; - wsFullScreen( &appMPlayer.subWindow ); - vo_fs=0; - } - break; - case evNormalSize: - if ( guiIntfStruct.Playing ) - { - appMPlayer.subWindow.isFullScreen=True; - appMPlayer.subWindow.OldX=( wsMaxX - guiIntfStruct.MovieWidth ) / 2; - appMPlayer.subWindow.OldY=( wsMaxY - guiIntfStruct.MovieHeight ) / 2; - appMPlayer.subWindow.OldWidth=guiIntfStruct.MovieWidth; appMPlayer.subWindow.OldHeight=guiIntfStruct.MovieHeight; - wsFullScreen( &appMPlayer.subWindow ); - vo_fs=0; - break; - } else if ( !appMPlayer.subWindow.isFullScreen ) break; - case evFullScreen: - for ( j=0;j<appMPlayer.NumberOfItems + 1;j++ ) - { - if ( appMPlayer.Items[j].msg == evFullScreen ) - { - appMPlayer.Items[j].tmp=!appMPlayer.Items[j].tmp; - appMPlayer.Items[j].pressed=appMPlayer.Items[j].tmp; - } - } - mplFullScreen(); - break; - - case evSetAspect: - switch ( (int)param ) - { - case 2: movie_aspect=16.0f / 9.0f; break; - case 3: movie_aspect=4.0f / 3.0f; break; - case 4: movie_aspect=2.35; break; - case 1: - default: movie_aspect=-1; - } - wsClearWindow( appMPlayer.subWindow ); -#ifdef USE_DVDREAD - if ( guiIntfStruct.StreamType == STREAMTYPE_DVD ) goto play_dvd_2; - else -#endif - guiIntfStruct.FilenameChanged=1; - break; - -// --- timer events - case evRedraw: - mplMainRender=1; - wsPostRedisplay( &appMPlayer.mainWindow ); - mplRedrawTimer=mplRedrawTimerConst; - break; -// --- system events -#ifdef MP_DEBUG - case evNone: - mp_msg( MSGT_GPLAYER,MSGL_STATUS,"[mw] event none received.\n" ); - break; - default: - mp_msg( MSGT_GPLAYER,MSGL_STATUS,"[mw] unknown event received ( %d,%.2f ).\n",msg,param ); - break; -#endif - } -} - -#define itPLMButton (itNULL - 1) -#define itPRMButton (itNULL - 2) - -void mplMainMouseHandle( int Button,int X,int Y,int RX,int RY ) -{ - static int itemtype = 0; - int i; - wItem * item = NULL; - float value = 0.0f; - - static int SelectedItem = -1; - int currentselected = -1; - - for ( i=0;i < appMPlayer.NumberOfItems + 1;i++ ) - if ( ( appMPlayer.Items[i].pressed != btnDisabled )&& - ( wgIsRect( X,Y,appMPlayer.Items[i].x,appMPlayer.Items[i].y,appMPlayer.Items[i].x+appMPlayer.Items[i].width,appMPlayer.Items[i].y+appMPlayer.Items[i].height ) ) ) - { currentselected=i; break; } - - switch ( Button ) - { - case wsPMMouseButton: - gtkShow( evHidePopUpMenu,NULL ); - mplShowMenu( RX,RY ); - itemtype=itPRMButton; - break; - case wsRMMouseButton: - mplHideMenu( RX,RY,0 ); - break; - - case wsPLMouseButton: - gtkShow( evHidePopUpMenu,NULL ); - sx=X; sy=Y; boxMoved=1; itemtype=itPLMButton; // if move the main window - SelectedItem=currentselected; - if ( SelectedItem == -1 ) break; // yeees, i'm move the fucking window - boxMoved=0; //mplMainRender=1; // No, not move the window, i'm pressed one button - item=&appMPlayer.Items[SelectedItem]; - itemtype=item->type; - item->pressed=btnPressed; - switch( item->type ) - { - case itButton: - if ( ( SelectedItem > -1 ) && - ( ( ( appMPlayer.Items[SelectedItem].msg == evPlaySwitchToPause && item->msg == evPauseSwitchToPlay ) ) || - ( ( appMPlayer.Items[SelectedItem].msg == evPauseSwitchToPlay && item->msg == evPlaySwitchToPause ) ) ) ) - { appMPlayer.Items[SelectedItem].pressed=btnDisabled; } - break; - } - break; - case wsRLMouseButton: - boxMoved=0; - item=&appMPlayer.Items[SelectedItem]; - item->pressed=btnReleased; - SelectedItem=-1; - if ( currentselected == - 1 ) { itemtype=0; break; } - value=0; - switch( itemtype ) - { - case itPotmeter: - case itHPotmeter: - btnModify( item->msg,(float)( X - item->x ) / item->width * 100.0f ); - mplEventHandling( item->msg,item->value ); - value=item->value; - break; - } - mplEventHandling( item->msg,value ); -// mplMainRender=1; - itemtype=0; - break; - - case wsPRMouseButton: - gtkShow( evShowPopUpMenu,NULL ); - break; - -// --- rolled mouse ... de szar :))) - case wsP5MouseButton: value=-2.5f; goto rollerhandled; - case wsP4MouseButton: value= 2.5f; -rollerhandled: - item=&appMPlayer.Items[currentselected]; - if ( ( item->type == itHPotmeter )||( item->type == itVPotmeter )||( item->type == itPotmeter ) ) - { - item->value+=value; - btnModify( item->msg,item->value ); - mplEventHandling( item->msg,item->value ); - } - break; - -// --- moving - case wsMoveMouse: - item=&appMPlayer.Items[SelectedItem]; - switch ( itemtype ) - { - case itPLMButton: - wsMoveWindow( &appMPlayer.mainWindow,False,RX - abs( sx ),RY - abs( sy ) ); - mplMainRender=0; - break; - case itPRMButton: - mplMenuMouseHandle( X,Y,RX,RY ); - break; - case itPotmeter: - item->value=(float)( X - item->x ) / item->width * 100.0f; - goto potihandled; - case itHPotmeter: - item->value=(float)( X - item->x ) / item->width * 100.0f; -potihandled: - if ( item->value > 100.0f ) item->value=100.0f; - if ( item->value < 0.0f ) item->value=0.0f; - mplEventHandling( item->msg,item->value ); - break; - } - break; - } -// if ( Button != wsMoveMouse ) wsPostRedisplay( &appMPlayer.mainWindow ); -} - -int keyPressed = 0; - -void mplMainKeyHandle( int KeyCode,int Type,int Key ) -{ - int msg = evNone; - - if ( Type != wsKeyPressed ) return; - - if ( !Key ) - { - switch ( KeyCode ) - { - case wsXFMMPrev: msg=evPrev; break; - case wsXFMMStop: msg=evStop; break; - case wsXFMMPlay: msg=evPlaySwitchToPause; break; - case wsXFMMNext: msg=evNext; break; - case wsXFMMVolUp: msg=evIncVolume; break; - case wsXFMMVolDown: msg=evDecVolume; break; - case wsXFMMMute: msg=evMute; break; - } - } - else - { - switch ( Key ) - { - case wsEnter: msg=evPlay; break; - case wsXF86LowerVolume: msg=evDecVolume; break; - case wsXF86RaiseVolume: msg=evIncVolume; break; - case wsXF86Mute: msg=evMute; break; - case wsXF86Play: msg=evPlaySwitchToPause; break; - case wsXF86Stop: msg=evStop; break; - case wsXF86Prev: msg=evPrev; break; - case wsXF86Next: msg=evNext; break; - case wsXF86Media: msg=evLoad; break; - - default: vo_x11_putkey( Key ); return; - } - } - if ( msg != evNone ) mplEventHandling( msg,0 ); -} - -/* this will be used to handle Drag&Drop files */ -void mplDandDHandler(int num,char** files) -{ - struct stat buf; - int f = 0; - - if (num <= 0) - return; - - /* clear playlist */ - gtkSet(gtkDelPl,0,NULL); - - /* now fill it with new items */ - for(f=0; f < num; f++){ - char* str = strdup( files[f] ); - plItem* item; - -#ifdef USE_ICONV - if ( strchr( str,'%' ) ) - { - char * tmp=gconvert_uri_to_filename( str ); - free( str ); str=tmp; - } -#endif - - if(stat(str,&buf) == 0 && S_ISDIR(buf.st_mode) == 0) { - /* this is not a directory so try to play it */ - printf("Received D&D %s\n",str); - item = calloc(1,sizeof(plItem)); - - /* FIXME: decompose file name ? */ - /* yes -- Pontscho */ - if ( strrchr( str,'/' ) ) - { - char * s = strrchr( str,'/' ); *s=0; s++; - item->name = gstrdup( s ); - item->path = gstrdup( str ); - } else { item->name = strdup(str); item->path = strdup(""); } - gtkSet(gtkAddPlItem,0,(void*)item); - } else { - printf("Received not a file: %s !\n",str); - } - free( str ); - } - - mplSetFileName( NULL,files[0],STREAMTYPE_FILE ); - if ( guiIntfStruct.Playing == 1 ) mplEventHandling( evStop,0 ); - mplEventHandling( evPlay,0 ); - -}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Gui/mplayer/sw.c Sat Nov 02 17:25:06 2002 +0000 @@ -0,0 +1,74 @@ + +// sub window + +int mplSubRender = 0; +int SubVisible = 0; + +void mplSubDraw( wsParamDisplay ) +{ + if ( appMPlayer.subWindow.State == wsWindowClosed ) exit_player( MSGTR_Exit_quit ); + + if ( appMPlayer.subWindow.State == wsWindowFocusIn ) SubVisible++; + if ( appMPlayer.subWindow.State == wsWindowFocusOut && wsWMType != wsWMKDE && wsWMType != wsWMIceWM ) SubVisible--; + + if ( !appMPlayer.subWindow.Mapped || + appMPlayer.subWindow.Visible == wsWindowNotVisible ) return; + + if ( guiIntfStruct.Playing ) mplSubRender=0; + + if ( mplSubRender && appMPlayer.subWindow.State == wsWindowExpose ) + { + if ( appMPlayer.sub.Bitmap.Image ) wsPutImage( &appMPlayer.subWindow ); + } + appMPlayer.subWindow.State=0; +} + +void mplSubMouseHandle( int Button,int X,int Y,int RX,int RY ) +{ + static int mplSubMoved = 0; + static int msButton = 0; + + switch( Button ) + { + case wsPRMouseButton: + gtkShow( evShowPopUpMenu,NULL ); + break; + case wsPMMouseButton: + gtkShow( evHidePopUpMenu,NULL ); + mplShowMenu( RX,RY ); + msButton=wsPMMouseButton; + break; + case wsRMMouseButton: + mplHideMenu( RX,RY,1 ); + msButton=0; + break; +// --- + case wsPLMouseButton: + gtkShow( evHidePopUpMenu,NULL ); + sx=X; sy=Y; + msButton=wsPLMouseButton; + mplSubMoved=0; + break; + case wsMoveMouse: + switch ( msButton ) + { + case wsPLMouseButton: + mplSubMoved=1; + if ( !appMPlayer.subWindow.isFullScreen ) wsMoveWindow( &appMPlayer.subWindow,False,RX - sx,RY - sy ); + break; + case wsPMMouseButton: + mplMenuMouseHandle( X,Y,RX,RY ); + break; + } + break; + case wsRLMouseButton: + if ( ( !mplSubMoved )&&( appMPlayer.subWindow.isFullScreen ) ) + { + if( SubVisible++%2 ) wsMoveTopWindow( wsDisplay,appMPlayer.mainWindow.WindowID ); + else if ( wsWMType != wsWMNetWM && wsWMType != wsWMKDE ) wsMoveTopWindow( wsDisplay,appMPlayer.subWindow.WindowID ); + } + msButton=0; + mplSubMoved=0; + break; + } +}
--- a/Gui/mplayer/sw.h Sat Nov 02 17:22:09 2002 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,74 +0,0 @@ - -// sub window - -int mplSubRender = 0; -int SubVisible = 0; - -void mplSubDraw( wsParamDisplay ) -{ - if ( appMPlayer.subWindow.State == wsWindowClosed ) exit_player( MSGTR_Exit_quit ); - - if ( appMPlayer.subWindow.State == wsWindowFocusIn ) SubVisible++; - if ( appMPlayer.subWindow.State == wsWindowFocusOut && wsWMType != wsWMKDE && wsWMType != wsWMIceWM ) SubVisible--; - - if ( !appMPlayer.subWindow.Mapped || - appMPlayer.subWindow.Visible == wsWindowNotVisible ) return; - - if ( guiIntfStruct.Playing ) mplSubRender=0; - - if ( mplSubRender && appMPlayer.subWindow.State == wsWindowExpose ) - { - if ( appMPlayer.sub.Bitmap.Image ) wsPutImage( &appMPlayer.subWindow ); - } - appMPlayer.subWindow.State=0; -} - -void mplSubMouseHandle( int Button,int X,int Y,int RX,int RY ) -{ - static int mplSubMoved = 0; - static int msButton = 0; - - switch( Button ) - { - case wsPRMouseButton: - gtkShow( evShowPopUpMenu,NULL ); - break; - case wsPMMouseButton: - gtkShow( evHidePopUpMenu,NULL ); - mplShowMenu( RX,RY ); - msButton=wsPMMouseButton; - break; - case wsRMMouseButton: - mplHideMenu( RX,RY,1 ); - msButton=0; - break; -// --- - case wsPLMouseButton: - gtkShow( evHidePopUpMenu,NULL ); - sx=X; sy=Y; - msButton=wsPLMouseButton; - mplSubMoved=0; - break; - case wsMoveMouse: - switch ( msButton ) - { - case wsPLMouseButton: - mplSubMoved=1; - if ( !appMPlayer.subWindow.isFullScreen ) wsMoveWindow( &appMPlayer.subWindow,False,RX - sx,RY - sy ); - break; - case wsPMMouseButton: - mplMenuMouseHandle( X,Y,RX,RY ); - break; - } - break; - case wsRLMouseButton: - if ( ( !mplSubMoved )&&( appMPlayer.subWindow.isFullScreen ) ) - { - if( SubVisible++%2 ) wsMoveTopWindow( wsDisplay,appMPlayer.mainWindow.WindowID ); - else if ( wsWMType != wsWMNetWM && wsWMType != wsWMKDE ) wsMoveTopWindow( wsDisplay,appMPlayer.subWindow.WindowID ); - } - msButton=0; - mplSubMoved=0; - break; - } -}