X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fwx_util.h;h=dfa0fca5e4c6e1d1744a7b675ad5bc9a93a88f15;hb=663424bf13787560d987b51b7a984d73be839024;hp=6cb7fd00290e8abf553ceade48d651818e440716;hpb=288e7e64e9be84b8dbe11f5acb490e64a29d9378;p=dcpomatic.git diff --git a/src/wx/wx_util.h b/src/wx/wx_util.h index 6cb7fd002..dfa0fca5e 100644 --- a/src/wx/wx_util.h +++ b/src/wx/wx_util.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2012-2015 Carl Hetherington 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 @@ -17,49 +17,78 @@ */ +/** @file src/wx/wx_util.h + * @brief Some utility functions and classes. + */ + +#ifndef DCPOMATIC_WX_UTIL_H +#define DCPOMATIC_WX_UTIL_H + #include +#include #include #include +#include +#ifdef __WXGTK__ +#include +#endif class wxFilePickerCtrl; class wxSpinCtrl; +class wxSpinCtrlDouble; +class wxGridBagSizer; -/** @file src/wx/wx_util.h - * @brief Some utility functions and classes. - */ +#define DCPOMATIC_SIZER_X_GAP 8 +#define DCPOMATIC_SIZER_Y_GAP 8 +#define DCPOMATIC_SIZER_GAP 8 +#define DCPOMATIC_DIALOG_BORDER 12 -extern void error_dialog (wxWindow *, std::string); -extern wxStaticText* add_label_to_sizer (wxSizer *, wxWindow *, std::string, int prop = 0); -extern std::string wx_to_std (wxString); -extern wxString std_to_wx (std::string); +/** Spacing to use between buttons in a vertical line */ +#ifdef DCPOMATIC_OSX +#define DCPOMATIC_BUTTON_STACK_GAP 2 +#else +#define DCPOMATIC_BUTTON_STACK_GAP 0 +#endif -/** @class ThreadedStaticText - * - * @brief A wxStaticText whose content is computed in a separate thread, to avoid holding - * up the GUI while work is done. +/** i18n macro to support strings like Context|String + * so that `String' can be translated to different things + * in different contexts. */ -class ThreadedStaticText : public wxStaticText -{ -public: - ThreadedStaticText (wxWindow* parent, std::string 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; -}; +#define S_(x) context_translation(x) +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 (); +extern wxString context_translation (wxString); 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 (wxComboBox* widget, int value); -extern void checked_set (wxComboBox* widget, std::string value); +extern void checked_set (wxSpinCtrlDouble* widget, double value); +extern void checked_set (wxChoice* widget, int value); +extern void checked_set (wxChoice* widget, std::string value); +extern void checked_set (wxChoice* widget, std::vector > items); extern void checked_set (wxTextCtrl* widget, std::string value); +extern void checked_set (wxTextCtrl* widget, wxString 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); +extern void checked_set (wxStaticText* widget, wxString value); + +extern int wx_get (wxChoice* widget); +extern int wx_get (wxSpinCtrl* widget); +extern double wx_get (wxSpinCtrlDouble* widget); + +/* GTK 2.24.17 has a buggy GtkFileChooserButton and it was put in Ubuntu 13.04. + This also seems to apply to 2.24.20 in Ubuntu 13.10 and 2.24.23 in Ubuntu 14.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 || GTK_MICRO_VERSION == 20 || GTK_MICRO_VERSION == 23)) +#define DCPOMATIC_USE_OWN_DIR_PICKER +#endif + +#endif