X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fwx_util.h;h=6cde08a90924dd93977d628d4b94ac1f48c730a5;hb=044ae60c8c0da7dc1a6b667b657d342aa770c42b;hp=8a84b1323296f5b9970cb98a9af1c50e897357d1;hpb=3d4faebe28da789a9083e6a2cc0b345df6c17306;p=dcpomatic.git diff --git a/src/wx/wx_util.h b/src/wx/wx_util.h index 8a84b1323..6cde08a90 100644 --- a/src/wx/wx_util.h +++ b/src/wx/wx_util.h @@ -17,12 +17,50 @@ */ -#include #include +#include +#include + +class wxFilePickerCtrl; +class wxSpinCtrl; /** @file src/wx/wx_util.h - * @brief Some utility functions. + * @brief Some utility functions and classes. + */ + +extern void error_dialog (wxWindow *, wxString); +extern wxStaticText* add_label_to_sizer (wxSizer *, wxWindow *, wxString, int prop = 0); +extern std::string wx_to_std (wxString); +extern wxString std_to_wx (std::string); + +/** @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, wxString initial, boost::function fn); + ~ThreadedStaticText (); + +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 error_dialog (std::string); -extern wxStaticText* add_label_to_sizer (wxSizer *, wxWindow *, std::list&, std::string); +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);