# HG changeset patch # User pontscho # Date 1042145234 0 # Node ID b8c2717504508d7695a1461d243528cefba1d8ba # Parent 46440d3621a8ec7f79c5592688b1c2eadf67f536 - sync with x11_common - half rewrited font render engine (disabled by default) diff -r 46440d3621a8 -r b8c271750450 Gui/mplayer/mw.c --- a/Gui/mplayer/mw.c Thu Jan 09 20:42:01 2003 +0000 +++ b/Gui/mplayer/mw.c Thu Jan 09 20:47:14 2003 +0000 @@ -218,20 +218,20 @@ 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 ); + image=fntRender( item,0,"%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 ); + image=fntRender( item,(GetTimerMS() / 20)%(l?l:item->width),"%s",t ); } drawrenderedtext: if ( image ) { PutImage( image,item->x,item->y,1,0 ); - if ( image->Image ) free( image->Image ); - free( image ); +// if ( image->Image ) free( image->Image ); +// free( image ); } break; } diff -r 46440d3621a8 -r b8c271750450 Gui/mplayer/play.c --- a/Gui/mplayer/play.c Thu Jan 09 20:42:01 2003 +0000 +++ b/Gui/mplayer/play.c Thu Jan 09 20:47:14 2003 +0000 @@ -238,7 +238,7 @@ if ( ( mplDrawBuffer = (unsigned char *)calloc( 1,appMPlayer.main.Bitmap.ImageSize ) ) == NULL ) { mp_msg( MSGT_GPLAYER,MSGL_STATUS,MSGTR_NEMDB ); return; } - if ( wsWMType == wsWMUnknown ) wsVisibleWindow( &appMPlayer.mainWindow,wsHideWindow ); + if ( vo_wm_type == vo_wm_Unknown ) wsVisibleWindow( &appMPlayer.mainWindow,wsHideWindow ); wsResizeWindow( &appMPlayer.mainWindow,appMPlayer.main.width,appMPlayer.main.height ); wsMoveWindow( &appMPlayer.mainWindow,True,appMPlayer.main.x,appMPlayer.main.y ); wsResizeImage( &appMPlayer.mainWindow,appMPlayer.main.width,appMPlayer.main.height ); diff -r 46440d3621a8 -r b8c271750450 Gui/mplayer/sw.c --- a/Gui/mplayer/sw.c Thu Jan 09 20:42:01 2003 +0000 +++ b/Gui/mplayer/sw.c Thu Jan 09 20:47:14 2003 +0000 @@ -1,6 +1,11 @@ // sub window +#include + +#include "../../config.h" +#include "../../libvo/x11_common.h" + #include "../app.h" #include "../interface.h" #include "../../help_mp.h" @@ -18,7 +23,7 @@ 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.State == wsWindowFocusOut && metacity_hack != 3 ) SubVisible--; if ( !appMPlayer.subWindow.Mapped || appMPlayer.subWindow.Visible == wsWindowNotVisible ) return; @@ -74,7 +79,7 @@ if ( ( !mplSubMoved )&&( appMPlayer.subWindow.isFullScreen ) ) { if( SubVisible++%2 ) wsMoveTopWindow( wsDisplay,appMPlayer.mainWindow.WindowID ); - else if ( wsWMType != wsWMNetWM && wsWMType != wsWMKDE ) wsMoveTopWindow( wsDisplay,appMPlayer.subWindow.WindowID ); + else wsMoveTopWindow( wsDisplay,appMPlayer.subWindow.WindowID ); } msButton=0; mplSubMoved=0; diff -r 46440d3621a8 -r b8c271750450 Gui/mplayer/widgets.c --- a/Gui/mplayer/widgets.c Thu Jan 09 20:42:01 2003 +0000 +++ b/Gui/mplayer/widgets.c Thu Jan 09 20:47:14 2003 +0000 @@ -144,13 +144,15 @@ } gtk_widget_show( MessageBox ); gtkSetLayer( MessageBox ); - gtkActive( MessageBox ); if ( type == GTK_MB_FATAL ) while ( MessageBox ) gtk_main_iteration_do( 0 ); } void gtkSetLayer( GtkWidget * wdg ) -{ wsSetLayer( gdk_display,GDK_WINDOW_XWINDOW( wdg->window ),appMPlayer.subWindow.isFullScreen ); } +{ + wsSetLayer( gdk_display,GDK_WINDOW_XWINDOW( wdg->window ),appMPlayer.subWindow.isFullScreen ); + gtkActive( wdg ); +} void gtkActive( GtkWidget * wdg ) { wsMoveTopWindow( gdk_display,GDK_WINDOW_XWINDOW( wdg->window )); } diff -r 46440d3621a8 -r b8c271750450 Gui/skin/font.c --- a/Gui/skin/font.c Thu Jan 09 20:42:01 2003 +0000 +++ b/Gui/skin/font.c Thu Jan 09 20:47:14 2003 +0000 @@ -5,6 +5,7 @@ #include #include +#include "../app.h" #include "skin.h" #include "font.h" #include "cut.h" @@ -118,7 +119,7 @@ if ( ( !Fonts[id] )||( !str[0] ) ) return 0; - for ( i=0;i < (unsigned int)strlen( str );i++ ) + for ( i=0;i < (int)strlen( str );i++ ) { unsigned char c = (unsigned char)str[i]; if ( Fonts[id]->Fnt[c].sx == -1 ) c = ' '; @@ -144,16 +145,134 @@ return max; } -txSample * fntRender( int id,int px,int sx,char * fmt,... ) +typedef struct +{ + int pos; + char c; +} iChar; + +txSample * fntRender( wItem * item,int px,char * fmt,... ) { +#if 0 + txSample * tmp = NULL; + va_list ap; + char p[512]; + iChar pos[512]; + int i, dx = 0, s, tw; + uint32_t * ibuf; + uint32_t * obuf; + + va_start( ap,fmt ); + vsnprintf( p,512,fmt,ap ); + va_end( ap ); + + if ( ( !item )|| + ( !Fonts[item->fontid] )|| + ( !p[0] )|| + ( !fntTextWidth( item->fontid,p ) ) ) return NULL; + + tw=fntTextWidth( item->fontid,p ); + + if ( item->Bitmap.Image == NULL ) + { + item->Bitmap.Height=item->height=fntTextHeight( item->fontid,p ); + item->Bitmap.Width=item->width; + item->Bitmap.ImageSize=item->height * item->width * 4; + item->Bitmap.BPP=32; + item->Bitmap.Image=malloc( item->Bitmap.ImageSize ); + } + + obuf=(uint32_t *)item->Bitmap.Image; + ibuf=(uint32_t *)Fonts[item->fontid]->Bitmap.Image; + + for ( i=0;i < item->Bitmap.ImageSize / 4;i++ ) obuf[i]=0xff00ff; + + if ( tw < item->width ) + { + switch ( item->align ) + { + default: + case fntAlignLeft: dx=0; break; + case fntAlignCenter: dx=( item->width - fntTextWidth( item->fontid,p ) ) / 2; break; + case fntAlignRight: dx=item->width - fntTextWidth( item->fontid,p ); break; + } + + } else dx+=px; +/* + for ( i=0;i < (int)strlen( p );i++ ) + { + int c = (int)p[i]; + int fw = Fonts[item->fontid]->Fnt[c].sx; + int fh = Fonts[item->fontid]->Fnt[c].sy; + int fx = Fonts[item->fontid]->Fnt[c].x; + int fy = Fonts[item->fontid]->Fnt[c].y; + + if ( fw != -1 ) + { + // font rendernig + int x,y; + for ( y=0;y < fh;y++ ) + { + if ( dx >= 0 ) + for ( x=0; x < fw;x++ ) + { + if ( dx + x >= item->width ) goto fnt_exit; + obuf[y * item->width + x + dx]=ibuf[ ( fy + y ) * Fonts[item->fontid]->Bitmap.Width + fx + x ]; + } + } + dx+=fw; + } else dx+=4; + } + +fnt_exit: +*/ + +if ( !strncmp( p,"lofasz",6 ) ) +{ + int i,j, c = 0; + char t[512]; + memset( t,0,512 ); +// printf( "!!!! " ); + for ( i=0; i < (int)strlen( p );i++ ) + { + int c = (int)p[i]; + int fw = Fonts[item->fontid]->Fnt[c].sx; + pos[i].pos=dx; + pos[i].c=p[i]; + if ( pos[i].pos > item->width ) pos[i].pos-=item->width; +// printf( "%d; ",pos[i] ); + dx+=fw; + } + for ( i=0;i < (int)strlen( p );i++ ) + for ( j=strlen( p );j > i;j-- ) + if ( pos[j].pos < pos[i].pos ) + { + iChar tmp; + memcpy( &tmp,&pos[i],sizeof( iChar ) ); + memcpy( &pos[i],&pos[j],sizeof( iChar ) ); + memcpy( &pos[j],&tmp,sizeof( iChar ) ); + } +// + for ( i=0;i < (int)strlen( p );i++ ) + t[c++]=pos[i].c; +// if ( pos[i].pos > 0 && pos[i].pos < item->width ) t[c++]=pos[i].c; + printf( "!!! %s\n",t ); +} + + return &item->Bitmap; + +#else + txSample tmp2; txSample * tmp = NULL; - txSample tmp2; + va_list ap; char p[512]; - va_list ap; uint32_t * ibuf; uint32_t * obuf; int i,x,y; - int oy = 0, ox = 0, dx = 0; + int oy = 0, ox = 0, dx = 0, s = 0; + int id=item->fontid; + int sx=item->width; + int a=item->align; va_start( ap,fmt ); vsnprintf( p,512,fmt,ap ); @@ -169,15 +288,24 @@ tmp->BPP=32; tmp->ImageSize=tmp->Width * tmp->Height * 4; if ( ( tmp->Image=malloc( tmp->ImageSize ) ) == NULL ) return NULL; + obuf=(uint32_t *)tmp->Image; ibuf=(uint32_t *)Fonts[id]->Bitmap.Image; + for ( i=0;i < (int)strlen( p );i++ ) { unsigned int c = (unsigned char)p[i]; + int cx,cy; + if ( Fonts[id]->Fnt[c].sx == -1 ) c=32; - for ( oy=0,y=Fonts[id]->Fnt[c].y;y < Fonts[id]->Fnt[c].y + Fonts[id]->Fnt[c].sy; y++,oy++ ) - for ( ox=0,x=Fonts[id]->Fnt[c].x;x < Fonts[id]->Fnt[c].x + Fonts[id]->Fnt[c].sx; x++,ox++ ) - obuf[ oy * tmp->Width + dx + ox ]=ibuf[ y * Fonts[id]->Bitmap.Width + x ]; + + cx=Fonts[id]->Fnt[c].x; + cy=Fonts[id]->Fnt[c].y; + + for ( oy=0,y=cy;y < cy + Fonts[id]->Fnt[c].sy; y++,oy++ ) + for ( ox=0,x=cx;x < cx + Fonts[id]->Fnt[c].sx; x++,ox++ ) + obuf[ oy * tmp->Width + dx + ox ]=ibuf[ y * Fonts[id]->Bitmap.Width + x ]; + dx+=Fonts[id]->Fnt[c].sx; } @@ -203,6 +331,7 @@ free( tmp->Image ); tmp->Width=sx; tmp->ImageSize=tmp2.ImageSize; tmp->Image=tmp2.Image; } +#endif return tmp; } diff -r 46440d3621a8 -r b8c271750450 Gui/skin/font.h --- a/Gui/skin/font.h Thu Jan 09 20:42:01 2003 +0000 +++ b/Gui/skin/font.h Thu Jan 09 20:47:14 2003 +0000 @@ -3,6 +3,11 @@ #define _FONT_H #include "../bitmap.h" +#include "../app.h" + +#define fntAlignLeft 0 +#define fntAlignCenter 1 +#define fntAlignRight 2 typedef struct { @@ -27,7 +32,7 @@ extern int fntTextWidth( int id,char * str ); extern int fntRead( char * path,char * fname ); -extern txSample * fntRender( int id,int px,int sx,char * fmt,... ); +extern txSample * fntRender( wItem * item,int px,char * fmt,... ); #endif diff -r 46440d3621a8 -r b8c271750450 Gui/wm/ws.c --- a/Gui/wm/ws.c Thu Jan 09 20:42:01 2003 +0000 +++ b/Gui/wm/ws.c Thu Jan 09 20:47:14 2003 +0000 @@ -19,6 +19,7 @@ #include #include "../../config.h" +#include "../../libvo/x11_common.h" #include "ws.h" #include "wsxdnd.h" #include "../../postproc/rgb2rgb.h" @@ -33,7 +34,7 @@ #include #include -#define ENABLE_DPMS 0 +#undef ENABLE_DPMS typedef struct { @@ -54,7 +55,6 @@ Window wsRootWin; XEvent wsEvent; int wsWindowDepth; -int wsWMType = wsWMUnknown; GC wsHGC; MotifWmHints wsMotifWmHints; Atom wsTextProperlyAtom = None; @@ -167,73 +167,6 @@ exit( 0 ); } -int wsWindowManagerType( void ) -{ - Atom type; - int format; - unsigned long nitems, bytesafter; - unsigned char * args = NULL; - - Window win; - XEvent xev; - int c = 0; - int wm = wsWMUnknown; - -// --- gnome -/* - type=XInternAtom( wsDisplay,"_WIN_SUPPORTING_WM_CHECK",False ); - if ( Success == XGetWindowProperty( wsDisplay,wsRootWin,type,0,65536 / sizeof( int32_t ),False,AnyPropertyType,&type,&format,&nitems,&bytesafter,&args ) && nitems > 0 ) - { - mp_dbg( MSGT_GPLAYER,MSGL_STATUS,"[ws] Detected wm is Gnome\n" ); - XFree( args ); - return wsWMGnome; - } -*/ -// --- net wm - type=XInternAtom( wsDisplay,"_NET_SUPPORTED",False ); - if ( Success == XGetWindowProperty( wsDisplay,wsRootWin,type,0,65536 / sizeof( int32_t ),False,AnyPropertyType,&type,&format,&nitems,&bytesafter,&args ) && nitems > 0 ) - { - mp_dbg( MSGT_GPLAYER,MSGL_STATUS,"[ws] Detected wm is NetWM\n" ); - XFree( args ); - return wsWMNetWM; - } - -// --- other wm - mp_dbg( MSGT_VO,MSGL_STATUS,"[ws] Create window for WM detect ...\n" ); - win=XCreateSimpleWindow( wsDisplay,wsRootWin,wsMaxX,wsMaxY,1,1,0,0,0 ); - XSelectInput( wsDisplay,win,PropertyChangeMask | StructureNotifyMask ); - XMapWindow( wsDisplay,win ); - XMoveWindow( wsDisplay,win,wsMaxX,wsMaxY ); - do - { - XCheckWindowEvent( wsDisplay,win,PropertyChangeMask | StructureNotifyMask,&xev ); - - if ( xev.type == PropertyNotify ) - { - char * name = XGetAtomName( wsDisplay,xev.xproperty.atom ); - if ( !name ) break; - - if ( !strncmp( name,"_ICEWM_TRAY",11 ) ) - { mp_dbg( MSGT_VO,MSGL_STATUS,"[ws] Detected wm is IceWM.\n" ); wm=wsWMIceWM; break; } - if ( !strncmp( name,"_KDE_",5 ) ) - { mp_dbg( MSGT_VO,MSGL_STATUS,"[ws] Detected wm is KDE.\n" ); wm=wsWMKDE; break; } - if ( !strncmp( name,"KWM_WIN_DESKTOP",15 ) ) - { mp_dbg( MSGT_VO,MSGL_STATUS,"[ws] Detected wm is WindowMaker style.\n" ); wm=wsWMWMaker; break; } -// fprintf(stderr,"[ws] PropertyNotify ( 0x%x ) %s ( 0x%x )\n",win,name,xev.xproperty.atom ); - XFree( name ); - } - } while( c++ < 25 ); - XUnmapWindow( wsDisplay,win ); - XDestroyWindow( wsDisplay,win ); -#ifdef MP_DEBUG - if ( wm == wsWMUnknown ) mp_dbg( MSGT_VO,MSGL_STATUS,"[ws] Unknown wm type...\n" ); -#endif - return wsWMUnknown; -} - -extern int vo_wm_type; -extern int vo_find_depth_from_visuals(Display *dpy, int screen, Visual **visual_return); - void wsXInit( void* mDisplay ) { int eventbase; @@ -265,6 +198,7 @@ mp_dbg( MSGT_GPLAYER,MSGL_DBG2,"[ws] Display name: %s => %s display.\n",dispname,localdisp?"local":"REMOTE"); if (!localdisp) mp_msg( MSGT_GPLAYER,MSGL_STATUS,"[ws] Remote display, disabling XMITSHM\n"); } + if ( !XShmQueryExtension( wsDisplay ) ) { mp_msg( MSGT_GPLAYER,MSGL_ERR,"[ws] sorry, your system is not supported X shared memory extension.\n" ); @@ -287,9 +221,6 @@ wsMaxX=DisplayWidth( wsDisplay,wsScreen ); wsMaxY=DisplayHeight( wsDisplay,wsScreen ); - if ( vo_wm_type != -1 ) wsWMType=vo_wm_type; - else wsWMType=wsWindowManagerType(); - wsGetDepthOnScreen(); #ifdef DEBUG { @@ -684,33 +615,6 @@ wsWindowList[l]->MouseHandler( i,Event->xbutton.x,Event->xbutton.y,Event->xmotion.x_root,Event->xmotion.y_root ); break; - case PropertyNotify: - { - char * name = XGetAtomName( wsDisplay,Event->xproperty.atom ); - - if ( !name ) break; - if ( !strncmp( name,"_ICEWM_TRAY",11 ) ) - { - wsWMType=wsWMIceWM; -// mp_dbg( MSGT_GPLAYER,MSGL_STATUS,"[ws] Detected wm is IceWM.\n" ); - } - if ( !strncmp( name,"_KDE_",5 ) ) - { -// mp_dbg( MSGT_GPLAYER,MSGL_STATUS,"[ws] Detected wm is KDE.\n" ); - wsWMType=wsWMKDE; - } - if ( !strncmp( name,"KWM_WIN_DESKTOP",15 ) ) - { -// mp_dbg( MSGT_GPLAYER,MSGL_STATUS,"[ws] Detected wm is WindowMaker style.\n" ); - wsWMType=wsWMWMaker; - } - -// fprintf(stderr,"[ws] PropertyNotify %s ( 0x%x )\n",name,Event->xproperty.atom ); - - XFree( name ); - } - break; - case SelectionNotify: /* Handle DandD */ wsXDNDProcessSelection(wsWindowList[l],Event); @@ -775,75 +679,7 @@ #define WIN_LAYER_ONTOP 10 void wsSetLayer( Display * wsDisplay, Window win, int layer ) -{ - Atom type; - int format; - unsigned long nitems, bytesafter; - Atom * args = NULL; - - if ( wsWMType == wsWMIceWM ) - { - switch ( layer ) - { - case -1: layer=2; break; // WinLayerBelow - case 0: layer=4; break; // WinLayerNormal - case 1: layer=8; break; // WinLayerOnTop - } - XChangeProperty( wsDisplay,win, - XInternAtom( wsDisplay,"_WIN_LAYER",False ),XA_CARDINAL,32,PropModeReplace,(unsigned char *)&layer,1 ); - return; - } - - type=XInternAtom( wsDisplay,"_WIN_SUPPORTING_WM_CHECK",False ); - if ( Success == XGetWindowProperty( wsDisplay,wsRootWin,type,0,65536 / sizeof( int32_t ),False,AnyPropertyType,&type,&format,&nitems,&bytesafter,(unsigned char **)&args ) && nitems > 0 ) - { - XClientMessageEvent xev; - - memset( &xev,0,sizeof( xev ) ); - xev.type=ClientMessage; - xev.window=win; - xev.message_type=XInternAtom( wsDisplay,"_WIN_LAYER",False ); - xev.format=32; - switch ( layer ) - { - case -1: xev.data.l[0] = WIN_LAYER_ONBOTTOM; break; - case 0: xev.data.l[0] = WIN_LAYER_NORMAL; break; - case 1: xev.data.l[0] = WIN_LAYER_ONTOP; break; - } - XSendEvent( wsDisplay,wsRootWin,False,SubstructureNotifyMask,(XEvent*)&xev ); - if ( layer ) XRaiseWindow( wsDisplay,win ); - - XFree( args ); - return; - } - - type=XInternAtom( wsDisplay,"_NET_SUPPORTED",False ); - if ( Success == XGetWindowProperty( wsDisplay,wsRootWin,type,0,65536 / sizeof( int32_t ),False,AnyPropertyType,&type,&format,&nitems,&bytesafter,(unsigned char **)&args ) && nitems > 0 ) - { - int i; - XEvent e; - - e.xclient.type=ClientMessage; - e.xclient.message_type=XInternAtom( wsDisplay,"_NET_WM_STATE",False ); - e.xclient.display=wsDisplay; - e.xclient.window=win; - e.xclient.format=32; - e.xclient.data.l[0]=layer; - - e.xclient.data.l[1]=XInternAtom( wsDisplay,"_NET_WM_STATE_STAYS_ON_TOP",False ); - type=XInternAtom( wsDisplay,"_NET_WM_STATE_FULLSCREEN",False ); - for ( i=0;(unsigned long)i < nitems;i++ ) - if ( args[i] == type ) { e.xclient.data.l[1]=XInternAtom( wsDisplay,"_NET_WM_STATE_FULLSCREEN",False ); break; } - - e.xclient.data.l[2]=0l; - e.xclient.data.l[3]=0l; - e.xclient.data.l[4]=0l; - XSendEvent( wsDisplay,wsRootWin,False,SubstructureRedirectMask,&e ); - - XFree( args ); - return; - } -} +{ vo_x11_setlayer( wsDisplay,win,layer ); } // ---------------------------------------------------------------------------------------------- // Switch to fullscreen. @@ -851,17 +687,6 @@ void wsFullScreen( wsTWindow * win ) { int decoration = 0; - - switch ( wsWMType ) - { - case wsWMUnknown: -// XUnmapWindow( wsDisplay,win->WindowID ); - XWithdrawWindow( wsDisplay,win->WindowID,wsScreen ); - break; - case wsWMIceWM: - if ( !win->isFullScreen ) XUnmapWindow( wsDisplay,win->WindowID ); - break; - } if ( win->isFullScreen ) { @@ -887,31 +712,21 @@ #endif } - win->SizeHint.flags=PPosition | PSize | PWinGravity;// | PBaseSize; - win->SizeHint.x=win->X; win->SizeHint.y=win->Y; - win->SizeHint.width=win->Width; win->SizeHint.height=win->Height; -// win->SizeHint.base_width=win->Width; win->SizeHint.base_height=win->Height; - - win->SizeHint.win_gravity=StaticGravity; - if ( win->Property & wsMaxSize ) + if ( net_wm_support != SUPPORT_FULLSCREEN || metacity_hack == 1 ) { - win->SizeHint.flags|=PMaxSize; - win->SizeHint.max_width=win->Width; - win->SizeHint.max_height=win->Height; + vo_x11_decoration( wsDisplay,win->WindowID,decoration ); + vo_x11_sizehint( win->X,win->Y,win->Width,win->Height,0 ); } - if ( win->Property & wsMinSize ) + vo_x11_setlayer( wsDisplay,win->WindowID,win->isFullScreen ); + if ( net_wm_support != SUPPORT_FULLSCREEN || metacity_hack == 1 ) { - win->SizeHint.flags|=PMinSize; - win->SizeHint.min_width=win->Width; - win->SizeHint.min_height=win->Height; + if ( vo_wm_type == vo_wm_Unknown && !(vo_fsmode&16) ) + XWithdrawWindow( wsDisplay,win->WindowID,wsScreen ); + XMoveResizeWindow( wsDisplay,win->WindowID,win->X,win->Y,win->Width,win->Height ); } - XSetWMNormalHints( wsDisplay,win->WindowID,&win->SizeHint ); - - wsSetLayer( wsDisplay,win->WindowID,win->isFullScreen ); - XMoveResizeWindow( wsDisplay,win->WindowID,win->X,win->Y,win->Width,win->Height ); - wsWindowDecoration( win,decoration ); XMapRaised( wsDisplay,win->WindowID ); XRaiseWindow( wsDisplay,win->WindowID ); + XFlush( wsDisplay ); } // ---------------------------------------------------------------------------------------------- @@ -1019,7 +834,7 @@ win->SizeHint.win_gravity=StaticGravity; win->SizeHint.base_width=sx; win->SizeHint.base_height=sy; - if ( wsWMType == wsWMUnknown ) XUnmapWindow( wsDisplay,win->WindowID ); + if ( vo_wm_type == vo_wm_Unknown ) XUnmapWindow( wsDisplay,win->WindowID ); XSetWMNormalHints( wsDisplay,win->WindowID,&win->SizeHint ); XResizeWindow( wsDisplay,win->WindowID,sx,sy ); @@ -1038,30 +853,10 @@ // ---------------------------------------------------------------------------------------------- void wsMoveTopWindow( Display * wsDisplay,Window win ) { - switch ( wsWMType ) - { - case wsWMIceWM: - XUnmapWindow( wsDisplay,win ); - XMapWindow( wsDisplay,win ); - break; - case wsWMNetWM: - case wsWMKDE: - { - XEvent e; - e.xclient.type=ClientMessage; - e.xclient.message_type=XInternAtom( wsDisplay,"_NET_ACTIVE_WINDOW",False ); - e.xclient.display=wsDisplay; - e.xclient.window=win; - e.xclient.format=32; - e.xclient.data.l[0]=0; - XSendEvent( wsDisplay,RootWindow( wsDisplay,DefaultScreen( wsDisplay ) ),False,SubstructureRedirectMask,&e ); - break; - } - default: - XMapRaised( wsDisplay,win ); - XRaiseWindow( wsDisplay,win ); - break; - } +// XUnmapWindow( wsDisplay,win ); +// XMapWindow( wsDisplay,win ); + XMapRaised( wsDisplay,win ); + XRaiseWindow( wsDisplay,win ); } // ---------------------------------------------------------------------------------------------- diff -r 46440d3621a8 -r b8c271750450 Gui/wm/ws.h --- a/Gui/wm/ws.h Thu Jan 09 20:42:01 2003 +0000 +++ b/Gui/wm/ws.h Thu Jan 09 20:47:14 2003 +0000 @@ -170,8 +170,6 @@ extern int wsMaxX; extern int wsMaxY; -extern int wsWMType; - extern Display * wsDisplay; extern int wsScreen; extern Window wsRootWin; diff -r 46440d3621a8 -r b8c271750450 libvo/x11_common.c --- a/libvo/x11_common.c Thu Jan 09 20:42:01 2003 +0000 +++ b/libvo/x11_common.c Thu Jan 09 20:47:14 2003 +0000 @@ -41,10 +41,6 @@ #include "../mplayer.h" #endif -#define vo_wm_Unknown 0 -#define vo_wm_NetWM 1 -#define vo_wm_Layered 2 - #define WIN_LAYER_ONBOTTOM 2 #define WIN_LAYER_NORMAL 4 #define WIN_LAYER_ONTOP 6 @@ -72,10 +68,6 @@ /* if equal to 1 means that WM is a metacity (broken as hell) */ int metacity_hack = 0; -#define SUPPORT_NONE 0 -#define SUPPORT_FULLSCREEN 1 -#define SUPPORT_ABOVE 2 -#define SUPPORT_STAYS_ON_TOP 4 int net_wm_support = 0; Atom XA_NET_SUPPORTED; @@ -701,10 +693,13 @@ XSetWMNormalHints( mDisplay,vo_window,&vo_hint ); } -void vo_x11_setlayer( int layer ) +void vo_x11_setlayer( Display * mDisplay,Window vo_window,int layer ) { if ( WinID >= 0 ) return; - + + // window manager could be changed during play + vo_wm_type=vo_wm_detect(); + switch ( vo_wm_type ) { case vo_wm_Layered: { @@ -718,6 +713,7 @@ xev.data.l[0] = layer?ice_layer:WIN_LAYER_NORMAL; // if not fullscreen, stay on layer "Normal" xev.data.l[1] = CurrentTime; mp_dbg( MSGT_VO,MSGL_STATUS,"[x11] Layered style stay on top ( layer %d ).\n",xev.data.l[0] ); + printf( "[x11] Layered style stay on top ( layer %d ).\n",xev.data.l[0] ); XSendEvent(mDisplay, mRootWin, False, SubstructureNotifyMask, (XEvent *) &xev); break; } @@ -751,6 +747,7 @@ } state = XGetAtomName (mDisplay, xev.data.l[1]); mp_dbg( MSGT_VO,MSGL_STATUS,"[x11] NET style stay on top ( layer %d ). Using state %s.\n",layer,state ); + printf( "[x11] NET style stay on top ( layer %d ). Using state %s.\n",layer,state ); XFree (state); } } @@ -784,7 +781,7 @@ vo_x11_decoration( mDisplay,vo_window,(vo_fs) ? 0 : 1 ); vo_x11_sizehint( x,y,w,h,0 ); } - vo_x11_setlayer( vo_fs ); + vo_x11_setlayer( mDisplay,vo_window,vo_fs ); if (net_wm_support!=SUPPORT_FULLSCREEN || metacity_hack==1) { if(vo_wm_type==vo_wm_Unknown && !(vo_fsmode&16)) diff -r 46440d3621a8 -r b8c271750450 libvo/x11_common.h --- a/libvo/x11_common.h Thu Jan 09 20:42:01 2003 +0000 +++ b/libvo/x11_common.h Thu Jan 09 20:47:14 2003 +0000 @@ -7,6 +7,19 @@ #include #include +#define vo_wm_Unknown 0 +#define vo_wm_NetWM 1 +#define vo_wm_Layered 2 + +#define SUPPORT_NONE 0 +#define SUPPORT_FULLSCREEN 1 +#define SUPPORT_ABOVE 2 +#define SUPPORT_STAYS_ON_TOP 4 + +extern int net_wm_support; +extern int metacity_hack; +extern int vo_fsmode; + extern int vo_depthonscreen; extern int vo_screenwidth; extern int vo_screenheight; @@ -35,6 +48,7 @@ extern int vo_x11_check_events(Display *mydisplay); extern void vo_x11_selectinput_witherr(Display *display, Window w, long event_mask); extern void vo_x11_fullscreen( void ); +extern void vo_x11_setlayer( Display * mDisplay,Window vo_window,int layer ); extern void vo_x11_uninit(); extern Colormap vo_x11_create_colormap(XVisualInfo *vinfo); extern uint32_t vo_x11_set_equalizer(char *name, int value); @@ -63,6 +77,7 @@ void vo_vm_close(Display*); #endif +int vo_find_depth_from_visuals(Display *dpy, int screen, Visual **visual_return); + #endif -int vo_find_depth_from_visuals(Display *dpy, int screen, Visual **visual_return);