Get(Class)DefaultAttributes() for wxGTK controls
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@27115 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -71,6 +71,9 @@ public:
|
|||||||
// to override this here too...
|
// to override this here too...
|
||||||
virtual bool ShouldInheritColours() const { return false; }
|
virtual bool ShouldInheritColours() const { return false; }
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
|
@@ -45,6 +45,9 @@ public:
|
|||||||
virtual void SetLabel( const wxString& label );
|
virtual void SetLabel( const wxString& label );
|
||||||
virtual bool Enable( bool enable = TRUE );
|
virtual bool Enable( bool enable = TRUE );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
|
||||||
|
@@ -77,6 +77,9 @@ public:
|
|||||||
wxString GetString( int n ) const;
|
wxString GetString( int n ) const;
|
||||||
void SetString( int n, const wxString& string );
|
void SetString( int n, const wxString& string );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
wxList m_clientList; // contains the client data for the items
|
wxList m_clientList; // contains the client data for the items
|
||||||
|
|
||||||
@@ -92,6 +95,7 @@ protected:
|
|||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
virtual bool IsOwnGtkWindow( GdkWindow *window );
|
virtual bool IsOwnGtkWindow( GdkWindow *window );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// common part of Create() and DoAppend()
|
// common part of Create() and DoAppend()
|
||||||
int GtkAddHelper(GtkWidget *menu, int pos, const wxString& item);
|
int GtkAddHelper(GtkWidget *menu, int pos, const wxString& item);
|
||||||
|
@@ -134,6 +134,9 @@ public:
|
|||||||
|
|
||||||
wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST
|
wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual int DoAppend(const wxString& item);
|
virtual int DoAppend(const wxString& item);
|
||||||
virtual int DoInsert(const wxString& item, int pos);
|
virtual int DoInsert(const wxString& item, int pos);
|
||||||
@@ -145,6 +148,10 @@ protected:
|
|||||||
|
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxComboBox)
|
DECLARE_DYNAMIC_CLASS_NO_COPY(wxComboBox)
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
|
@@ -53,6 +53,8 @@ public:
|
|||||||
virtual void SetLabel( const wxString &label );
|
virtual void SetLabel( const wxString &label );
|
||||||
virtual wxString GetLabel() const;
|
virtual wxString GetLabel() const;
|
||||||
|
|
||||||
|
virtual wxVisualAttributes GetDefaultAttributes() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
void PostCreation(const wxSize& size);
|
void PostCreation(const wxSize& size);
|
||||||
@@ -61,6 +63,29 @@ protected:
|
|||||||
wxString PrepareLabelMnemonics( const wxString &label ) const;
|
wxString PrepareLabelMnemonics( const wxString &label ) const;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// These are used by GetDefaultAttributes
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetDefaultAttributesFromGTKWidget(GtkWidget* widget,
|
||||||
|
bool useBase = false,
|
||||||
|
int state = -1);
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(void),
|
||||||
|
bool useBase = false,
|
||||||
|
int state = -1);
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(const gchar*),
|
||||||
|
bool useBase = false,
|
||||||
|
int state = -1);
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(GtkAdjustment*),
|
||||||
|
bool useBase = false,
|
||||||
|
int state = -1);
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return false; }
|
||||||
|
|
||||||
wxString m_label;
|
wxString m_label;
|
||||||
char m_chAccel; // enabled to avoid breaking binary compatibility later on
|
char m_chAccel; // enabled to avoid breaking binary compatibility later on
|
||||||
|
|
||||||
|
@@ -77,6 +77,9 @@ public:
|
|||||||
|
|
||||||
bool IsVertical() const { return HasFlag(wxGA_VERTICAL); }
|
bool IsVertical() const { return HasFlag(wxGA_VERTICAL); }
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// -------------
|
// -------------
|
||||||
|
|
||||||
@@ -100,6 +103,8 @@ protected:
|
|||||||
|
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
|
virtual wxVisualAttributes GetDefaultAttributes() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS(wxGauge)
|
DECLARE_DYNAMIC_CLASS(wxGauge)
|
||||||
};
|
};
|
||||||
|
@@ -96,6 +96,9 @@ public:
|
|||||||
virtual void DoSetItemClientObject(int n, wxClientData* clientData);
|
virtual void DoSetItemClientObject(int n, wxClientData* clientData);
|
||||||
virtual wxClientData* DoGetItemClientObject(int n) const;
|
virtual wxClientData* DoGetItemClientObject(int n) const;
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation from now on
|
// implementation from now on
|
||||||
|
|
||||||
void GtkAddItem( const wxString &item, int pos=-1 );
|
void GtkAddItem( const wxString &item, int pos=-1 );
|
||||||
@@ -127,6 +130,10 @@ protected:
|
|||||||
// return the string label for the given item
|
// return the string label for the given item
|
||||||
wxString GetRealLabel(struct _GList *item) const;
|
wxString GetRealLabel(struct _GList *item) const;
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// this array is only used for controls with wxCB_SORT style, so only
|
// this array is only used for controls with wxCB_SORT style, so only
|
||||||
// allocate it if it's needed (hence using pointer)
|
// allocate it if it's needed (hence using pointer)
|
||||||
|
@@ -98,6 +98,10 @@ public:
|
|||||||
// --------------------------
|
// --------------------------
|
||||||
void OnNavigationKey(wxNavigationKeyEvent& event);
|
void OnNavigationKey(wxNavigationKeyEvent& event);
|
||||||
|
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
|
||||||
|
@@ -111,6 +111,9 @@ public:
|
|||||||
virtual bool Show( bool show = TRUE );
|
virtual bool Show( bool show = TRUE );
|
||||||
virtual bool Enable( bool enable = TRUE );
|
virtual bool Enable( bool enable = TRUE );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
|
||||||
|
@@ -49,6 +49,9 @@ public:
|
|||||||
virtual bool GetValue() const;
|
virtual bool GetValue() const;
|
||||||
virtual bool Enable( bool enable = TRUE );
|
virtual bool Enable( bool enable = TRUE );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
|
|
||||||
virtual bool IsRadioButton() const { return TRUE; }
|
virtual bool IsRadioButton() const { return TRUE; }
|
||||||
|
@@ -68,6 +68,9 @@ public:
|
|||||||
void SetObjectLength( int objectLength );
|
void SetObjectLength( int objectLength );
|
||||||
void SetViewLength( int viewLength );
|
void SetViewLength( int viewLength );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
|
||||||
|
@@ -60,6 +60,9 @@ public:
|
|||||||
virtual void SetThumbLength(int lenPixels);
|
virtual void SetThumbLength(int lenPixels);
|
||||||
virtual int GetThumbLength() const;
|
virtual int GetThumbLength() const;
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
bool IsOwnGtkWindow( GdkWindow *window );
|
bool IsOwnGtkWindow( GdkWindow *window );
|
||||||
void ApplyWidgetStyle();
|
void ApplyWidgetStyle();
|
||||||
|
@@ -46,6 +46,9 @@ public:
|
|||||||
virtual int GetMin() const;
|
virtual int GetMin() const;
|
||||||
virtual int GetMax() const;
|
virtual int GetMax() const;
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
void OnSize( wxSizeEvent &event );
|
void OnSize( wxSizeEvent &event );
|
||||||
|
|
||||||
|
@@ -59,6 +59,9 @@ public:
|
|||||||
virtual int GetMin() const;
|
virtual int GetMin() const;
|
||||||
virtual int GetMax() const;
|
virtual int GetMax() const;
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
void OnChar( wxKeyEvent &event );
|
void OnChar( wxKeyEvent &event );
|
||||||
|
|
||||||
@@ -73,6 +76,10 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS(wxSpinCtrl)
|
DECLARE_DYNAMIC_CLASS(wxSpinCtrl)
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
|
@@ -52,6 +52,9 @@ public:
|
|||||||
return (const wxIcon &)m_bitmap;
|
return (const wxIcon &)m_bitmap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// creates the new pixmap widget
|
// creates the new pixmap widget
|
||||||
void CreatePixmapWidget();
|
void CreatePixmapWidget();
|
||||||
|
@@ -40,6 +40,9 @@ public:
|
|||||||
|
|
||||||
virtual void SetLabel( const wxString &label );
|
virtual void SetLabel( const wxString &label );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
|
|
||||||
virtual void ApplyWidgetStyle();
|
virtual void ApplyWidgetStyle();
|
||||||
|
@@ -45,6 +45,10 @@ public:
|
|||||||
bool Create( wxWindow *parent, wxWindowID id,
|
bool Create( wxWindow *parent, wxWindowID id,
|
||||||
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
|
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
|
||||||
long style = wxLI_HORIZONTAL, const wxString &name = wxStaticTextNameStr );
|
long style = wxLI_HORIZONTAL, const wxString &name = wxStaticTextNameStr );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -59,6 +59,9 @@ public:
|
|||||||
|
|
||||||
bool SetFont( const wxFont &font );
|
bool SetFont( const wxFont &font );
|
||||||
bool SetForegroundColour( const wxColour& colour );
|
bool SetForegroundColour( const wxColour& colour );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
@@ -56,6 +56,9 @@ public:
|
|||||||
|
|
||||||
virtual void SetWindowStyleFlag( long style );
|
virtual void SetWindowStyleFlag( long style );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation from now on
|
// implementation from now on
|
||||||
// --------------------------
|
// --------------------------
|
||||||
|
|
||||||
|
@@ -162,6 +162,9 @@ public:
|
|||||||
// should we ignore the changed signal? always resets the flag
|
// should we ignore the changed signal? always resets the flag
|
||||||
bool IgnoreTextUpdate();
|
bool IgnoreTextUpdate();
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
@@ -175,6 +178,10 @@ protected:
|
|||||||
// scroll position changed
|
// scroll position changed
|
||||||
bool DoScroll(GtkAdjustment *adj, int diff);
|
bool DoScroll(GtkAdjustment *adj, int diff);
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// change the font for everything in this control
|
// change the font for everything in this control
|
||||||
void ChangeFontGlobally();
|
void ChangeFontGlobally();
|
||||||
|
@@ -66,7 +66,9 @@ public:
|
|||||||
void SetLabel(const wxBitmap& label);
|
void SetLabel(const wxBitmap& label);
|
||||||
bool Enable(bool enable = TRUE);
|
bool Enable(bool enable = TRUE);
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
bool m_blockEvent;
|
bool m_blockEvent;
|
||||||
wxBitmap m_bitmap;
|
wxBitmap m_bitmap;
|
||||||
@@ -81,6 +83,7 @@ public:
|
|||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS(wxToggleBitmapButton)
|
DECLARE_DYNAMIC_CLASS(wxToggleBitmapButton)
|
||||||
};
|
};
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxToggleButton
|
// wxToggleButton
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -119,6 +122,8 @@ public:
|
|||||||
void SetLabel(const wxString& label);
|
void SetLabel(const wxString& label);
|
||||||
bool Enable(bool enable = TRUE);
|
bool Enable(bool enable = TRUE);
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
bool m_blockEvent;
|
bool m_blockEvent;
|
||||||
|
@@ -71,6 +71,9 @@ public:
|
|||||||
// to override this here too...
|
// to override this here too...
|
||||||
virtual bool ShouldInheritColours() const { return false; }
|
virtual bool ShouldInheritColours() const { return false; }
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
|
@@ -45,6 +45,9 @@ public:
|
|||||||
virtual void SetLabel( const wxString& label );
|
virtual void SetLabel( const wxString& label );
|
||||||
virtual bool Enable( bool enable = TRUE );
|
virtual bool Enable( bool enable = TRUE );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
|
||||||
|
@@ -77,6 +77,9 @@ public:
|
|||||||
wxString GetString( int n ) const;
|
wxString GetString( int n ) const;
|
||||||
void SetString( int n, const wxString& string );
|
void SetString( int n, const wxString& string );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
wxList m_clientList; // contains the client data for the items
|
wxList m_clientList; // contains the client data for the items
|
||||||
|
|
||||||
@@ -92,6 +95,7 @@ protected:
|
|||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
virtual bool IsOwnGtkWindow( GdkWindow *window );
|
virtual bool IsOwnGtkWindow( GdkWindow *window );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// common part of Create() and DoAppend()
|
// common part of Create() and DoAppend()
|
||||||
int GtkAddHelper(GtkWidget *menu, int pos, const wxString& item);
|
int GtkAddHelper(GtkWidget *menu, int pos, const wxString& item);
|
||||||
|
@@ -134,6 +134,9 @@ public:
|
|||||||
|
|
||||||
wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST
|
wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual int DoAppend(const wxString& item);
|
virtual int DoAppend(const wxString& item);
|
||||||
virtual int DoInsert(const wxString& item, int pos);
|
virtual int DoInsert(const wxString& item, int pos);
|
||||||
@@ -145,6 +148,10 @@ protected:
|
|||||||
|
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxComboBox)
|
DECLARE_DYNAMIC_CLASS_NO_COPY(wxComboBox)
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
|
@@ -53,6 +53,8 @@ public:
|
|||||||
virtual void SetLabel( const wxString &label );
|
virtual void SetLabel( const wxString &label );
|
||||||
virtual wxString GetLabel() const;
|
virtual wxString GetLabel() const;
|
||||||
|
|
||||||
|
virtual wxVisualAttributes GetDefaultAttributes() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
void PostCreation(const wxSize& size);
|
void PostCreation(const wxSize& size);
|
||||||
@@ -61,6 +63,29 @@ protected:
|
|||||||
wxString PrepareLabelMnemonics( const wxString &label ) const;
|
wxString PrepareLabelMnemonics( const wxString &label ) const;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// These are used by GetDefaultAttributes
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetDefaultAttributesFromGTKWidget(GtkWidget* widget,
|
||||||
|
bool useBase = false,
|
||||||
|
int state = -1);
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(void),
|
||||||
|
bool useBase = false,
|
||||||
|
int state = -1);
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(const gchar*),
|
||||||
|
bool useBase = false,
|
||||||
|
int state = -1);
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(GtkAdjustment*),
|
||||||
|
bool useBase = false,
|
||||||
|
int state = -1);
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return false; }
|
||||||
|
|
||||||
wxString m_label;
|
wxString m_label;
|
||||||
char m_chAccel; // enabled to avoid breaking binary compatibility later on
|
char m_chAccel; // enabled to avoid breaking binary compatibility later on
|
||||||
|
|
||||||
|
@@ -77,6 +77,9 @@ public:
|
|||||||
|
|
||||||
bool IsVertical() const { return HasFlag(wxGA_VERTICAL); }
|
bool IsVertical() const { return HasFlag(wxGA_VERTICAL); }
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// -------------
|
// -------------
|
||||||
|
|
||||||
@@ -100,6 +103,8 @@ protected:
|
|||||||
|
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
|
virtual wxVisualAttributes GetDefaultAttributes() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS(wxGauge)
|
DECLARE_DYNAMIC_CLASS(wxGauge)
|
||||||
};
|
};
|
||||||
|
@@ -96,6 +96,9 @@ public:
|
|||||||
virtual void DoSetItemClientObject(int n, wxClientData* clientData);
|
virtual void DoSetItemClientObject(int n, wxClientData* clientData);
|
||||||
virtual wxClientData* DoGetItemClientObject(int n) const;
|
virtual wxClientData* DoGetItemClientObject(int n) const;
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation from now on
|
// implementation from now on
|
||||||
|
|
||||||
void GtkAddItem( const wxString &item, int pos=-1 );
|
void GtkAddItem( const wxString &item, int pos=-1 );
|
||||||
@@ -127,6 +130,10 @@ protected:
|
|||||||
// return the string label for the given item
|
// return the string label for the given item
|
||||||
wxString GetRealLabel(struct _GList *item) const;
|
wxString GetRealLabel(struct _GList *item) const;
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// this array is only used for controls with wxCB_SORT style, so only
|
// this array is only used for controls with wxCB_SORT style, so only
|
||||||
// allocate it if it's needed (hence using pointer)
|
// allocate it if it's needed (hence using pointer)
|
||||||
|
@@ -98,6 +98,10 @@ public:
|
|||||||
// --------------------------
|
// --------------------------
|
||||||
void OnNavigationKey(wxNavigationKeyEvent& event);
|
void OnNavigationKey(wxNavigationKeyEvent& event);
|
||||||
|
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
|
||||||
|
@@ -111,6 +111,9 @@ public:
|
|||||||
virtual bool Show( bool show = TRUE );
|
virtual bool Show( bool show = TRUE );
|
||||||
virtual bool Enable( bool enable = TRUE );
|
virtual bool Enable( bool enable = TRUE );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
|
||||||
|
@@ -49,6 +49,9 @@ public:
|
|||||||
virtual bool GetValue() const;
|
virtual bool GetValue() const;
|
||||||
virtual bool Enable( bool enable = TRUE );
|
virtual bool Enable( bool enable = TRUE );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
|
|
||||||
virtual bool IsRadioButton() const { return TRUE; }
|
virtual bool IsRadioButton() const { return TRUE; }
|
||||||
|
@@ -68,6 +68,9 @@ public:
|
|||||||
void SetObjectLength( int objectLength );
|
void SetObjectLength( int objectLength );
|
||||||
void SetViewLength( int viewLength );
|
void SetViewLength( int viewLength );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
|
||||||
|
@@ -60,6 +60,9 @@ public:
|
|||||||
virtual void SetThumbLength(int lenPixels);
|
virtual void SetThumbLength(int lenPixels);
|
||||||
virtual int GetThumbLength() const;
|
virtual int GetThumbLength() const;
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
bool IsOwnGtkWindow( GdkWindow *window );
|
bool IsOwnGtkWindow( GdkWindow *window );
|
||||||
void ApplyWidgetStyle();
|
void ApplyWidgetStyle();
|
||||||
|
@@ -46,6 +46,9 @@ public:
|
|||||||
virtual int GetMin() const;
|
virtual int GetMin() const;
|
||||||
virtual int GetMax() const;
|
virtual int GetMax() const;
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
void OnSize( wxSizeEvent &event );
|
void OnSize( wxSizeEvent &event );
|
||||||
|
|
||||||
|
@@ -59,6 +59,9 @@ public:
|
|||||||
virtual int GetMin() const;
|
virtual int GetMin() const;
|
||||||
virtual int GetMax() const;
|
virtual int GetMax() const;
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
void OnChar( wxKeyEvent &event );
|
void OnChar( wxKeyEvent &event );
|
||||||
|
|
||||||
@@ -73,6 +76,10 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS(wxSpinCtrl)
|
DECLARE_DYNAMIC_CLASS(wxSpinCtrl)
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
|
@@ -52,6 +52,9 @@ public:
|
|||||||
return (const wxIcon &)m_bitmap;
|
return (const wxIcon &)m_bitmap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// creates the new pixmap widget
|
// creates the new pixmap widget
|
||||||
void CreatePixmapWidget();
|
void CreatePixmapWidget();
|
||||||
|
@@ -40,6 +40,9 @@ public:
|
|||||||
|
|
||||||
virtual void SetLabel( const wxString &label );
|
virtual void SetLabel( const wxString &label );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
|
|
||||||
virtual void ApplyWidgetStyle();
|
virtual void ApplyWidgetStyle();
|
||||||
|
@@ -45,6 +45,10 @@ public:
|
|||||||
bool Create( wxWindow *parent, wxWindowID id,
|
bool Create( wxWindow *parent, wxWindowID id,
|
||||||
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
|
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
|
||||||
long style = wxLI_HORIZONTAL, const wxString &name = wxStaticTextNameStr );
|
long style = wxLI_HORIZONTAL, const wxString &name = wxStaticTextNameStr );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -59,6 +59,9 @@ public:
|
|||||||
|
|
||||||
bool SetFont( const wxFont &font );
|
bool SetFont( const wxFont &font );
|
||||||
bool SetForegroundColour( const wxColour& colour );
|
bool SetForegroundColour( const wxColour& colour );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
// --------------
|
// --------------
|
||||||
|
@@ -56,6 +56,9 @@ public:
|
|||||||
|
|
||||||
virtual void SetWindowStyleFlag( long style );
|
virtual void SetWindowStyleFlag( long style );
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation from now on
|
// implementation from now on
|
||||||
// --------------------------
|
// --------------------------
|
||||||
|
|
||||||
|
@@ -162,6 +162,9 @@ public:
|
|||||||
// should we ignore the changed signal? always resets the flag
|
// should we ignore the changed signal? always resets the flag
|
||||||
bool IgnoreTextUpdate();
|
bool IgnoreTextUpdate();
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
@@ -175,6 +178,10 @@ protected:
|
|||||||
// scroll position changed
|
// scroll position changed
|
||||||
bool DoScroll(GtkAdjustment *adj, int diff);
|
bool DoScroll(GtkAdjustment *adj, int diff);
|
||||||
|
|
||||||
|
// Widgets that use the style->base colour for the BG colour should
|
||||||
|
// override this and return true.
|
||||||
|
virtual bool UseGTKStyleBase() const { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// change the font for everything in this control
|
// change the font for everything in this control
|
||||||
void ChangeFontGlobally();
|
void ChangeFontGlobally();
|
||||||
|
@@ -66,7 +66,9 @@ public:
|
|||||||
void SetLabel(const wxBitmap& label);
|
void SetLabel(const wxBitmap& label);
|
||||||
bool Enable(bool enable = TRUE);
|
bool Enable(bool enable = TRUE);
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
bool m_blockEvent;
|
bool m_blockEvent;
|
||||||
wxBitmap m_bitmap;
|
wxBitmap m_bitmap;
|
||||||
@@ -81,6 +83,7 @@ public:
|
|||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS(wxToggleBitmapButton)
|
DECLARE_DYNAMIC_CLASS(wxToggleBitmapButton)
|
||||||
};
|
};
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxToggleButton
|
// wxToggleButton
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -119,6 +122,8 @@ public:
|
|||||||
void SetLabel(const wxString& label);
|
void SetLabel(const wxString& label);
|
||||||
bool Enable(bool enable = TRUE);
|
bool Enable(bool enable = TRUE);
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
bool m_blockEvent;
|
bool m_blockEvent;
|
||||||
|
@@ -232,5 +232,12 @@ wxSize wxButton::DoGetBestSize() const
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_BUTTON
|
#endif // wxUSE_BUTTON
|
||||||
|
|
||||||
|
@@ -216,4 +216,11 @@ wxSize wxCheckBox::DoGetBestSize() const
|
|||||||
return wxControl::DoGetBestSize();
|
return wxControl::DoGetBestSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxCheckBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_check_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -574,6 +574,13 @@ bool wxChoice::IsOwnGtkWindow( GdkWindow *window )
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxChoice::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_option_menu_new);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif // wxUSE_CHOICE
|
#endif // wxUSE_CHOICE
|
||||||
|
|
||||||
|
@@ -779,4 +779,11 @@ wxSize wxComboBox::DoGetBestSize() const
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxComboBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_combo_new, true);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -19,6 +19,8 @@
|
|||||||
#if wxUSE_CONTROLS
|
#if wxUSE_CONTROLS
|
||||||
|
|
||||||
#include "wx/control.h"
|
#include "wx/control.h"
|
||||||
|
#include "wx/fontutil.h"
|
||||||
|
#include "wx/settings.h"
|
||||||
|
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
|
|
||||||
@@ -140,5 +142,123 @@ wxString wxControl::PrepareLabelMnemonics( const wxString &label ) const
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
wxVisualAttributes wxControl::GetDefaultAttributes() const
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(m_widget,
|
||||||
|
UseGTKStyleBase());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#define SHIFT (8*(sizeof(short int)-sizeof(char)))
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxControl::GetDefaultAttributesFromGTKWidget(GtkWidget* widget,
|
||||||
|
bool useBase,
|
||||||
|
int state)
|
||||||
|
{
|
||||||
|
GtkStyle* style;
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
|
||||||
|
style = gtk_rc_get_style(widget);
|
||||||
|
if (!style)
|
||||||
|
style = gtk_widget_get_default_style();
|
||||||
|
|
||||||
|
if (!style)
|
||||||
|
{
|
||||||
|
return wxWindow::GetClassDefaultAttributes(wxWINDOW_VARIANT_NORMAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (state == -1)
|
||||||
|
state = GTK_STATE_NORMAL;
|
||||||
|
|
||||||
|
// get the style's colours
|
||||||
|
attr.colFg = wxColour(style->fg[state].red >> SHIFT,
|
||||||
|
style->fg[state].green >> SHIFT,
|
||||||
|
style->fg[state].blue >> SHIFT);
|
||||||
|
if (useBase)
|
||||||
|
attr.colBg = wxColour(style->base[state].red >> SHIFT,
|
||||||
|
style->base[state].green >> SHIFT,
|
||||||
|
style->base[state].blue >> SHIFT);
|
||||||
|
else
|
||||||
|
attr.colBg = wxColour(style->bg[state].red >> SHIFT,
|
||||||
|
style->bg[state].green >> SHIFT,
|
||||||
|
style->bg[state].blue >> SHIFT);
|
||||||
|
|
||||||
|
// get the style's font
|
||||||
|
#ifdef __WXGTK20__
|
||||||
|
if ( !style->font_desc )
|
||||||
|
style = gtk_widget_get_default_style();
|
||||||
|
if ( style && style->font_desc )
|
||||||
|
{
|
||||||
|
wxNativeFontInfo info;
|
||||||
|
info.description = style->font_desc;
|
||||||
|
attr.font = wxFont(info);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GtkSettings *settings = gtk_settings_get_default();
|
||||||
|
gchar *font_name = NULL;
|
||||||
|
g_object_get ( settings,
|
||||||
|
"gtk-font-name",
|
||||||
|
&font_name,
|
||||||
|
NULL);
|
||||||
|
if (!font_name)
|
||||||
|
attr.font = wxSystemSettings::GetFont( wxSYS_DEFAULT_GUI_FONT );
|
||||||
|
else
|
||||||
|
attr.font = wxFont(wxString::FromAscii(font_name));
|
||||||
|
g_free (font_name);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
// TODO: isn't there a way to get a standard gtk 1.2 font?
|
||||||
|
attr.font = wxFont( 12, wxSWISS, wxNORMAL, wxNORMAL );
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxControl::GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(void),
|
||||||
|
bool useBase,
|
||||||
|
int state)
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = widget_new();
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget, useBase, state);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
//static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxControl::GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(const gchar*),
|
||||||
|
bool useBase,
|
||||||
|
int state)
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = widget_new("");
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget, useBase, state);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxControl::GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(GtkAdjustment*),
|
||||||
|
bool useBase,
|
||||||
|
int state)
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = widget_new(NULL);
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget, useBase, state);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif // wxUSE_CONTROLS
|
#endif // wxUSE_CONTROLS
|
||||||
|
|
||||||
|
@@ -112,5 +112,22 @@ void wxGauge::ApplyWidgetStyle()
|
|||||||
gtk_widget_set_style( m_widget, m_widgetStyle );
|
gtk_widget_set_style( m_widget, m_widgetStyle );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wxVisualAttributes wxGauge::GetDefaultAttributes() const
|
||||||
|
{
|
||||||
|
// Visible gauge colours use a different colour state
|
||||||
|
return GetDefaultAttributesFromGTKWidget(m_widget,
|
||||||
|
UseGTKStyleBase(),
|
||||||
|
GTK_STATE_ACTIVE);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxGauge::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_progress_bar_new,
|
||||||
|
false, GTK_STATE_ACTIVE);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_GAUGE
|
#endif // wxUSE_GAUGE
|
||||||
|
|
||||||
|
@@ -1087,5 +1087,13 @@ void wxListBox::FixUpMouseEvent(GtkWidget *widget, wxCoord& x, wxCoord& y)
|
|||||||
y += widget->allocation.y;
|
y += widget->allocation.y;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxListBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_list_new, true);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_LISTBOX
|
#endif // wxUSE_LISTBOX
|
||||||
|
|
||||||
|
@@ -866,6 +866,13 @@ bool wxNotebook::SetFont(const wxFont& font)
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxNotebook::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_notebook_new);
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxNotebookEvent
|
// wxNotebookEvent
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@@ -752,5 +752,16 @@ void wxRadioBox::OnInternalIdle()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxRadioBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = gtk_radio_button_new_with_label(NULL, "");
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_RADIOBOX
|
#endif // wxUSE_RADIOBOX
|
||||||
|
|
||||||
|
@@ -233,4 +233,16 @@ wxSize wxRadioButton::DoGetBestSize() const
|
|||||||
return wxControl::DoGetBestSize();
|
return wxControl::DoGetBestSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxRadioButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = gtk_radio_button_new_with_label(NULL, "");
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -336,4 +336,11 @@ wxSize wxScrollBar::DoGetBestSize() const
|
|||||||
return wxControl::DoGetBestSize();
|
return wxControl::DoGetBestSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxScrollBar::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_vscrollbar_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -286,4 +286,11 @@ void wxSlider::GtkEnableEvents()
|
|||||||
(gpointer) this );
|
(gpointer) this );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxSlider::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_vscale_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -236,4 +236,13 @@ wxSize wxSpinButton::DoGetBestSize() const
|
|||||||
return wxSize(15, 26);
|
return wxSize(15, 26);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxSpinButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
// TODO: overload to accept functions like gtk_spin_button_new?
|
||||||
|
// Until then use a similar type
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -310,5 +310,14 @@ wxSize wxSpinCtrl::DoGetBestSize() const
|
|||||||
return wxSize(95, ret.y);
|
return wxSize(95, ret.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxSpinCtrl::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
// TODO: overload to accept functions like gtk_spin_button_new?
|
||||||
|
// Until then use a similar type
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_entry_new, true);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// wxUSE_SPINCTRL
|
// wxUSE_SPINCTRL
|
||||||
|
@@ -117,5 +117,13 @@ void wxStaticBitmap::SetBitmap( const wxBitmap &bitmap )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxStaticBitmap::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
// TODO: overload to allow using gtk_pixmap_new?
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_label_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_STATBMP
|
#endif // wxUSE_STATBMP
|
||||||
|
|
||||||
|
@@ -97,4 +97,11 @@ void wxStaticBox::ApplyWidgetStyle()
|
|||||||
gtk_widget_set_style( m_widget, m_widgetStyle );
|
gtk_widget_set_style( m_widget, m_widgetStyle );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxStaticBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_frame_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_STATBOX
|
#endif // wxUSE_STATBOX
|
||||||
|
@@ -79,4 +79,11 @@ bool wxStaticLine::Create( wxWindow *parent, wxWindowID id,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxStaticLine::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_vseparator_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -199,4 +199,11 @@ bool wxStaticText::SetForegroundColour(const wxColour& colour)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxStaticText::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_label_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_STATTEXT
|
#endif // wxUSE_STATTEXT
|
||||||
|
@@ -703,4 +703,22 @@ void wxToolBar::OnInternalIdle()
|
|||||||
UpdateWindowUI(wxUPDATE_UI_FROMIDLE);
|
UpdateWindowUI(wxUPDATE_UI_FROMIDLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxToolBar::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
#ifdef __WXGTK20__
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_toolbar_new);
|
||||||
|
#else
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = gtk_toolbar_new(GTK_ORIENTATION_HORIZONTAL, GTK_TOOLBAR_BOTH);
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_TOOLBAR_NATIVE
|
#endif // wxUSE_TOOLBAR_NATIVE
|
||||||
|
@@ -303,7 +303,7 @@ bool wxTextCtrl::Create( wxWindow *parent,
|
|||||||
gtk_container_add( GTK_CONTAINER(m_widget), m_text );
|
gtk_container_add( GTK_CONTAINER(m_widget), m_text );
|
||||||
|
|
||||||
// Global settings which can be overridden by tags, I guess.
|
// Global settings which can be overridden by tags, I guess.
|
||||||
if (HasFlag( wxHSCROLL ))
|
if (HasFlag( wxHSCROLL ) || HasFlag( wxTE_DONTWRAP ))
|
||||||
gtk_text_view_set_wrap_mode( GTK_TEXT_VIEW( m_text ), GTK_WRAP_NONE );
|
gtk_text_view_set_wrap_mode( GTK_TEXT_VIEW( m_text ), GTK_WRAP_NONE );
|
||||||
else
|
else
|
||||||
gtk_text_view_set_wrap_mode( GTK_TEXT_VIEW( m_text ), GTK_WRAP_WORD );
|
gtk_text_view_set_wrap_mode( GTK_TEXT_VIEW( m_text ), GTK_WRAP_WORD );
|
||||||
@@ -415,16 +415,16 @@ bool wxTextCtrl::Create( wxWindow *parent,
|
|||||||
#ifdef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
else
|
else
|
||||||
gtk_text_view_set_editable( GTK_TEXT_VIEW( m_text), FALSE);
|
gtk_text_view_set_editable( GTK_TEXT_VIEW( m_text), FALSE);
|
||||||
}
|
|
||||||
#else
|
#else
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (multi_line)
|
if (multi_line)
|
||||||
gtk_text_set_editable( GTK_TEXT(m_text), 1 );
|
gtk_text_set_editable( GTK_TEXT(m_text), 1 );
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// We want to be notified about text changes.
|
// We want to be notified about text changes.
|
||||||
#ifdef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
if (multi_line)
|
if (multi_line)
|
||||||
@@ -434,26 +434,21 @@ bool wxTextCtrl::Create( wxWindow *parent,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
{
|
{
|
||||||
gtk_signal_connect( GTK_OBJECT(m_text), "changed",
|
gtk_signal_connect( GTK_OBJECT(m_text), "changed",
|
||||||
GTK_SIGNAL_FUNC(gtk_text_changed_callback), (gpointer)this);
|
GTK_SIGNAL_FUNC(gtk_text_changed_callback), (gpointer)this);
|
||||||
}
|
}
|
||||||
|
|
||||||
// we don't set a valid background colour, because the window
|
|
||||||
// manager should use a default one
|
|
||||||
m_backgroundColour = wxColour();
|
|
||||||
|
|
||||||
wxColour colFg = parent->GetForegroundColour();
|
|
||||||
SetForegroundColour( colFg );
|
|
||||||
|
|
||||||
m_cursor = wxCursor( wxCURSOR_IBEAM );
|
m_cursor = wxCursor( wxCURSOR_IBEAM );
|
||||||
|
|
||||||
wxTextAttr attrDef( colFg, m_backgroundColour, parent->GetFont() );
|
wxTextAttr attrDef(GetForegroundColour(), GetBackgroundColour(), GetFont());
|
||||||
SetDefaultStyle( attrDef );
|
SetDefaultStyle( attrDef );
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void wxTextCtrl::CalculateScrollbar()
|
void wxTextCtrl::CalculateScrollbar()
|
||||||
{
|
{
|
||||||
#ifndef __WXGTK20__
|
#ifndef __WXGTK20__
|
||||||
@@ -1522,11 +1517,11 @@ bool wxTextCtrl::SetStyle( long start, long end, const wxTextAttr& style )
|
|||||||
|
|
||||||
void wxTextCtrl::ApplyWidgetStyle()
|
void wxTextCtrl::ApplyWidgetStyle()
|
||||||
{
|
{
|
||||||
if (m_windowStyle & wxTE_MULTILINE)
|
// if (m_windowStyle & wxTE_MULTILINE)
|
||||||
{
|
// {
|
||||||
// how ?
|
// // how ?
|
||||||
}
|
// }
|
||||||
else
|
// else
|
||||||
{
|
{
|
||||||
SetWidgetStyle();
|
SetWidgetStyle();
|
||||||
gtk_widget_set_style( m_text, m_widgetStyle );
|
gtk_widget_set_style( m_text, m_widgetStyle );
|
||||||
@@ -1724,3 +1719,10 @@ bool wxTextCtrl::ScrollPages(int pages)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxTextCtrl::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_entry_new, true);
|
||||||
|
}
|
||||||
|
@@ -207,6 +207,16 @@ wxSize wxToggleBitmapButton::DoGetBestSize() const
|
|||||||
}
|
}
|
||||||
return best;
|
return best;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxToggleBitmapButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_toggle_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
// wxToggleButton
|
// wxToggleButton
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
@@ -339,5 +349,12 @@ wxSize wxToggleButton::DoGetBestSize() const
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxToggleButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_toggle_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_TOGGLEBTN
|
#endif // wxUSE_TOGGLEBTN
|
||||||
|
|
||||||
|
@@ -232,5 +232,12 @@ wxSize wxButton::DoGetBestSize() const
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_BUTTON
|
#endif // wxUSE_BUTTON
|
||||||
|
|
||||||
|
@@ -216,4 +216,11 @@ wxSize wxCheckBox::DoGetBestSize() const
|
|||||||
return wxControl::DoGetBestSize();
|
return wxControl::DoGetBestSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxCheckBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_check_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -574,6 +574,13 @@ bool wxChoice::IsOwnGtkWindow( GdkWindow *window )
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxChoice::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_option_menu_new);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif // wxUSE_CHOICE
|
#endif // wxUSE_CHOICE
|
||||||
|
|
||||||
|
@@ -779,4 +779,11 @@ wxSize wxComboBox::DoGetBestSize() const
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxComboBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_combo_new, true);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -19,6 +19,8 @@
|
|||||||
#if wxUSE_CONTROLS
|
#if wxUSE_CONTROLS
|
||||||
|
|
||||||
#include "wx/control.h"
|
#include "wx/control.h"
|
||||||
|
#include "wx/fontutil.h"
|
||||||
|
#include "wx/settings.h"
|
||||||
|
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
|
|
||||||
@@ -140,5 +142,123 @@ wxString wxControl::PrepareLabelMnemonics( const wxString &label ) const
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
wxVisualAttributes wxControl::GetDefaultAttributes() const
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(m_widget,
|
||||||
|
UseGTKStyleBase());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#define SHIFT (8*(sizeof(short int)-sizeof(char)))
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxControl::GetDefaultAttributesFromGTKWidget(GtkWidget* widget,
|
||||||
|
bool useBase,
|
||||||
|
int state)
|
||||||
|
{
|
||||||
|
GtkStyle* style;
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
|
||||||
|
style = gtk_rc_get_style(widget);
|
||||||
|
if (!style)
|
||||||
|
style = gtk_widget_get_default_style();
|
||||||
|
|
||||||
|
if (!style)
|
||||||
|
{
|
||||||
|
return wxWindow::GetClassDefaultAttributes(wxWINDOW_VARIANT_NORMAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (state == -1)
|
||||||
|
state = GTK_STATE_NORMAL;
|
||||||
|
|
||||||
|
// get the style's colours
|
||||||
|
attr.colFg = wxColour(style->fg[state].red >> SHIFT,
|
||||||
|
style->fg[state].green >> SHIFT,
|
||||||
|
style->fg[state].blue >> SHIFT);
|
||||||
|
if (useBase)
|
||||||
|
attr.colBg = wxColour(style->base[state].red >> SHIFT,
|
||||||
|
style->base[state].green >> SHIFT,
|
||||||
|
style->base[state].blue >> SHIFT);
|
||||||
|
else
|
||||||
|
attr.colBg = wxColour(style->bg[state].red >> SHIFT,
|
||||||
|
style->bg[state].green >> SHIFT,
|
||||||
|
style->bg[state].blue >> SHIFT);
|
||||||
|
|
||||||
|
// get the style's font
|
||||||
|
#ifdef __WXGTK20__
|
||||||
|
if ( !style->font_desc )
|
||||||
|
style = gtk_widget_get_default_style();
|
||||||
|
if ( style && style->font_desc )
|
||||||
|
{
|
||||||
|
wxNativeFontInfo info;
|
||||||
|
info.description = style->font_desc;
|
||||||
|
attr.font = wxFont(info);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GtkSettings *settings = gtk_settings_get_default();
|
||||||
|
gchar *font_name = NULL;
|
||||||
|
g_object_get ( settings,
|
||||||
|
"gtk-font-name",
|
||||||
|
&font_name,
|
||||||
|
NULL);
|
||||||
|
if (!font_name)
|
||||||
|
attr.font = wxSystemSettings::GetFont( wxSYS_DEFAULT_GUI_FONT );
|
||||||
|
else
|
||||||
|
attr.font = wxFont(wxString::FromAscii(font_name));
|
||||||
|
g_free (font_name);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
// TODO: isn't there a way to get a standard gtk 1.2 font?
|
||||||
|
attr.font = wxFont( 12, wxSWISS, wxNORMAL, wxNORMAL );
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxControl::GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(void),
|
||||||
|
bool useBase,
|
||||||
|
int state)
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = widget_new();
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget, useBase, state);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
//static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxControl::GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(const gchar*),
|
||||||
|
bool useBase,
|
||||||
|
int state)
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = widget_new("");
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget, useBase, state);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxControl::GetDefaultAttributesFromGTKWidget(GtkWidget* (*widget_new)(GtkAdjustment*),
|
||||||
|
bool useBase,
|
||||||
|
int state)
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = widget_new(NULL);
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget, useBase, state);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif // wxUSE_CONTROLS
|
#endif // wxUSE_CONTROLS
|
||||||
|
|
||||||
|
@@ -112,5 +112,22 @@ void wxGauge::ApplyWidgetStyle()
|
|||||||
gtk_widget_set_style( m_widget, m_widgetStyle );
|
gtk_widget_set_style( m_widget, m_widgetStyle );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wxVisualAttributes wxGauge::GetDefaultAttributes() const
|
||||||
|
{
|
||||||
|
// Visible gauge colours use a different colour state
|
||||||
|
return GetDefaultAttributesFromGTKWidget(m_widget,
|
||||||
|
UseGTKStyleBase(),
|
||||||
|
GTK_STATE_ACTIVE);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxGauge::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_progress_bar_new,
|
||||||
|
false, GTK_STATE_ACTIVE);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_GAUGE
|
#endif // wxUSE_GAUGE
|
||||||
|
|
||||||
|
@@ -1087,5 +1087,13 @@ void wxListBox::FixUpMouseEvent(GtkWidget *widget, wxCoord& x, wxCoord& y)
|
|||||||
y += widget->allocation.y;
|
y += widget->allocation.y;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxListBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_list_new, true);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_LISTBOX
|
#endif // wxUSE_LISTBOX
|
||||||
|
|
||||||
|
@@ -866,6 +866,13 @@ bool wxNotebook::SetFont(const wxFont& font)
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxNotebook::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_notebook_new);
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxNotebookEvent
|
// wxNotebookEvent
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@@ -752,5 +752,16 @@ void wxRadioBox::OnInternalIdle()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxRadioBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = gtk_radio_button_new_with_label(NULL, "");
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_RADIOBOX
|
#endif // wxUSE_RADIOBOX
|
||||||
|
|
||||||
|
@@ -233,4 +233,16 @@ wxSize wxRadioButton::DoGetBestSize() const
|
|||||||
return wxControl::DoGetBestSize();
|
return wxControl::DoGetBestSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxRadioButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = gtk_radio_button_new_with_label(NULL, "");
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -336,4 +336,11 @@ wxSize wxScrollBar::DoGetBestSize() const
|
|||||||
return wxControl::DoGetBestSize();
|
return wxControl::DoGetBestSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxScrollBar::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_vscrollbar_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -286,4 +286,11 @@ void wxSlider::GtkEnableEvents()
|
|||||||
(gpointer) this );
|
(gpointer) this );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxSlider::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_vscale_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -236,4 +236,13 @@ wxSize wxSpinButton::DoGetBestSize() const
|
|||||||
return wxSize(15, 26);
|
return wxSize(15, 26);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxSpinButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
// TODO: overload to accept functions like gtk_spin_button_new?
|
||||||
|
// Until then use a similar type
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -310,5 +310,14 @@ wxSize wxSpinCtrl::DoGetBestSize() const
|
|||||||
return wxSize(95, ret.y);
|
return wxSize(95, ret.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxSpinCtrl::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
// TODO: overload to accept functions like gtk_spin_button_new?
|
||||||
|
// Until then use a similar type
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_entry_new, true);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// wxUSE_SPINCTRL
|
// wxUSE_SPINCTRL
|
||||||
|
@@ -117,5 +117,13 @@ void wxStaticBitmap::SetBitmap( const wxBitmap &bitmap )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxStaticBitmap::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
// TODO: overload to allow using gtk_pixmap_new?
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_label_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_STATBMP
|
#endif // wxUSE_STATBMP
|
||||||
|
|
||||||
|
@@ -97,4 +97,11 @@ void wxStaticBox::ApplyWidgetStyle()
|
|||||||
gtk_widget_set_style( m_widget, m_widgetStyle );
|
gtk_widget_set_style( m_widget, m_widgetStyle );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxStaticBox::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_frame_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_STATBOX
|
#endif // wxUSE_STATBOX
|
||||||
|
@@ -79,4 +79,11 @@ bool wxStaticLine::Create( wxWindow *parent, wxWindowID id,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxStaticLine::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_vseparator_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -199,4 +199,11 @@ bool wxStaticText::SetForegroundColour(const wxColour& colour)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxStaticText::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_label_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_STATTEXT
|
#endif // wxUSE_STATTEXT
|
||||||
|
@@ -703,4 +703,22 @@ void wxToolBar::OnInternalIdle()
|
|||||||
UpdateWindowUI(wxUPDATE_UI_FROMIDLE);
|
UpdateWindowUI(wxUPDATE_UI_FROMIDLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxToolBar::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
#ifdef __WXGTK20__
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_toolbar_new);
|
||||||
|
#else
|
||||||
|
wxVisualAttributes attr;
|
||||||
|
GtkWidget* widget = gtk_toolbar_new(GTK_ORIENTATION_HORIZONTAL, GTK_TOOLBAR_BOTH);
|
||||||
|
attr = GetDefaultAttributesFromGTKWidget(widget);
|
||||||
|
gtk_widget_destroy(widget);
|
||||||
|
return attr;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_TOOLBAR_NATIVE
|
#endif // wxUSE_TOOLBAR_NATIVE
|
||||||
|
@@ -303,7 +303,7 @@ bool wxTextCtrl::Create( wxWindow *parent,
|
|||||||
gtk_container_add( GTK_CONTAINER(m_widget), m_text );
|
gtk_container_add( GTK_CONTAINER(m_widget), m_text );
|
||||||
|
|
||||||
// Global settings which can be overridden by tags, I guess.
|
// Global settings which can be overridden by tags, I guess.
|
||||||
if (HasFlag( wxHSCROLL ))
|
if (HasFlag( wxHSCROLL ) || HasFlag( wxTE_DONTWRAP ))
|
||||||
gtk_text_view_set_wrap_mode( GTK_TEXT_VIEW( m_text ), GTK_WRAP_NONE );
|
gtk_text_view_set_wrap_mode( GTK_TEXT_VIEW( m_text ), GTK_WRAP_NONE );
|
||||||
else
|
else
|
||||||
gtk_text_view_set_wrap_mode( GTK_TEXT_VIEW( m_text ), GTK_WRAP_WORD );
|
gtk_text_view_set_wrap_mode( GTK_TEXT_VIEW( m_text ), GTK_WRAP_WORD );
|
||||||
@@ -415,16 +415,16 @@ bool wxTextCtrl::Create( wxWindow *parent,
|
|||||||
#ifdef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
else
|
else
|
||||||
gtk_text_view_set_editable( GTK_TEXT_VIEW( m_text), FALSE);
|
gtk_text_view_set_editable( GTK_TEXT_VIEW( m_text), FALSE);
|
||||||
}
|
|
||||||
#else
|
#else
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (multi_line)
|
if (multi_line)
|
||||||
gtk_text_set_editable( GTK_TEXT(m_text), 1 );
|
gtk_text_set_editable( GTK_TEXT(m_text), 1 );
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// We want to be notified about text changes.
|
// We want to be notified about text changes.
|
||||||
#ifdef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
if (multi_line)
|
if (multi_line)
|
||||||
@@ -434,26 +434,21 @@ bool wxTextCtrl::Create( wxWindow *parent,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
{
|
{
|
||||||
gtk_signal_connect( GTK_OBJECT(m_text), "changed",
|
gtk_signal_connect( GTK_OBJECT(m_text), "changed",
|
||||||
GTK_SIGNAL_FUNC(gtk_text_changed_callback), (gpointer)this);
|
GTK_SIGNAL_FUNC(gtk_text_changed_callback), (gpointer)this);
|
||||||
}
|
}
|
||||||
|
|
||||||
// we don't set a valid background colour, because the window
|
|
||||||
// manager should use a default one
|
|
||||||
m_backgroundColour = wxColour();
|
|
||||||
|
|
||||||
wxColour colFg = parent->GetForegroundColour();
|
|
||||||
SetForegroundColour( colFg );
|
|
||||||
|
|
||||||
m_cursor = wxCursor( wxCURSOR_IBEAM );
|
m_cursor = wxCursor( wxCURSOR_IBEAM );
|
||||||
|
|
||||||
wxTextAttr attrDef( colFg, m_backgroundColour, parent->GetFont() );
|
wxTextAttr attrDef(GetForegroundColour(), GetBackgroundColour(), GetFont());
|
||||||
SetDefaultStyle( attrDef );
|
SetDefaultStyle( attrDef );
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void wxTextCtrl::CalculateScrollbar()
|
void wxTextCtrl::CalculateScrollbar()
|
||||||
{
|
{
|
||||||
#ifndef __WXGTK20__
|
#ifndef __WXGTK20__
|
||||||
@@ -1522,11 +1517,11 @@ bool wxTextCtrl::SetStyle( long start, long end, const wxTextAttr& style )
|
|||||||
|
|
||||||
void wxTextCtrl::ApplyWidgetStyle()
|
void wxTextCtrl::ApplyWidgetStyle()
|
||||||
{
|
{
|
||||||
if (m_windowStyle & wxTE_MULTILINE)
|
// if (m_windowStyle & wxTE_MULTILINE)
|
||||||
{
|
// {
|
||||||
// how ?
|
// // how ?
|
||||||
}
|
// }
|
||||||
else
|
// else
|
||||||
{
|
{
|
||||||
SetWidgetStyle();
|
SetWidgetStyle();
|
||||||
gtk_widget_set_style( m_text, m_widgetStyle );
|
gtk_widget_set_style( m_text, m_widgetStyle );
|
||||||
@@ -1724,3 +1719,10 @@ bool wxTextCtrl::ScrollPages(int pages)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxTextCtrl::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_entry_new, true);
|
||||||
|
}
|
||||||
|
@@ -207,6 +207,16 @@ wxSize wxToggleBitmapButton::DoGetBestSize() const
|
|||||||
}
|
}
|
||||||
return best;
|
return best;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxToggleBitmapButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_toggle_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
// wxToggleButton
|
// wxToggleButton
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
@@ -339,5 +349,12 @@ wxSize wxToggleButton::DoGetBestSize() const
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
wxVisualAttributes
|
||||||
|
wxToggleButton::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
return GetDefaultAttributesFromGTKWidget(gtk_toggle_button_new);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_TOGGLEBTN
|
#endif // wxUSE_TOGGLEBTN
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user