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:
Robin Dunn
2004-05-06 17:26:25 +00:00
parent 3cfd077ff8
commit 9d522606d0
84 changed files with 852 additions and 34 deletions

View File

@@ -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;

View File

@@ -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
// -------------- // --------------

View File

@@ -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);

View File

@@ -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()

View File

@@ -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

View File

@@ -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)
}; };

View File

@@ -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)

View File

@@ -98,6 +98,10 @@ public:
// -------------------------- // --------------------------
void OnNavigationKey(wxNavigationKeyEvent& event); void OnNavigationKey(wxNavigationKeyEvent& event);
static wxVisualAttributes
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
// implementation // implementation
// -------------- // --------------

View File

@@ -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
// -------------- // --------------

View File

@@ -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; }

View File

@@ -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
// -------------- // --------------

View File

@@ -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();

View File

@@ -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 );

View File

@@ -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()

View File

@@ -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();

View File

@@ -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();

View File

@@ -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

View File

@@ -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
// -------------- // --------------

View File

@@ -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
// -------------------------- // --------------------------

View File

@@ -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();

View File

@@ -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;

View File

@@ -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;

View File

@@ -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
// -------------- // --------------

View File

@@ -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);

View File

@@ -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()

View File

@@ -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

View File

@@ -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)
}; };

View File

@@ -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)

View File

@@ -98,6 +98,10 @@ public:
// -------------------------- // --------------------------
void OnNavigationKey(wxNavigationKeyEvent& event); void OnNavigationKey(wxNavigationKeyEvent& event);
static wxVisualAttributes
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
// implementation // implementation
// -------------- // --------------

View File

@@ -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
// -------------- // --------------

View File

@@ -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; }

View File

@@ -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
// -------------- // --------------

View File

@@ -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();

View File

@@ -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 );

View File

@@ -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()

View File

@@ -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();

View File

@@ -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();

View File

@@ -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

View File

@@ -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
// -------------- // --------------

View File

@@ -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
// -------------------------- // --------------------------

View File

@@ -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();

View File

@@ -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;

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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);
}

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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);
}

View File

@@ -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