/*****************************************************************************
* event_thread_t: event thread
*****************************************************************************/
-typedef struct event_thread_t
-{
- VLC_COMMON_MEMBERS
-
- vout_thread_t * p_vout;
- HANDLE window_ready;
-
-} event_thread_t;
+#include "events.h"
#ifdef MODULE_NAME_IS_wingapi
typedef struct GXDisplayProperties {
struct vout_window_t *parent_window; /* Parent window VLC object */
HWND hparent; /* Handle of the parent window */
HWND hfswnd; /* Handle of the fullscreen window */
- WNDPROC pf_wndproc; /* Window handling callback */
/* Multi-monitor support */
HMONITOR hmonitor; /* handle of the current monitor */
/* size of the overall window (including black bands) */
RECT rect_parent;
- /* Window position and size */
- int i_window_x;
- int i_window_y;
- int i_window_width;
- int i_window_height;
- int i_window_style;
-
volatile uint16_t i_changes; /* changes made to the video display */
- /* Mouse */
- volatile bool b_cursor_hidden;
- volatile mtime_t i_lastmoved;
- mtime_t i_mouse_hide_timeout;
-
/* Misc */
bool b_on_top_change;
LPDIRECTDRAWSURFACE2 p_current_surface; /* surface currently displayed */
LPDIRECTDRAWCLIPPER p_clipper; /* clipper used for blitting */
HINSTANCE hddraw_dll; /* handle of the opened ddraw dll */
+ vlc_mutex_t lock;
#endif
#ifdef MODULE_NAME_IS_glwin32
RGBQUAD green;
RGBQUAD blue;
- bool b_focus;
- bool b_parent_focus;
-
HINSTANCE gapi_dll; /* handle of the opened gapi dll */
/* GAPI functions */
int (*GXResume)();
#endif
-#ifndef UNDER_CE
- /* suspend display */
- bool b_suspend_display;
-#endif
-
event_thread_t *p_event;
- vlc_mutex_t lock;
};
#ifdef MODULE_NAME_IS_wingapi
*****************************************************************************/
int DirectDrawUpdateOverlay( vout_thread_t *p_vout );
-/*****************************************************************************
- * Prototypes from events.c
- *****************************************************************************/
-int CreateEventThread( vout_thread_t *p_vout );
-void StopEventThread ( vout_thread_t *p_vout );
-
/*****************************************************************************
* Prototypes from common.c
*****************************************************************************/
-int CommonInit( vout_thread_t * );
+int CommonInit( vout_thread_t * );
void CommonClean( vout_thread_t * );
+void CommonManage( vout_thread_t * );
int Control( vout_thread_t *p_vout, int i_query, va_list args );
void UpdateRects ( vout_thread_t *p_vout, bool b_force );
void Win32ToggleFullscreen ( vout_thread_t *p_vout );
+void ExitFullscreen( vout_thread_t *p_vout );
#ifndef UNDER_CE
void DisableScreensaver ( vout_thread_t *p_vout );
void RestoreScreensaver ( vout_thread_t *p_vout );
/*****************************************************************************
* Constants
*****************************************************************************/
-#define WM_VLC_HIDE_MOUSE WM_APP
-#define WM_VLC_SHOW_MOUSE WM_APP + 1
-#define WM_VLC_CHANGE_TEXT WM_APP + 2
#define IDM_TOGGLE_ON_TOP WM_USER + 1
#define DX_POSITION_CHANGE 0x1000
#define DX_WALLPAPER_CHANGE 0x2000
#define DX_DESKTOP_CHANGE 0x4000
-#define EVENT_THREAD_ENDED 0x6000
-#define SWITCHING_MODE_FLAG 0x8000
/*****************************************************************************
* WinCE helpers