X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fwx%2Fwx_util.h;h=aefa75fca57749ef679371bb16ed04f223c8063a;hb=5d65df7ebdc96c658a6b7042e639cb395f91bfeb;hp=555a3ab0ee84344b5c2a16a1d990a4154751ce47;hpb=0401db037ade0781849072329feb5eef73d5ca98;p=dcpomatic.git diff --git a/src/wx/wx_util.h b/src/wx/wx_util.h index 555a3ab0e..aefa75fca 100644 --- a/src/wx/wx_util.h +++ b/src/wx/wx_util.h @@ -17,29 +17,78 @@ */ +#ifndef DCPOMATIC_WX_UTIL_H +#define DCPOMATIC_WX_UTIL_H + #include +#include #include +#include +#include +#ifdef __WXGTK__ +#include +#endif + +class wxFilePickerCtrl; +class wxSpinCtrl; +class wxGridBagSizer; + +#define DCPOMATIC_SIZER_X_GAP 8 +#define DCPOMATIC_SIZER_Y_GAP 8 +#define DCPOMATIC_DIALOG_BORDER 12 /** @file src/wx/wx_util.h * @brief Some utility functions and classes. */ -extern void error_dialog (wxWindow *, std::string); -extern wxStaticText* add_label_to_sizer (wxSizer *, wxWindow *, std::string, int prop = 0); +extern void error_dialog (wxWindow *, wxString); +extern bool confirm_dialog (wxWindow *, wxString); +extern wxStaticText* add_label_to_sizer (wxSizer *, wxWindow *, wxString, bool left, int prop = 0); +extern wxStaticText* add_label_to_grid_bag_sizer (wxGridBagSizer *, wxWindow *, wxString, bool, wxGBPosition, wxGBSpan span = wxDefaultSpan); extern std::string wx_to_std (wxString); extern wxString std_to_wx (std::string); +extern void dcpomatic_setup_i18n (); -/** A wxStaticText whose content is computed in a separate thread, to avoid holding +/** @class ThreadedStaticText + * + * @brief A wxStaticText whose content is computed in a separate thread, to avoid holding * up the GUI while work is done. */ class ThreadedStaticText : public wxStaticText { public: - ThreadedStaticText (wxWindow* parent, std::string initial, boost::function fn); + ThreadedStaticText (wxWindow* parent, wxString initial, boost::function fn); + ~ThreadedStaticText (); + + /** Emitted in the UI thread when the text has been set up */ + boost::signals2::signal Finished; private: void run (boost::function fn); void thread_finished (wxCommandEvent& ev); + /** Thread to do our work in */ + boost::thread* _thread; + static const int _update_event_id; }; + +extern std::string string_client_data (wxClientData* o); + +extern void checked_set (wxFilePickerCtrl* widget, std::string value); +extern void checked_set (wxSpinCtrl* widget, int value); +extern void checked_set (wxChoice* widget, int value); +extern void checked_set (wxChoice* widget, std::string value); +extern void checked_set (wxTextCtrl* widget, std::string value); +extern void checked_set (wxCheckBox* widget, bool value); +extern void checked_set (wxRadioButton* widget, bool value); +extern void checked_set (wxStaticText* widget, std::string value); + +/* GTK 2.24.17 has a buggy GtkFileChooserButton and it was put in Ubuntu 13.04. + Use our own dir picker as this is the least bad option I can think of. +*/ +#if defined(__WXMSW__) || (GTK_MAJOR_VERSION == 2 && GTK_MINOR_VERSION == 24 && GTK_MICRO_VERSION == 17) +#define DCPOMATIC_USE_OWN_DIR_PICKER +#endif + +#endif