/*****************************************************************************
* wxwindows.h: private wxWindows interface description
*****************************************************************************
- * Copyright (C) 1999, 2000 VideoLAN
- * $Id: wxwindows.h,v 1.83 2004/01/05 13:00:39 zorglub Exp $
+ * Copyright (C) 1999-2005 the VideoLAN team
+ * $Id$
*
- * Authors: Gildas Bazin <gbazin@netcourrier.com>
+ * Authors: Gildas Bazin <gbazin@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
#include <wx/gauge.h>
#include <wx/accel.h>
#include <wx/checkbox.h>
+#include <wx/wizard.h>
+#include <wx/taskbar.h>
#include "vlc_keys.h"
-DECLARE_LOCAL_EVENT_TYPE( wxEVT_DIALOG, 0 );
+#if (!wxCHECK_VERSION(2,5,0))
+typedef long wxTreeItemIdValue;
+#endif
-class OpenDialog;
-class Playlist;
-class Messages;
-class FileInfo;
+DECLARE_LOCAL_EVENT_TYPE( wxEVT_DIALOG, 0 );
+DECLARE_LOCAL_EVENT_TYPE( wxEVT_INTF, 1 );
#define SLIDER_MAX_POS 10000
/* wxU is used to convert ansi/utf8 strings to unicode strings (wchar_t) */
-#if defined( ENABLE_NLS ) && defined( HAVE_GETTEXT ) && \
- defined( WIN32 ) && !defined( HAVE_INCLUDED_GETTEXT )
+#if defined( ENABLE_NLS ) && defined( ENABLE_UTF8 )
#if wxUSE_UNICODE
# define wxU(utf8) wxString(utf8, wxConvUTF8)
#else
#endif
#define ISUTF8 1
-#else // ENABLE_NLS && HAVE_GETTEXT && WIN32 && !HAVE_INCLUDED_GETTEXT
+#else // ENABLE_NLS && ENABLE_UTF8
#if wxUSE_UNICODE
-# define wxU(ansi) wxString(ansi, *wxConvCurrent)
+# define wxU(ansi) wxString(ansi, wxConvLocal)
#else
-# define wxU(ansi) ansi
+# define wxU(ansi) (ansi)
#endif
#define ISUTF8 0
/* wxL2U (locale to unicode) is used to convert ansi strings to unicode
* strings (wchar_t) */
-#if wxUSE_UNICODE
-# define wxL2U(ansi) wxString(ansi, *wxConvCurrent)
-#else
-# define wxL2U(ansi) ansi
-#endif
+#define wxL2U(ansi) wxU(ansi)
#define WRAPCOUNT 80
#define MODE_AUTHOR 2
#define MODE_TITLE 3
-wxArrayString SeparateEntries( wxString );
+enum{
+ ID_CONTROLS_TIMER,
+ ID_SLIDER_TIMER,
+};
+
+class DialogsProvider;
+class PrefsTreeCtrl;
+class AutoBuiltPanel;
+class VideoWindow;
+class WindowSettings;
/*****************************************************************************
* intf_sys_t: description and status of wxwindows interface
wxWindow *p_wxwindow;
wxIcon *p_icon;
+ /* window settings */
+ WindowSettings *p_window_settings;
+
/* special actions */
vlc_bool_t b_playing;
+ vlc_bool_t b_intf_show; /* interface to be shown */
/* The input thread */
input_thread_t * p_input;
/* Playlist management */
int i_playing; /* playlist selected item */
+ unsigned i_playlist_usage;
/* Send an event to show a dialog */
void (*pf_show_dialog) ( intf_thread_t *p_intf, int i_dialog, int i_arg,
/* Popup menu */
wxMenu *p_popup_menu;
+ /* Hotkeys */
+ int i_first_hotkey_event;
+ int i_hotkeys;
+
+ /* Embedded vout */
+ VideoWindow *p_video_window;
+ wxBoxSizer *p_video_sizer;
+ vlc_bool_t b_video_autosize;
+
+ /* Aout */
+ aout_instance_t *p_aout;
};
/*****************************************************************************
* Prototypes
*****************************************************************************/
+wxArrayString SeparateEntries( wxString );
+wxWindow *CreateVideoWindow( intf_thread_t *p_intf, wxWindow *p_parent );
+void UpdateVideoWindow( intf_thread_t *p_intf, wxWindow *p_window );
+wxWindow *BookmarksDialog( intf_thread_t *p_intf, wxWindow *p_parent );
+wxWindow *CreateDialogsProvider( intf_thread_t *p_intf, wxWindow *p_parent );
+
+namespace wxvlc
+{
+class Interface;
+class OpenDialog;
+class SoutDialog;
+class SubsFileDialog;
+class Playlist;
+class Messages;
+class FileInfo;
+class StreamDialog;
+class WizardDialog;
+class ItemInfoDialog;
+class NewGroup;
+class ExportPlaylist;
/*****************************************************************************
* Classes declarations.
*****************************************************************************/
-class Interface;
-
/* Timer */
class Timer: public wxTimer
{
virtual void Notify();
private:
+ //use wxWindow::IsShown instead
+ //vlc_bool_t b_slider_shown;
+ //vlc_bool_t b_disc_shown;
intf_thread_t *p_intf;
Interface *p_main_interface;
+ vlc_bool_t b_init;
int i_old_playing_status;
int i_old_rate;
};
+
+/* Extended panel */
+class ExtraPanel: public wxPanel
+{
+public:
+ /* Constructor */
+ ExtraPanel( intf_thread_t *p_intf, wxWindow *p_parent );
+ virtual ~ExtraPanel();
+
+ wxStaticBox *adjust_box;
+ wxButton *restoredefaults_button;
+ wxSlider *brightness_slider;
+ wxSlider *contrast_slider;
+ wxSlider *saturation_slider;
+ wxSlider *hue_slider;
+ wxSlider *gamma_slider;
+
+ wxStaticBox *other_box;
+ wxComboBox *ratio_combo;
+
+ char *psz_bands;
+ float f_preamp;
+ vlc_bool_t b_update;
+
+private:
+
+ wxPanel *VideoPanel( wxWindow * );
+ wxPanel *EqzPanel( wxWindow * );
+ wxPanel *AudioPanel( wxWindow * );
+
+ wxNotebook *notebook;
+
+ wxCheckBox *eq_chkbox;
+
+ wxCheckBox *eq_2p_chkbox;
+
+ wxButton *eq_restoredefaults_button;
+
+ wxSlider *smooth_slider;
+ wxStaticText *smooth_text;
+
+ wxSlider *preamp_slider;
+ wxStaticText * preamp_text;
+
+ int i_smooth;
+ wxWindow *p_parent;
+
+ wxSlider *band_sliders[10];
+ wxStaticText *band_texts[10];
+
+ int i_values[10];
+
+ void CheckAout();
+
+ /* Event handlers (these functions should _not_ be virtual) */
+
+ void OnEnableAdjust( wxCommandEvent& );
+ void OnEnableEqualizer( wxCommandEvent& );
+ void OnRestoreDefaults( wxCommandEvent& );
+ void OnChangeEqualizer( wxScrollEvent& );
+ void OnAdjustUpdate( wxScrollEvent& );
+ void OnRatio( wxCommandEvent& );
+ void OnFiltersInfo( wxCommandEvent& );
+ void OnSelectFilter( wxCommandEvent& );
+
+ void OnEqSmooth( wxScrollEvent& );
+ void OnPreamp( wxScrollEvent& );
+ void OnEq2Pass( wxCommandEvent& );
+ void OnEqRestore( wxCommandEvent& );
+
+ void OnHeadphone( wxCommandEvent& );
+ void OnNormvol( wxCommandEvent& );
+ void OnNormvolSlider( wxScrollEvent& );
+
+ void OnIdle( wxIdleEvent& );
+
+ DECLARE_EVENT_TABLE();
+
+ intf_thread_t *p_intf;
+ vlc_bool_t b_my_update;
+};
+
+#if 0
+/* Extended Window */
+class ExtraWindow: public wxFrame
+{
+public:
+ /* Constructor */
+ ExtraWindow( intf_thread_t *p_intf, wxWindow *p_parent, wxPanel *panel );
+ virtual ~ExtraWindow();
+
+private:
+
+ wxPanel *panel;
+
+ DECLARE_EVENT_TABLE();
+
+ intf_thread_t *p_intf;
+};
+#endif
+
+/* Systray integration */
+#ifdef wxHAS_TASK_BAR_ICON
+class Systray: public wxTaskBarIcon
+{
+public:
+ Systray( Interface* p_main_interface, intf_thread_t *p_intf );
+ virtual ~Systray() {};
+ wxMenu* CreatePopupMenu();
+ void UpdateTooltip( const wxChar* tooltip );
+
+private:
+ void OnMenuIconize( wxCommandEvent& event );
+ void OnLeftClick( wxTaskBarIconEvent& event );
+ void OnPlayStream ( wxCommandEvent& event );
+ void OnStopStream ( wxCommandEvent& event );
+ void OnPrevStream ( wxCommandEvent& event );
+ void OnNextStream ( wxCommandEvent& event );
+ void OnExit( wxCommandEvent& event );
+ Interface* p_main_interface;
+ intf_thread_t *p_intf;
+ DECLARE_EVENT_TABLE()
+};
+#endif
+
/* Main Interface */
class Interface: public wxFrame
{
public:
/* Constructor */
- Interface( intf_thread_t *p_intf );
+ Interface( intf_thread_t *p_intf, long style = wxDEFAULT_FRAME_STYLE );
virtual ~Interface();
+ void Init();
void TogglePlayButton( int i_playing_status );
+ void Update();
+ void PlayStream();
+ void StopStream();
+ void PrevStream();
+ void NextStream();
-// wxFlexGridSizer *frame_sizer;
wxBoxSizer *frame_sizer;
wxStatusBar *statusbar;
+ void HideSlider(bool layout = true);
+ void ShowSlider(bool show = true, bool layout = true);
+
wxSlider *slider;
wxWindow *slider_frame;
- wxWindow *extra_frame;
- wxStaticBox *slider_box;
+ wxBoxSizer *slider_sizer;
+ wxPanel *extra_frame;
+
+ void HideDiscFrame(bool layout = true);
+ void ShowDiscFrame(bool show = true, bool layout = true);
+
+ wxPanel *disc_frame;
+ wxBoxSizer *disc_sizer;
+ wxBitmapButton *disc_menu_button;
+ wxBitmapButton *disc_prev_button;
+ wxBitmapButton *disc_next_button;
+
+ wxFrame *extra_window;
vlc_bool_t b_extra;
+ vlc_bool_t b_undock;
- wxStaticBox *adjust_box;
- wxSlider *brightness_slider;
- wxSlider *contrast_slider;
- wxSlider *saturation_slider;
- wxSlider *hue_slider;
+ wxControl *volctrl;
- wxStaticBox *other_box;
- wxComboBox *ratio_combo;
+#ifdef wxHAS_TASK_BAR_ICON
+ Systray *p_systray;
+#endif
- wxGauge *volctrl;
+ wxTimer m_controls_timer;
+ wxTimer m_slider_timer;
private:
- void UpdateAcceleratorTable();
+ void SetupHotkeys();
void CreateOurMenuBar();
void CreateOurToolBar();
- void CreateOurExtraPanel();
+ void CreateOurExtendedPanel();
void CreateOurSlider();
void Open( int i_access_method );
/* Event handlers (these functions should _not_ be virtual) */
+ void OnControlsTimer(wxTimerEvent& WXUNUSED(event));
+ void OnSliderTimer(wxTimerEvent& WXUNUSED(event));
+
void OnExit( wxCommandEvent& event );
void OnAbout( wxCommandEvent& event );
void OnOpenFileSimple( wxCommandEvent& event );
+ void OnOpenDir( wxCommandEvent& event );
void OnOpenFile( wxCommandEvent& event );
void OnOpenDisc( wxCommandEvent& event );
void OnOpenNet( wxCommandEvent& event );
void OnOpenSat( wxCommandEvent& event );
- void OnOpenV4L( wxCommandEvent& event );
- void OnStream( wxCommandEvent& event );
- void OnExtra( wxCommandEvent& event );
+
+ void OnExtended( wxCommandEvent& event );
+ //void OnUndock( wxCommandEvent& event );
+
+ void OnBookmarks( wxCommandEvent& event );
void OnShowDialog( wxCommandEvent& event );
void OnPlayStream( wxCommandEvent& event );
void OnStopStream( wxCommandEvent& event );
void OnSlowStream( wxCommandEvent& event );
void OnFastStream( wxCommandEvent& event );
- void OnEnableAdjust( wxCommandEvent& event );
- void OnHueUpdate( wxScrollEvent& event );
- void OnContrastUpdate( wxScrollEvent& event );
- void OnBrightnessUpdate( wxScrollEvent& event );
- void OnSaturationUpdate( wxScrollEvent& event );
-
- void OnRatio( wxCommandEvent& event );
- void OnEnableVisual( wxCommandEvent& event );
+ void OnDiscMenu( wxCommandEvent& event );
+ void OnDiscPrev( wxCommandEvent& event );
+ void OnDiscNext( wxCommandEvent& event );
void OnMenuOpen( wxMenuEvent& event );
#endif
void OnContextMenu(wxMouseEvent& event);
+ void OnControlEvent( wxCommandEvent& event );
+
DECLARE_EVENT_TABLE();
Timer *timer;
intf_thread_t *p_intf;
-private:
+ wxWindow *video_window;
+
int i_old_playing_status;
/* For auto-generated menus */
wxMenu *p_settings_menu;
- vlc_bool_t b_settings_menu;
wxMenu *p_audio_menu;
- vlc_bool_t b_audio_menu;
wxMenu *p_video_menu;
- vlc_bool_t b_video_menu;
wxMenu *p_navig_menu;
- vlc_bool_t b_navig_menu;
-};
-
-class StreamDialog;
-
-/* Dialogs Provider */
-class DialogsProvider: public wxFrame
-{
-public:
- /* Constructor */
- DialogsProvider( intf_thread_t *p_intf, wxWindow *p_parent );
- virtual ~DialogsProvider();
-
-private:
- void Open( int i_access_method, int i_arg );
-
- /* Event handlers (these functions should _not_ be virtual) */
- void OnExit( wxCommandEvent& event );
- void OnPlaylist( wxCommandEvent& event );
- void OnMessages( wxCommandEvent& event );
- void OnFileInfo( wxCommandEvent& event );
- void OnPreferences( wxCommandEvent& event );
- void OnStreamDialog( wxCommandEvent& event );
-
- void OnOpenFileGeneric( wxCommandEvent& event );
- void OnOpenFileSimple( wxCommandEvent& event );
- void OnOpenFile( wxCommandEvent& event );
- void OnOpenDisc( wxCommandEvent& event );
- void OnOpenNet( wxCommandEvent& event );
- void OnOpenSat( wxCommandEvent& event );
-
- void OnPopupMenu( wxCommandEvent& event );
-
- void OnIdle( wxIdleEvent& event );
-
- void OnExitThread( wxCommandEvent& event );
-
- DECLARE_EVENT_TABLE();
-
- intf_thread_t *p_intf;
-
-public:
- /* Secondary windows */
- OpenDialog *p_open_dialog;
- wxFileDialog *p_file_dialog;
- Playlist *p_playlist_dialog;
- Messages *p_messages_dialog;
- FileInfo *p_fileinfo_dialog;
- StreamDialog *p_stream_dialog;
- wxFrame *p_prefs_dialog;
- wxFileDialog *p_file_generic_dialog;
};
/* Open Dialog */
-class AutoBuiltPanel;
WX_DEFINE_ARRAY(AutoBuiltPanel *, ArrayOfAutoBuiltPanel);
-class V4LDialog;
-class SoutDialog;
-class SubsFileDialog;
-class OpenDialog: public wxFrame
+class OpenDialog: public wxDialog
{
public:
/* Constructor */
wxPanel *FilePanel( wxWindow* parent );
wxPanel *DiscPanel( wxWindow* parent );
wxPanel *NetPanel( wxWindow* parent );
- wxPanel *V4LPanel( wxWindow* parent );
ArrayOfAutoBuiltPanel input_tab_array;
/* Event handlers (these functions should _not_ be virtual) */
void OnOk( wxCommandEvent& event );
void OnCancel( wxCommandEvent& event );
+ void OnClose( wxCloseEvent& event );
void OnPageChange( wxNotebookEvent& event );
void OnMRLChange( wxCommandEvent& event );
void OnFileBrowse( wxCommandEvent& event );
/* Event handlers for the disc page */
+ void OnDiscPanelChangeSpin( wxSpinEvent& event );
void OnDiscPanelChange( wxCommandEvent& event );
void OnDiscTypeChange( wxCommandEvent& event );
void OnDiscDeviceChange( wxCommandEvent& event );
/* Event handlers for the net page */
+ void OnNetPanelChangeSpin( wxSpinEvent& event );
void OnNetPanelChange( wxCommandEvent& event );
void OnNetTypeChange( wxCommandEvent& event );
- /* Event handlers for the v4l page */
- void OnV4LPanelChange( wxCommandEvent& event );
- void OnV4LTypeChange( wxCommandEvent& event );
- void OnV4LSettingsChange( wxCommandEvent& event );
-
/* Event handlers for the stream output */
void OnSubsFileEnable( wxCommandEvent& event );
void OnSubsFileSettings( wxCommandEvent& WXUNUSED(event) );
void OnSoutEnable( wxCommandEvent& event );
void OnSoutSettings( wxCommandEvent& WXUNUSED(event) );
+ /* Event handlers for the caching option */
+ void OnCachingEnable( wxCommandEvent& event );
+ void OnCachingChange( wxCommandEvent& event );
+ void OnCachingChangeSpin( wxSpinEvent& event );
+
DECLARE_EVENT_TABLE();
intf_thread_t *p_intf;
int i_disc_type_selection;
int i_method; /* Normal or for the stream dialog ? */
+ int i_open_arg;
+
wxComboBox *mrl_combo;
wxNotebook *notebook;
/* Controls for the disc panel */
wxRadioBox *disc_type;
wxTextCtrl *disc_device;
- wxSpinCtrl *disc_title;
- wxSpinCtrl *disc_chapter;
+ wxSpinCtrl *disc_title; int i_disc_title;
+ wxSpinCtrl *disc_chapter; int i_disc_chapter;
+ wxSpinCtrl *disc_sub; int i_disc_sub;
+ wxSpinCtrl *disc_audio; int i_disc_audio;
/* The media equivalent name for a DVD names. For example,
- "Title", is "Track" for a CD-DA */
+ * "Title", is "Track" for a CD-DA */
wxStaticText *disc_title_label;
wxStaticText *disc_chapter_label;
-
+ wxStaticText *disc_sub_label;
+ wxStaticText *disc_audio_label;
+
/* Indicates if the disc device control was modified */
bool b_disc_device_changed;
-
+
/* Controls for the net panel */
wxRadioBox *net_type;
int i_net_type;
wxSpinCtrl *net_ports[4];
int i_net_ports[4];
wxTextCtrl *net_addrs[4];
+ wxCheckBox *net_timeshift;
wxCheckBox *net_ipv6;
- /* Controls for the v4l panel */
- wxRadioBox *video_type;
- wxTextCtrl *video_device;
- wxSpinCtrl *video_channel;
- wxButton *v4l_button;
- V4LDialog *v4l_dialog;
- wxArrayString v4l_mrl;
-
/* Controls for the subtitles file */
wxButton *subsfile_button;
wxCheckBox *subsfile_checkbox;
wxCheckBox *sout_checkbox;
SoutDialog *sout_dialog;
wxArrayString sout_mrl;
+
+ /* Controls for the caching options */
+ wxCheckBox *caching_checkbox;
+ wxSpinCtrl *caching_value;
+ int i_caching;
};
enum
FILE_ACCESS = 0,
DISC_ACCESS,
NET_ACCESS,
-#ifndef WIN32
- V4L_ACCESS,
-#endif
- MAX_ACCESS,
- FILE_SIMPLE_ACCESS
-};
-
-/* V4L Dialog */
-class V4LDialog: public wxDialog
-{
-public:
- /* Constructor */
- V4LDialog( intf_thread_t *p_intf, wxWindow *p_parent );
- virtual ~V4LDialog();
-
- wxArrayString GetOptions();
-
-private:
- void UpdateMRL();
- wxPanel *AudioPanel( wxWindow* parent );
- wxPanel *CommonPanel( wxWindow* parent );
- wxPanel *BitratePanel( wxWindow* parent );
- void ParseMRL();
-
- /* Event handlers (these functions should _not_ be virtual) */
- void OnOk( wxCommandEvent& event );
- void OnCancel( wxCommandEvent& event );
- void OnMRLChange( wxCommandEvent& event );
- void OnAudioEnable( wxCommandEvent& event );
- void OnAudioChange( wxCommandEvent& event );
- void OnAudioChannel( wxCommandEvent& event );
- void OnSizeEnable( wxCommandEvent& event );
- void OnSize( wxCommandEvent& event );
- void OnNormEnable( wxCommandEvent& event );
- void OnNorm( wxCommandEvent& event );
- void OnFrequencyEnable( wxCommandEvent& event );
- void OnFrequency( wxCommandEvent& event );
- void OnBitrateEnable( wxCommandEvent& event );
- void OnBitrate( wxCommandEvent& event );
- void OnMaxBitrateEnable( wxCommandEvent& event );
- void OnMaxBitrate( wxCommandEvent& event );
-
- DECLARE_EVENT_TABLE();
-
- intf_thread_t *p_intf;
- wxWindow *p_parent;
-
- wxComboBox *mrl_combo;
-
- int i_access_type;
-
- /* Controls for the v4l advanced options */
- wxPanel *common_subpanel;
- wxPanel *common_panel;
- wxCheckBox *size_checkbox;
- wxComboBox *size_combo;
- wxCheckBox *norm_checkbox;
- wxComboBox *norm_combo;
- wxCheckBox *frequency_checkbox;
- wxSpinCtrl *frequency;
-
- wxPanel *audio_subpanel;
- wxPanel *audio_panel;
- wxCheckBox *audio_checkbox;
- wxTextCtrl *audio_device;
- wxSpinCtrl *audio_channel;
-
- wxPanel *bitrate_subpanel;
- wxPanel *bitrate_panel;
- wxCheckBox *bitrate_checkbox;
- wxSpinCtrl *bitrate;
- wxCheckBox *maxbitrate_checkbox;
- wxSpinCtrl *maxbitrate;
+ /* Auto-built panels */
+ CAPTURE_ACCESS
};
+#define MAX_ACCESS CAPTURE_ACCESS
/* Stream output Dialog */
enum
HTTP_ACCESS_OUT,
MMSH_ACCESS_OUT,
UDP_ACCESS_OUT,
- RTP_ACCESS_OUT,
ACCESS_OUT_NUM
};
PS_ENCAPSULATION,
MPEG1_ENCAPSULATION,
OGG_ENCAPSULATION,
- RAW_ENCAPSULATION,
ASF_ENCAPSULATION,
- AVI_ENCAPSULATION,
MP4_ENCAPSULATION,
MOV_ENCAPSULATION,
+ WAV_ENCAPSULATION,
+ RAW_ENCAPSULATION,
+ AVI_ENCAPSULATION,
ENCAPS_NUM
};
void OnNetChange( wxCommandEvent& event );
/* Event specific to the announce address */
+ void OnAnnounceGroupChange( wxCommandEvent& event );
void OnAnnounceAddrChange( wxCommandEvent& event );
/* Event handlers for the encapsulation panel */
wxPanel *misc_subpanels[MISC_SOUT_NUM];
wxCheckBox *sap_checkbox;
wxCheckBox *slp_checkbox;
+ wxTextCtrl *announce_group;
wxTextCtrl *announce_addr;
/* Controls for the encapsulation */
wxComboBox *audio_bitrate_combo;
wxComboBox *audio_channels_combo;
wxComboBox *video_scale_combo;
+ wxComboBox *subtitles_codec_combo;
+ wxCheckBox *subtitles_transc_checkbox;
+ wxCheckBox *subtitles_overlay_checkbox;
+
+ /* Misc controls */
+ wxCheckBox *sout_all_checkbox;
};
/* Subtitles File Dialog */
wxComboBox *file_combo;
wxComboBox *encoding_combo;
- wxSpinCtrl *delay_spinctrl;
+ wxComboBox *size_combo;
+ wxComboBox *align_combo;
wxSpinCtrl *fps_spinctrl;
+ wxSpinCtrl *delay_spinctrl;
private:
/* Event handlers (these functions should _not_ be virtual) */
SoutDialog *p_sout_dialog;
};
+/* Wizard */
+class WizardDialog : public wxWizard
+{
+public:
+ /* Constructor */
+ WizardDialog( intf_thread_t *, wxWindow *p_parent, char *, int, int );
+ virtual ~WizardDialog();
+ void SetTranscode( char const *vcodec, int vb, char const *acodec, int ab);
+ void SetMrl( const char *mrl );
+ void SetTTL( int i_ttl );
+ void SetPartial( int, int );
+ void SetStream( char const *method, char const *address );
+ void SetTranscodeOut( char const *address );
+ void SetAction( int i_action );
+ int GetAction();
+ void SetSAP( bool b_enabled, const char *psz_name );
+ void SetMux( char const *mux );
+ void Run();
+ int i_action;
+ char *method;
+
+protected:
+ int vb,ab;
+ int i_from, i_to, i_ttl;
+ char *vcodec , *acodec , *address , *mrl , *mux ;
+ char *psz_sap_name;
+ bool b_sap;
+ DECLARE_EVENT_TABLE();
+
+ intf_thread_t *p_intf;
+};
/* Preferences Dialog */
-class PrefsTreeCtrl;
class PrefsDialog: public wxFrame
{
public:
void OnSave( wxCommandEvent& event );
void OnResetAll( wxCommandEvent& event );
void OnAdvanced( wxCommandEvent& event );
+ void OnClose( wxCloseEvent& event );
DECLARE_EVENT_TABLE();
private:
/* Event handlers (these functions should _not_ be virtual) */
- void OnClose( wxCommandEvent& event );
+ void OnButtonClose( wxCommandEvent& event );
+ void OnClose( wxCloseEvent& WXUNUSED(event) );
void OnClear( wxCommandEvent& event );
void OnSaveLog( wxCommandEvent& event );
};
/* Playlist */
-class ItemInfoDialog;
-class NewGroup;
class Playlist: public wxFrame
{
public:
void UpdatePlaylist();
void ShowPlaylist( bool show );
void UpdateItem( int );
+ void AppendItem( wxCommandEvent& );
bool b_need_update;
- vlc_mutex_t lock;
private:
+ void RemoveItem( int );
+ void DeleteTreeItem( wxTreeItemId );
void DeleteItem( int item );
- void ShowInfos( int item );
+ void DeleteNode( playlist_item_t *node );
+
+ void RecursiveDeleteSelection( wxTreeItemId );
/* Event handlers (these functions should _not_ be virtual) */
+
+ /* Menu Handlers */
void OnAddFile( wxCommandEvent& event );
+ void OnAddDir( wxCommandEvent& event );
void OnAddMRL( wxCommandEvent& event );
- void OnClose( wxCommandEvent& event );
- void OnSearch( wxCommandEvent& event );
- void OnEnDis( wxCommandEvent& event );
- void OnInfos( wxCommandEvent& event );
- void OnSearchTextChange( wxCommandEvent& event );
+ void OnMenuClose( wxCommandEvent& event );
+ void OnClose( wxCloseEvent& WXUNUSED(event) );
+
+ void OnDeleteSelection( wxCommandEvent& event );
+
void OnOpen( wxCommandEvent& event );
void OnSave( wxCommandEvent& event );
+ /* Search (user) */
+ void OnSearch( wxCommandEvent& event );
+ /*void OnSearchTextChange( wxCommandEvent& event );*/
+ wxTextCtrl *search_text;
+ wxButton *search_button;
+ wxTreeItemId search_current;
+
+ void OnEnDis( wxCommandEvent& event );
+
+ /* Sort */
+ int i_sort_mode;
void OnSort( wxCommandEvent& event );
- void OnColSelect( wxListEvent& event );
+ int i_title_sorted;
+ int i_group_sorted;
+ int i_duration_sorted;
+
+ /* Dynamic menus */
+ void OnMenuEvent( wxCommandEvent& event );
+ void OnMenuOpen( wxMenuEvent& event );
+ wxMenu *p_view_menu;
+ wxMenu *p_sd_menu;
+ wxMenu *ViewMenu();
+ wxMenu *SDMenu();
void OnUp( wxCommandEvent& event);
void OnDown( wxCommandEvent& event);
- void OnEnableSelection( wxCommandEvent& event );
- void OnDisableSelection( wxCommandEvent& event );
- void OnInvertSelection( wxCommandEvent& event );
- void OnDeleteSelection( wxCommandEvent& event );
- void OnSelectAll( wxCommandEvent& event );
void OnRandom( wxCommandEvent& event );
void OnRepeat( wxCommandEvent& event );
void OnLoop ( wxCommandEvent& event );
- void OnActivateItem( wxListEvent& event );
- void OnKeyDown( wxListEvent& event );
+
+ void OnActivateItem( wxTreeEvent& event );
+ void OnKeyDown( wxTreeEvent& event );
void OnNewGroup( wxCommandEvent& event );
- /* Popup functions */
- void OnPopup( wxListEvent& event );
- void OnPopupPlay( wxMenuEvent& event );
- void OnPopupDel( wxMenuEvent& event );
- void OnPopupEna( wxMenuEvent& event );
- void OnPopupInfo( wxMenuEvent& event );
- void Rebuild();
+ /* Popup */
+ wxMenu *item_popup;
+ wxMenu *node_popup;
+ wxTreeItemId i_wx_popup_item;
+ int i_popup_item;
+ int i_popup_parent;
+ void OnPopup( wxContextMenuEvent& event );
+ void OnPopupPlay( wxCommandEvent& event );
+ void OnPopupPreparse( wxCommandEvent& event );
+ void OnPopupSort( wxCommandEvent& event );
+ void OnPopupDel( wxCommandEvent& event );
+ void OnPopupEna( wxCommandEvent& event );
+ void OnPopupInfo( wxCommandEvent& event );
+ void Rebuild( vlc_bool_t );
- wxTextCtrl *search_text;
- wxButton *search_button;
- DECLARE_EVENT_TABLE();
+ void Preparse();
- wxMenu *popup_menu;
+ /* Update */
+ void UpdateNode( playlist_item_t*, wxTreeItemId );
+ void UpdateNodeChildren( playlist_item_t*, wxTreeItemId );
+ void CreateNode( playlist_item_t*, wxTreeItemId );
+ void UpdateTreeItem( wxTreeItemId );
- ItemInfoDialog *iteminfo_dialog;
+ /* Search (internal) */
+ int CountItems( wxTreeItemId);
+ wxTreeItemId FindItem( wxTreeItemId, int );
+ wxTreeItemId FindItemByName( wxTreeItemId, wxString,
+ wxTreeItemId, vlc_bool_t *);
- intf_thread_t *p_intf;
- wxListView *listview;
- wxTreeCtrl *treeview;
- int i_update_counter;
- int i_sort_mode;
+ wxTreeItemId saved_tree_item;
+ int i_saved_id;
- int i_popup_item;
+ playlist_t *p_playlist;
- int i_title_sorted;
- int i_author_sorted;
- int i_group_sorted;
-};
+ /* Custom events */
+ void OnPlaylistEvent( wxCommandEvent& event );
-class NewGroup: public wxDialog
-{
-public:
- /* Constructor */
- NewGroup( intf_thread_t *p_intf, wxWindow *p_parent );
- virtual ~NewGroup();
+ DECLARE_EVENT_TABLE();
-private:
- /* Event handlers (these functions should _not_ be virtual) */
- void OnOk( wxCommandEvent& event );
- void OnCancel( wxCommandEvent& event );
+ /* Global widgets */
+ wxStatusBar *statusbar;
+ ItemInfoDialog *iteminfo_dialog;
- DECLARE_EVENT_TABLE();
+ int i_update_counter;
intf_thread_t *p_intf;
- wxTextCtrl *groupname;
+ wxTreeCtrl *treectrl;
+ int i_current_view;
+ vlc_bool_t b_changed_view;
+ char **pp_sds;
-protected:
- friend class Playlist;
- friend class ItemInfoDialog;
- char *psz_name;
-};
+};
/* ItemInfo Dialog */
class ItemInfoDialog: public wxDialog
/* Event handlers (these functions should _not_ be virtual) */
void OnOk( wxCommandEvent& event );
void OnCancel( wxCommandEvent& event );
- void OnNewGroup( wxCommandEvent& event );
void UpdateInfo();
wxTextCtrl *uri_text;
wxTextCtrl *name_text;
- wxTextCtrl *author_text;
wxTreeCtrl *info_tree;
wxTreeItemId info_root;
- wxCheckBox *enabled_checkbox;
- wxComboBox *group_combo;
- int ids_array[100];
};
virtual ~FileInfo();
void UpdateFileInfo();
+ vlc_bool_t b_need_update;
+
private:
- void OnClose( wxCommandEvent& event );
+ void OnButtonClose( wxCommandEvent& event );
+ void OnClose( wxCloseEvent& WXUNUSED(event) );
DECLARE_EVENT_TABLE();
};
-
-#if !defined(__WXX11__)
+#if wxUSE_DRAG_AND_DROP
/* Drag and Drop class */
class DragAndDrop: public wxFileDropTarget
{
vlc_bool_t b_enqueue;
};
#endif
+} // end of wxvlc namespace
+
+/* */
+class WindowSettings
+{
+public:
+ WindowSettings( intf_thread_t *_p_intf );
+ virtual ~WindowSettings();
+ enum
+ {
+ ID_SCREEN = -1,
+ ID_MAIN,
+ ID_PLAYLIST,
+ ID_MESSAGES,
+ ID_FILE_INFO,
+ ID_BOOKMARKS,
+ ID_VIDEO,
+
+ ID_MAX,
+ };
+
+ void SetSettings( int id, bool _b_shown,
+ wxPoint p = wxDefaultPosition, wxSize s = wxDefaultSize );
+ bool GetSettings( int id, bool& _b_shown, wxPoint& p, wxSize& s );
+
+ void SetScreen( int i_screen_w, int i_screen_h );
+
+private:
+ intf_thread_t *p_intf;
+
+ int i_screen_w;
+ int i_screen_h;
+ bool b_valid[ID_MAX];
+ bool b_shown[ID_MAX];
+ wxPoint position[ID_MAX];
+ wxSize size[ID_MAX];
+};
/* Menus */
-void PopupMenu( intf_thread_t *_p_intf, wxWindow *p_parent,
- const wxPoint& pos );
-wxMenu *SettingsMenu( intf_thread_t *_p_intf, wxWindow *p_parent );
-wxMenu *AudioMenu( intf_thread_t *_p_intf, wxWindow *p_parent );
-wxMenu *VideoMenu( intf_thread_t *_p_intf, wxWindow *p_parent );
-wxMenu *NavigMenu( intf_thread_t *_p_intf, wxWindow *p_parent );
+void PopupMenu( intf_thread_t *, wxWindow *, const wxPoint& );
+wxMenu *SettingsMenu( intf_thread_t *, wxWindow *, wxMenu * = NULL );
+wxMenu *AudioMenu( intf_thread_t *, wxWindow *, wxMenu * = NULL );
+wxMenu *VideoMenu( intf_thread_t *, wxWindow *, wxMenu * = NULL );
+wxMenu *NavigMenu( intf_thread_t *, wxWindow *, wxMenu * = NULL );
+namespace wxvlc
+{
class MenuEvtHandler : public wxEvtHandler
{
public:
Interface *p_main_interface;
};
-class Menu: public wxMenu
-{
-public:
- /* Constructor */
- Menu( intf_thread_t *p_intf, wxWindow *p_parent, int i_count,
- char **ppsz_names, int *pi_objects, int i_start_id );
- virtual ~Menu();
+} // end of wxvlc namespace
-private:
- /* Event handlers (these functions should _not_ be virtual) */
- void OnClose( wxCommandEvent& event );
- void OnShowDialog( wxCommandEvent& event );
- void OnEntrySelected( wxCommandEvent& event );
- wxMenu *Menu::CreateDummyMenu();
- void Menu::CreateMenuItem( wxMenu *, char *, vlc_object_t * );
- wxMenu *Menu::CreateChoicesMenu( char *, vlc_object_t * );
-
- DECLARE_EVENT_TABLE();
-
- intf_thread_t *p_intf;
-
- int i_item_id;
-};
-
-static inline int ConvertHotkeyModifiers( int i_hotkey )
+/*
+ * wxWindows keeps dead locking because the timer tries to lock the playlist
+ * when it's already locked somewhere else in the very wxWindows interface
+ * module. Unless someone implements a "vlc_mutex_trylock", we need that.
+ */
+inline void LockPlaylist( intf_sys_t *p_sys, playlist_t *p_pl )
{
- int i_accel_flags = 0;
- if( i_hotkey & KEY_MODIFIER_ALT ) i_accel_flags |= wxACCEL_ALT;
- if( i_hotkey & KEY_MODIFIER_CTRL ) i_accel_flags |= wxACCEL_CTRL;
- if( i_hotkey & KEY_MODIFIER_SHIFT ) i_accel_flags |= wxACCEL_SHIFT;
- return i_accel_flags;
+ if( p_sys->i_playlist_usage++ == 0)
+ vlc_mutex_lock( &p_pl->object_lock );
}
-static inline int ConvertHotkey( int i_hotkey )
+inline void UnlockPlaylist( intf_sys_t *p_sys, playlist_t *p_pl )
{
- int i_key = i_hotkey & ~KEY_MODIFIER;
- if( i_key & KEY_ASCII ) return i_key & KEY_ASCII;
- else if( i_key & KEY_SPECIAL )
- {
- switch ( i_key )
- {
- case KEY_LEFT: return WXK_LEFT;
- case KEY_RIGHT: return WXK_RIGHT;
- case KEY_UP: return WXK_UP;
- case KEY_DOWN: return WXK_DOWN;
- case KEY_SPACE: return WXK_SPACE;
- case KEY_ENTER: return WXK_RETURN;
- case KEY_F1: return WXK_F1;
- case KEY_F2: return WXK_F2;
- case KEY_F3: return WXK_F3;
- case KEY_F4: return WXK_F4;
- case KEY_F5: return WXK_F5;
- case KEY_F6: return WXK_F6;
- case KEY_F7: return WXK_F7;
- case KEY_F8: return WXK_F8;
- case KEY_F9: return WXK_F9;
- case KEY_F10: return WXK_F10;
- case KEY_F11: return WXK_F11;
- case KEY_F12: return WXK_F12;
- case KEY_HOME: return WXK_HOME;
- case KEY_END: return WXK_HOME;
- case KEY_MENU: return WXK_MENU;
- case KEY_ESC: return WXK_ESCAPE;
- case KEY_PAGEUP: return WXK_PRIOR;
- case KEY_PAGEDOWN: return WXK_NEXT;
- case KEY_TAB: return WXK_TAB;
- case KEY_BACKSPACE: return WXK_BACK;
- }
- }
- return 0;
+ if( --p_sys->i_playlist_usage == 0)
+ vlc_mutex_unlock( &p_pl->object_lock );
}
+
+using namespace wxvlc;
+