Commit d5f52eba authored by Olivier Teulière's avatar Olivier Teulière

* ./modules/gui/wxwindows: added a log window

parent bd92601c
...@@ -2,6 +2,7 @@ SOURCES_wxwindows = \ ...@@ -2,6 +2,7 @@ SOURCES_wxwindows = \
modules/gui/wxwindows/wxwindows.cpp \ modules/gui/wxwindows/wxwindows.cpp \
modules/gui/wxwindows/wxwindows.h \ modules/gui/wxwindows/wxwindows.h \
modules/gui/wxwindows/interface.cpp \ modules/gui/wxwindows/interface.cpp \
modules/gui/wxwindows/messages.cpp \
modules/gui/wxwindows/playlist.cpp \ modules/gui/wxwindows/playlist.cpp \
modules/gui/wxwindows/popup.cpp \ modules/gui/wxwindows/popup.cpp \
modules/gui/wxwindows/timer.cpp \ modules/gui/wxwindows/timer.cpp \
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* interface.cpp : wxWindows plugin for vlc * interface.cpp : wxWindows plugin for vlc
***************************************************************************** *****************************************************************************
* Copyright (C) 2000-2001 VideoLAN * Copyright (C) 2000-2001 VideoLAN
* $Id: interface.cpp,v 1.10 2002/12/08 19:56:04 gbazin Exp $ * $Id: interface.cpp,v 1.11 2002/12/15 18:37:39 ipkiss Exp $
* *
* Authors: Gildas Bazin <gbazin@netcourrier.com> * Authors: Gildas Bazin <gbazin@netcourrier.com>
* *
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
...@@ -109,6 +109,7 @@ BEGIN_EVENT_TABLE(Interface, wxFrame) ...@@ -109,6 +109,7 @@ BEGIN_EVENT_TABLE(Interface, wxFrame)
EVT_MENU(Exit_Event, Interface::OnExit) EVT_MENU(Exit_Event, Interface::OnExit)
EVT_MENU(About_Event, Interface::OnAbout) EVT_MENU(About_Event, Interface::OnAbout)
EVT_MENU(Playlist_Event, Interface::OnPlaylist) EVT_MENU(Playlist_Event, Interface::OnPlaylist)
EVT_MENU(Logs_Event, Interface::OnLogs)
EVT_MENU(OpenFile_Event, Interface::OnOpenFile) EVT_MENU(OpenFile_Event, Interface::OnOpenFile)
/* Toolbar events */ /* Toolbar events */
EVT_MENU(OpenFile_Event, Interface::OnOpenFile) EVT_MENU(OpenFile_Event, Interface::OnOpenFile)
...@@ -147,7 +148,7 @@ Interface::Interface( intf_thread_t *_p_intf ): ...@@ -147,7 +148,7 @@ Interface::Interface( intf_thread_t *_p_intf ):
/* Creation of the slider sub-window */ /* Creation of the slider sub-window */
CreateOurSlider(); CreateOurSlider();
/* Creation of the status bar /* Creation of the status bar
* Helptext for menu items and toolbar tools will automatically get * Helptext for menu items and toolbar tools will automatically get
* displayed here. */ * displayed here. */
int i_status_width[2] = {-2,-3}; int i_status_width[2] = {-2,-3};
...@@ -347,6 +348,16 @@ void Interface::OnPlaylist( wxCommandEvent& WXUNUSED(event) ) ...@@ -347,6 +348,16 @@ void Interface::OnPlaylist( wxCommandEvent& WXUNUSED(event) )
} }
} }
void Interface::OnLogs( wxCommandEvent& WXUNUSED(event) )
{
/* Show/hide the log window */
wxFrame *p_messages_window = p_intf->p_sys->p_messages_window;
if( p_messages_window )
{
p_messages_window->Show( ! p_messages_window->IsShown() );
}
}
void Interface::OnOpenFile( wxCommandEvent& WXUNUSED(event) ) void Interface::OnOpenFile( wxCommandEvent& WXUNUSED(event) )
{ {
wxFileDialog dialog( this, _("Open file"), _(""), _(""), _("*.*") ); wxFileDialog dialog( this, _("Open file"), _(""), _(""), _("*.*") );
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* timer.cpp : wxWindows plugin for vlc * timer.cpp : wxWindows plugin for vlc
***************************************************************************** *****************************************************************************
* Copyright (C) 2000-2001 VideoLAN * Copyright (C) 2000-2001 VideoLAN
* $Id: timer.cpp,v 1.6 2002/12/13 01:50:32 gbazin Exp $ * $Id: timer.cpp,v 1.7 2002/12/15 18:37:39 ipkiss Exp $
* *
* Authors: Gildas Bazin <gbazin@netcourrier.com> * Authors: Gildas Bazin <gbazin@netcourrier.com>
* *
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
...@@ -109,14 +109,7 @@ void Timer::Notify() ...@@ -109,14 +109,7 @@ void Timer::Notify()
} }
/* Update the log window */ /* Update the log window */
vlc_mutex_lock( p_intf->p_sys->p_sub->p_lock ); p_intf->p_sys->p_messages_window->UpdateLog();
i_stop = *p_intf->p_sys->p_sub->pi_stop;
vlc_mutex_unlock( p_intf->p_sys->p_sub->p_lock );
if( p_intf->p_sys->p_sub->i_start != i_stop )
{
/* Append all messages to log window */
}
/* Update the playlist */ /* Update the playlist */
p_intf->p_sys->p_playlist_window->Manage(); p_intf->p_sys->p_playlist_window->Manage();
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* wxwindows.cpp : wxWindows plugin for vlc * wxwindows.cpp : wxWindows plugin for vlc
***************************************************************************** *****************************************************************************
* Copyright (C) 2000-2001 VideoLAN * Copyright (C) 2000-2001 VideoLAN
* $Id: wxwindows.cpp,v 1.8 2002/12/13 01:50:32 gbazin Exp $ * $Id: wxwindows.cpp,v 1.9 2002/12/15 18:37:39 ipkiss Exp $
* *
* Authors: Gildas Bazin <gbazin@netcourrier.com> * Authors: Gildas Bazin <gbazin@netcourrier.com>
* *
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
...@@ -198,10 +198,13 @@ bool Instance::OnInit() ...@@ -198,10 +198,13 @@ bool Instance::OnInit()
/* Create the playlist window */ /* Create the playlist window */
p_intf->p_sys->p_playlist_window = new Playlist( p_intf, MainInterface ); p_intf->p_sys->p_playlist_window = new Playlist( p_intf, MainInterface );
/* Create the log window */
p_intf->p_sys->p_messages_window = new Messages( p_intf, MainInterface );
/* Show the interface */ /* Show the interface */
MainInterface->Show(TRUE); MainInterface->Show( TRUE );
SetTopWindow(MainInterface); SetTopWindow( MainInterface );
/* Start timer */ /* Start timer */
new Timer( p_intf, MainInterface ); new Timer( p_intf, MainInterface );
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* wxwindows.h: private wxWindows interface description * wxwindows.h: private wxWindows interface description
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000 VideoLAN * Copyright (C) 1999, 2000 VideoLAN
* $Id: wxwindows.h,v 1.5 2002/12/13 01:50:32 gbazin Exp $ * $Id: wxwindows.h,v 1.6 2002/12/15 18:37:39 ipkiss Exp $
* *
* Authors: Gildas Bazin <gbazin@netcourrier.com> * Authors: Gildas Bazin <gbazin@netcourrier.com>
* *
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
...@@ -22,9 +22,11 @@ ...@@ -22,9 +22,11 @@
*****************************************************************************/ *****************************************************************************/
#include <wx/listctrl.h> #include <wx/listctrl.h>
#include <wx/textctrl.h>
#include <wx/dnd.h> #include <wx/dnd.h>
class Playlist; class Playlist;
class Messages;
#define SLIDER_MAX_POS 10000 #define SLIDER_MAX_POS 10000
...@@ -38,6 +40,7 @@ struct intf_sys_t ...@@ -38,6 +40,7 @@ struct intf_sys_t
/* secondary windows */ /* secondary windows */
Playlist *p_playlist_window; Playlist *p_playlist_window;
Messages *p_messages_window;
/* special actions */ /* special actions */
vlc_bool_t b_playing; vlc_bool_t b_playing;
...@@ -47,7 +50,7 @@ struct intf_sys_t ...@@ -47,7 +50,7 @@ struct intf_sys_t
vlc_bool_t b_slider_free; /* slider status */ vlc_bool_t b_slider_free; /* slider status */
/* menus handlers */ /* menus handlers */
vlc_bool_t b_program_update; /* do we need to update programs vlc_bool_t b_program_update; /* do we need to update programs
menu */ menu */
vlc_bool_t b_title_update; /* do we need to update title menus */ vlc_bool_t b_title_update; /* do we need to update title menus */
vlc_bool_t b_chapter_update; /* do we need to update vlc_bool_t b_chapter_update; /* do we need to update
...@@ -121,7 +124,9 @@ private: ...@@ -121,7 +124,9 @@ private:
/* Event handlers (these functions should _not_ be virtual) */ /* Event handlers (these functions should _not_ be virtual) */
void OnExit( wxCommandEvent& event ); void OnExit( wxCommandEvent& event );
void OnAbout( wxCommandEvent& event ); void OnAbout( wxCommandEvent& event );
void OnMessages( wxCommandEvent& event );
void OnPlaylist( wxCommandEvent& event ); void OnPlaylist( wxCommandEvent& event );
void OnLogs( wxCommandEvent& event );
void OnOpenFile( wxCommandEvent& event ); void OnOpenFile( wxCommandEvent& event );
void OnPlayStream( wxCommandEvent& event ); void OnPlayStream( wxCommandEvent& event );
void OnStopStream( wxCommandEvent& event ); void OnStopStream( wxCommandEvent& event );
...@@ -136,6 +141,31 @@ private: ...@@ -136,6 +141,31 @@ private:
intf_thread_t *p_intf; intf_thread_t *p_intf;
}; };
/* Messages */
class Messages: public wxFrame
{
public:
/* Constructor */
Messages( intf_thread_t *p_intf, Interface *_p_main_interface );
virtual ~Messages();
void UpdateLog();
private:
/* Event handlers (these functions should _not_ be virtual) */
void OnClose( wxCommandEvent& event );
DECLARE_EVENT_TABLE();
intf_thread_t *p_intf;
Interface *p_main_interface;
wxButton *ok_button;
wxTextCtrl *textctrl;
wxTextAttr *info_attr;
wxTextAttr *err_attr;
wxTextAttr *warn_attr;
wxTextAttr *dbg_attr;
};
/* Playlist */ /* Playlist */
class Playlist: public wxFrame class Playlist: public wxFrame
{ {
...@@ -147,6 +177,8 @@ public: ...@@ -147,6 +177,8 @@ public:
void Manage(); void Manage();
private: private:
void DeleteItem( int item );
/* Event handlers (these functions should _not_ be virtual) */ /* Event handlers (these functions should _not_ be virtual) */
void OnAddUrl( wxCommandEvent& event ); void OnAddUrl( wxCommandEvent& event );
void OnAddDirectory( wxCommandEvent& event ); void OnAddDirectory( wxCommandEvent& event );
...@@ -159,7 +191,6 @@ private: ...@@ -159,7 +191,6 @@ private:
DECLARE_EVENT_TABLE(); DECLARE_EVENT_TABLE();
void DeleteItem( int item );
intf_thread_t *p_intf; intf_thread_t *p_intf;
Interface *p_main_interface; Interface *p_main_interface;
wxListView *listview; wxListView *listview;
......
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