]> git.saurik.com Git - wxWidgets.git/blame - src/gtk1/stattext.cpp
Fixing another hard-coded WXDIR path
[wxWidgets.git] / src / gtk1 / stattext.cpp
CommitLineData
c801d85f
KB
1/////////////////////////////////////////////////////////////////////////////
2// Name: stattext.cpp
3// Purpose:
4// Author: Robert Roebling
a81258be
RR
5// Id: $Id$
6// Copyright: (c) 1998 Robert Roebling
b58197f2 7// Licence: wxWindows licence
c801d85f
KB
8/////////////////////////////////////////////////////////////////////////////
9
10
11#ifdef __GNUG__
b58197f2 12 #pragma implementation "stattext.h"
c801d85f
KB
13#endif
14
15#include "wx/stattext.h"
16
83624f79
RR
17#include "gdk/gdk.h"
18#include "gtk/gtk.h"
19
c801d85f
KB
20//-----------------------------------------------------------------------------
21// wxStaticText
22//-----------------------------------------------------------------------------
23
24IMPLEMENT_DYNAMIC_CLASS(wxStaticText,wxControl)
25
b58197f2 26wxStaticText::wxStaticText()
c801d85f 27{
3f659fd6 28}
c801d85f 29
b58197f2
VZ
30wxStaticText::wxStaticText(wxWindow *parent,
31 wxWindowID id,
32 const wxString &label,
33 const wxPoint &pos,
34 const wxSize &size,
35 long style,
36 const wxString &name)
c801d85f
KB
37{
38 Create( parent, id, label, pos, size, style, name );
3f659fd6 39}
c801d85f 40
b58197f2
VZ
41bool wxStaticText::Create(wxWindow *parent,
42 wxWindowID id,
43 const wxString &label,
44 const wxPoint &pos,
45 const wxSize &size,
46 long style,
47 const wxString &name )
c801d85f 48{
a93109d5 49 m_needParent = TRUE;
b58197f2 50
4dcaf11a
RR
51 if (!PreCreation( parent, pos, size ) ||
52 !CreateBase( parent, id, pos, size, style, wxDefaultValidator, name ))
53 {
223d09f6 54 wxFAIL_MSG( wxT("wxXX creation failed") );
185fa6bf 55 return FALSE;
4dcaf11a 56 }
b58197f2
VZ
57
58 // notice that we call the base class version which will just remove the
59 // '&' characters from the string, but not set the label's text to it
60 // because the label is not yet created and because SetLabel() has a side
61 // effect of changing the control size which might not be desirable
a93109d5 62 wxControl::SetLabel(label);
9f15c5fe 63 m_widget = gtk_label_new( m_label.mbc_str() );
97d7bfb8
RR
64
65 gtk_label_set_line_wrap( GTK_LABEL(m_widget), FALSE );
a93109d5 66
454e2a22
RR
67 SetFont( parent->GetFont() );
68
a93109d5
RR
69 GtkJustification justify;
70 if ( style & wxALIGN_CENTER )
71 justify = GTK_JUSTIFY_CENTER;
72 else if ( style & wxALIGN_RIGHT )
73 justify = GTK_JUSTIFY_RIGHT;
74 else // wxALIGN_LEFT is 0
75 justify = GTK_JUSTIFY_LEFT;
76 gtk_label_set_justify(GTK_LABEL(m_widget), justify);
1a5594b8 77
1a5594b8
VZ
78 // GTK_JUSTIFY_LEFT is 0, RIGHT 1 and CENTER 2
79 static const float labelAlignments[] = { 0.0, 1.0, 0.5 };
80 gtk_misc_set_alignment(GTK_MISC(m_widget), labelAlignments[justify], 0.0);
185fa6bf 81
f68586e5 82 SetSizeOrDefault( size );
b58197f2 83
f03fc89f 84 m_parent->DoAddChild( this );
b58197f2 85
a93109d5 86 PostCreation();
b58197f2 87
a93109d5
RR
88 SetBackgroundColour( parent->GetBackgroundColour() );
89 SetForegroundColour( parent->GetForegroundColour() );
a93109d5 90 Show( TRUE );
b58197f2 91
a93109d5 92 return TRUE;
3f659fd6 93}
c801d85f 94
ed58dbea 95wxString wxStaticText::GetLabel() const
c801d85f 96{
a93109d5
RR
97 char *str = (char *) NULL;
98 gtk_label_get( GTK_LABEL(m_widget), &str );
b58197f2
VZ
99
100 return wxString(str);
3f659fd6 101}
c801d85f
KB
102
103void wxStaticText::SetLabel( const wxString &label )
104{
a93109d5 105 wxControl::SetLabel(label);
32c77a71 106
9f15c5fe 107 gtk_label_set( GTK_LABEL(m_widget), m_label.mbc_str() );
b58197f2 108
185fa6bf
VZ
109 // adjust the label size to the new label unless disabled
110 if ( !(GetWindowStyle() & wxST_NO_AUTORESIZE) )
111 {
f68586e5 112 SetSize( GetBestSize() );
185fa6bf 113 }
b58197f2 114}
58614078
RR
115
116void wxStaticText::ApplyWidgetStyle()
117{
a93109d5
RR
118 SetWidgetStyle();
119 gtk_widget_set_style( m_widget, m_widgetStyle );
58614078 120}