Commit 2bc86e32 authored by Gildas Bazin's avatar Gildas Bazin

* modules/gui/wxwindows/video.cpp: before resizing the interface when a video...

* modules/gui/wxwindows/video.cpp: before resizing the interface when a video stops, wait a bit just to make sure a new video outut is not being spawned.
parent 687d5974
...@@ -65,12 +65,14 @@ private: ...@@ -65,12 +65,14 @@ private:
vout_thread_t *p_vout; vout_thread_t *p_vout;
wxWindow *p_parent; wxWindow *p_parent;
vlc_mutex_t lock; vlc_mutex_t lock;
mtime_t i_release_time;
wxWindow *p_child_window; wxWindow *p_child_window;
void UpdateSize( wxSizeEvent & ); void UpdateSize( wxSizeEvent & );
void UpdateHide( wxSizeEvent & ); void UpdateHide( wxSizeEvent & );
void OnControlEvent( wxCommandEvent & ); void OnControlEvent( wxCommandEvent & );
void OnIdle( wxIdleEvent& event );
DECLARE_EVENT_TABLE(); DECLARE_EVENT_TABLE();
}; };
...@@ -78,6 +80,8 @@ private: ...@@ -78,6 +80,8 @@ private:
DEFINE_LOCAL_EVENT_TYPE( wxEVT_VLC_VIDEO ); DEFINE_LOCAL_EVENT_TYPE( wxEVT_VLC_VIDEO );
BEGIN_EVENT_TABLE(VideoWindow, wxWindow) BEGIN_EVENT_TABLE(VideoWindow, wxWindow)
EVT_IDLE( VideoWindow::OnIdle )
EVT_CUSTOM( wxEVT_SIZE, UpdateSize_Event, VideoWindow::UpdateSize ) EVT_CUSTOM( wxEVT_SIZE, UpdateSize_Event, VideoWindow::UpdateSize )
EVT_CUSTOM( wxEVT_SIZE, UpdateHide_Event, VideoWindow::UpdateHide ) EVT_CUSTOM( wxEVT_SIZE, UpdateHide_Event, VideoWindow::UpdateHide )
EVT_COMMAND( SetStayOnTop_Event, wxEVT_VLC_VIDEO, EVT_COMMAND( SetStayOnTop_Event, wxEVT_VLC_VIDEO,
...@@ -105,6 +109,7 @@ VideoWindow::VideoWindow( intf_thread_t *_p_intf, wxWindow *_p_parent ): ...@@ -105,6 +109,7 @@ VideoWindow::VideoWindow( intf_thread_t *_p_intf, wxWindow *_p_parent ):
vlc_mutex_init( p_intf, &lock ); vlc_mutex_init( p_intf, &lock );
p_vout = NULL; p_vout = NULL;
i_release_time = 0;
p_intf->pf_request_window = ::GetWindow; p_intf->pf_request_window = ::GetWindow;
p_intf->pf_release_window = ::ReleaseWindow; p_intf->pf_release_window = ::ReleaseWindow;
...@@ -187,9 +192,15 @@ void *VideoWindow::GetWindow( vout_thread_t *_p_vout, ...@@ -187,9 +192,15 @@ void *VideoWindow::GetWindow( vout_thread_t *_p_vout,
p_vout = _p_vout; p_vout = _p_vout;
wxSizeEvent event( wxSize(*pi_width_hint, *pi_height_hint), /* Re-use window if possible */
UpdateSize_Event ); if( i_release_time <= 0 );
AddPendingEvent( event ); {
wxSizeEvent event( wxSize(*pi_width_hint, *pi_height_hint),
UpdateSize_Event );
AddPendingEvent( event );
}
i_release_time = 0;
vlc_mutex_unlock( &lock ); vlc_mutex_unlock( &lock );
#ifdef __WXGTK__ #ifdef __WXGTK__
...@@ -224,11 +235,7 @@ void VideoWindow::ReleaseWindow( void *p_window ) ...@@ -224,11 +235,7 @@ void VideoWindow::ReleaseWindow( void *p_window )
vlc_mutex_lock( &lock ); vlc_mutex_lock( &lock );
p_vout = NULL; p_vout = NULL;
i_release_time = mdate();
#if defined(__WXGTK__) || defined(WIN32)
wxSizeEvent event( wxSize(0, 0), UpdateHide_Event );
AddPendingEvent( event );
#endif
vlc_mutex_unlock( &lock ); vlc_mutex_unlock( &lock );
} }
...@@ -272,6 +279,28 @@ void VideoWindow::OnControlEvent( wxCommandEvent &event ) ...@@ -272,6 +279,28 @@ void VideoWindow::OnControlEvent( wxCommandEvent &event )
} }
} }
void VideoWindow::OnIdle( wxIdleEvent& WXUNUSED(event) )
{
vlc_bool_t b_cleanup = VLC_FALSE;
/* Cleanup the video window if needed */
vlc_mutex_lock( &lock );
if( i_release_time && i_release_time + 100000 < mdate() )
{
b_cleanup = VLC_TRUE;
i_release_time = 0;
}
vlc_mutex_unlock( &lock );
if( b_cleanup )
{
#if defined(__WXGTK__) || defined(WIN32)
wxSizeEvent event( wxSize(0, 0), UpdateHide_Event );
AddPendingEvent( event );
#endif
}
}
static int ControlWindow( intf_thread_t *p_intf, void *p_window, static int ControlWindow( intf_thread_t *p_intf, void *p_window,
int i_query, va_list args ) int i_query, va_list args )
{ {
......
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