Commit 4ffd7b44 authored by Olivier Teulière's avatar Olivier Teulière

* plugins/directs/vout_events.c: added an "Always on top" option in the

  system menu
parent 1eb5d638
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* vout_directx.h: Windows DirectX video output header file * vout_directx.h: Windows DirectX video output header file
***************************************************************************** *****************************************************************************
* Copyright (C) 1998, 1999, 2000 VideoLAN * Copyright (C) 1998, 1999, 2000 VideoLAN
* $Id: vout_directx.h,v 1.6.2.1 2002/07/29 16:22:14 gbazin Exp $ * $Id: vout_directx.h,v 1.6.2.2 2002/10/01 20:17:01 ipkiss Exp $
* *
* Authors: Gildas Bazin <gbazin@netcourrier.com> * Authors: Gildas Bazin <gbazin@netcourrier.com>
* *
...@@ -107,3 +107,4 @@ void DirectXUpdateOverlay( vout_thread_t *p_vout ); ...@@ -107,3 +107,4 @@ void DirectXUpdateOverlay( vout_thread_t *p_vout );
* Constants * Constants
*****************************************************************************/ *****************************************************************************/
#define WM_VLC_HIDE_MOUSE WM_APP #define WM_VLC_HIDE_MOUSE WM_APP
#define IDM_TOGGLE_ON_TOP WM_USER + 1
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* vout_events.c: Windows DirectX video output events handler * vout_events.c: Windows DirectX video output events handler
***************************************************************************** *****************************************************************************
* Copyright (C) 2001 VideoLAN * Copyright (C) 2001 VideoLAN
* $Id: vout_events.c,v 1.18.2.3 2002/07/29 16:22:14 gbazin Exp $ * $Id: vout_events.c,v 1.18.2.4 2002/10/01 20:17:01 ipkiss Exp $
* *
* Authors: Gildas Bazin <gbazin@netcourrier.com> * Authors: Gildas Bazin <gbazin@netcourrier.com>
* *
...@@ -245,6 +245,7 @@ static int DirectXCreateWindow( vout_thread_t *p_vout ) ...@@ -245,6 +245,7 @@ static int DirectXCreateWindow( vout_thread_t *p_vout )
COLORREF colorkey; COLORREF colorkey;
HDC hdc; HDC hdc;
HICON vlc_icon = NULL; HICON vlc_icon = NULL;
HMENU hMenu;
char vlc_path[_MAX_PATH+1]; char vlc_path[_MAX_PATH+1];
intf_WarnMsg( 3, "vout: DirectXCreateWindow" ); intf_WarnMsg( 3, "vout: DirectXCreateWindow" );
...@@ -366,6 +367,11 @@ static int DirectXCreateWindow( vout_thread_t *p_vout ) ...@@ -366,6 +367,11 @@ static int DirectXCreateWindow( vout_thread_t *p_vout )
* We need to use SetWindowLongPtr when it is available in mingw */ * We need to use SetWindowLongPtr when it is available in mingw */
SetWindowLong( p_vout->p_sys->hwnd, GWL_USERDATA, (LONG)p_vout ); SetWindowLong( p_vout->p_sys->hwnd, GWL_USERDATA, (LONG)p_vout );
/* append a "Always On Top" entry in the system menu */
hMenu = GetSystemMenu( p_vout->p_sys->hwnd, FALSE );
AppendMenu( hMenu, MF_SEPARATOR, 0, "" );
AppendMenu( hMenu, MF_STRING | MF_UNCHECKED, IDM_TOGGLE_ON_TOP, "Always on &Top");
/* now display the window */ /* now display the window */
ShowWindow(p_vout->p_sys->hwnd, SW_SHOW); ShowWindow(p_vout->p_sys->hwnd, SW_SHOW);
...@@ -546,6 +552,30 @@ static long FAR PASCAL DirectXEventProc( HWND hwnd, UINT message, ...@@ -546,6 +552,30 @@ static long FAR PASCAL DirectXEventProc( HWND hwnd, UINT message,
case SC_MONITORPOWER: /* catch the monitor turn-off */ case SC_MONITORPOWER: /* catch the monitor turn-off */
intf_WarnMsg( 3, "vout: WinProc WM_SYSCOMMAND" ); intf_WarnMsg( 3, "vout: WinProc WM_SYSCOMMAND" );
return 0; /* this stops them from happening */ return 0; /* this stops them from happening */
case IDM_TOGGLE_ON_TOP: /* toggle the "on top" status */
{
HMENU hMenu = GetSystemMenu( hwnd , FALSE );
// Check if the window is already on top
if( GetWindowLong( hwnd, GWL_EXSTYLE ) & WS_EX_TOPMOST )
{
CheckMenuItem( hMenu, IDM_TOGGLE_ON_TOP,
MF_BYCOMMAND | MFS_UNCHECKED );
SetWindowPos( hwnd, HWND_NOTOPMOST,
0, 0, 0, 0,
SWP_NOSIZE | SWP_NOMOVE );
}
else
{
CheckMenuItem( hMenu, IDM_TOGGLE_ON_TOP,
MF_BYCOMMAND | MFS_CHECKED );
SetWindowPos( hwnd, HWND_TOPMOST,
0, 0, 0, 0,
SWP_NOSIZE | SWP_NOMOVE );
}
return 0;
break;
}
} }
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment