]> git.saurik.com Git - wxWidgets.git/blame - src/os2/stattext.cpp
Combine two wxImage-to-pixmap creation functions into one.
[wxWidgets.git] / src / os2 / stattext.cpp
CommitLineData
0e320a79 1/////////////////////////////////////////////////////////////////////////////
d5da0ce7 2// Name: src/os2/stattext.cpp
0e320a79 3// Purpose: wxStaticText
d90895ac 4// Author: David Webster
0e320a79 5// Modified by:
d90895ac 6// Created: 10/17/99
0e320a79 7// RCS-ID: $Id$
d90895ac 8// Copyright: (c) David Webster
65571936 9// Licence: wxWindows licence
0e320a79
DW
10/////////////////////////////////////////////////////////////////////////////
11
d90895ac
DW
12// For compilers that support precompilation, includes "wx.h".
13#include "wx/wxprec.h"
0e320a79 14
ccdc11bb
WS
15#include "wx/stattext.h"
16
d90895ac 17#ifndef WX_PRECOMP
d5da0ce7
WS
18 #include "wx/event.h"
19 #include "wx/app.h"
20 #include "wx/brush.h"
21 #include "wx/scrolwin.h"
d90895ac 22#endif
0e320a79 23
d90895ac 24#include "wx/os2/private.h"
0e320a79
DW
25#include <stdio.h>
26
0e320a79 27IMPLEMENT_DYNAMIC_CLASS(wxStaticText, wxControl)
0e320a79 28
d5da0ce7
WS
29bool wxStaticText::Create( wxWindow* pParent,
30 wxWindowID vId,
31 const wxString& rsLabel,
32 const wxPoint& rPos,
33 const wxSize& rSize,
34 long lStyle,
35 const wxString& rsName )
0e320a79 36{
1f3154c8
DW
37 SetName(rsName);
38 if (pParent)
39 pParent->AddChild(this);
d90895ac 40
1f3154c8
DW
41 SetBackgroundColour(pParent->GetBackgroundColour()) ;
42 SetForegroundColour(pParent->GetForegroundColour()) ;
0e320a79 43
d5da0ce7 44 if ( vId == wxID_ANY )
d90895ac
DW
45 m_windowId = (int)NewControlId();
46 else
1f3154c8 47 m_windowId = vId;
0e320a79 48
d5da0ce7
WS
49 int nX = rPos.x;
50 int nY = rPos.y;
51 int nWidth = rSize.x;
52 int nHeight = rSize.y;
0e320a79 53
1f3154c8 54 m_windowStyle = lStyle;
0e320a79 55
d5da0ce7 56 long lSstyle = 0L;
0e320a79 57
61cc6764
SN
58 // Used to have DT_VCENTER but that doesn't work correctly with
59 // multiline strings and DT_WORDBREAK. Accept a reasonable
60 // compromise for now
61 lSstyle = WS_VISIBLE | SS_TEXT | DT_WORDBREAK | DT_MNEMONIC;
1f3154c8
DW
62 if (m_windowStyle & wxALIGN_CENTRE)
63 lSstyle |= DT_CENTER;
64 else if (m_windowStyle & wxALIGN_RIGHT)
65 lSstyle |= DT_RIGHT;
66 else
67 lSstyle |= DT_LEFT;
e94d504d 68
d5da0ce7 69 wxString sLabel = ::wxPMTextToLabel(rsLabel);
e94d504d 70
1f3154c8
DW
71 m_hWnd = (WXHWND)::WinCreateWindow( (HWND)GetHwndOf(pParent) // Parent window handle
72 ,WC_STATIC // Window class
e94d504d 73 ,(PSZ)sLabel.c_str() // Initial Text
1f3154c8
DW
74 ,(ULONG)lSstyle // Style flags
75 ,0L, 0L, 0L, 0L // Origin -- 0 size
76 ,(HWND)GetHwndOf(pParent) // owner window handle (same as parent
77 ,HWND_TOP // initial z position
78 ,(ULONG)m_windowId // Window identifier
79 ,NULL // no control data
80 ,NULL // no Presentation parameters
81 );
82
d5da0ce7 83 wxCHECK_MSG(m_hWnd, false, wxT("Failed to create static ctrl"));
3c299c3a 84
d5da0ce7 85 LONG lColor = (LONG)wxBLACK->GetPixel();
3c299c3a
DW
86
87 ::WinSetPresParam( m_hWnd
88 ,PP_FOREGROUNDCOLOR
89 ,sizeof(LONG)
90 ,(PVOID)&lColor
91 );
7993e67c
DW
92 lColor = (LONG)m_backgroundColour.GetPixel();
93
94 ::WinSetPresParam( m_hWnd
95 ,PP_BACKGROUNDCOLOR
96 ,sizeof(LONG)
97 ,(PVOID)&lColor
98 );
3c299c3a 99
1f3154c8 100 SubclassWin(m_hWnd);
b720b24d
DW
101 SetFont(*wxSMALL_FONT);
102 SetXComp(0);
103 SetYComp(0);
d5da0ce7
WS
104 SetSize( nX, nY, nWidth, nHeight );
105
106 return true;
1f3154c8 107} // end of wxStaticText::Create
0e320a79 108
e78c4d50 109wxSize wxStaticText::DoGetBestSize() const
0e320a79 110{
d5da0ce7
WS
111 wxString sText(wxGetWindowText(GetHWND()));
112 int nWidthTextMax = 0;
113 int nWidthLine = 0;
114 int nHeightTextTotal = 0;
115 int nHeightLineDefault = 0;
116 int nHeightLine = 0;
117 wxString sCurLine;
118 bool bLastWasTilde = false;
1f3154c8 119
3c299c3a 120 for (const wxChar *pc = sText; ; pc++)
1f3154c8
DW
121 {
122 if ( *pc == wxT('\n') || *pc == wxT('\0') )
123 {
124 if (!sCurLine )
125 {
126 //
127 // We can't use GetTextExtent - it will return 0 for both width
e78c4d50
DW
128 // and height and an empty line should count in height
129 // calculation
1f3154c8
DW
130 //
131 if (!nHeightLineDefault)
132 nHeightLineDefault = nHeightLine;
133 if (!nHeightLineDefault)
134 GetTextExtent(_T("W"), NULL, &nHeightLineDefault);
135 nHeightTextTotal += nHeightLineDefault;
e78c4d50 136 }
1f3154c8
DW
137 else
138 {
139 GetTextExtent( sCurLine
140 ,&nWidthLine
141 ,&nHeightLine
142 );
143 if (nWidthLine > nWidthTextMax)
144 nWidthTextMax = nWidthLine;
145 nHeightTextTotal += nHeightLine;
e78c4d50 146 }
d90895ac 147
1f3154c8
DW
148 if ( *pc == wxT('\n') )
149 {
150 sCurLine.Empty();
d90895ac 151 }
1f3154c8
DW
152 else
153 {
d90895ac
DW
154 break;
155 }
156 }
1f3154c8
DW
157 else
158 {
6e348b12 159 //
e94d504d 160 // We shouldn't take into account the '~' which just introduces the
6e348b12 161 // mnemonic characters and so are not shown on the screen -- except
e94d504d
SN
162 // when it is preceded by another '~' in which case it stands for a
163 // literal tilde
6e348b12 164 //
e94d504d 165 if (*pc == _T('~'))
6e348b12 166 {
e94d504d 167 if (!bLastWasTilde)
6e348b12 168 {
d5da0ce7 169 bLastWasTilde = true;
6e348b12
DW
170
171 //
172 // Skip the statement adding pc to curLine below
173 //
174 continue;
175 }
176
177 //
e94d504d 178 // It is a literal tilde
6e348b12 179 //
d5da0ce7 180 bLastWasTilde = false;
6e348b12 181 }
1f3154c8 182 sCurLine += *pc;
d90895ac
DW
183 }
184 }
1f3154c8
DW
185 return wxSize( nWidthTextMax
186 ,nHeightTextTotal
187 );
188} // end of wxStaticText::DoGetBestSize
189
7993e67c
DW
190void wxStaticText::DoSetSize(
191 int nX
192, int nY
193, int nWidth
194, int nHeight
195, int nSizeFlags
196)
197{
198 //
199 // We need to refresh the window after changing its size as the standard
200 // control doesn't always update itself properly.
201 //
202 wxStaticTextBase::DoSetSize( nX
203 ,nY
204 ,nWidth
205 ,nHeight
206 ,nSizeFlags
207 );
208 Refresh();
209} // end of wxStaticText::DoSetSize
210
3c299c3a
DW
211bool wxStaticText::SetFont(
212 const wxFont& rFont
1f3154c8 213)
0e320a79 214{
3c299c3a 215 bool bRet = wxControl::SetFont(rFont);
1f3154c8
DW
216
217 //
218 // Adjust the size of the window to fit to the label unless autoresizing is
219 // disabled
220 //
3c299c3a 221 if ( !(GetWindowStyle() & wxST_NO_AUTORESIZE) )
1f3154c8
DW
222 {
223 DoSetSize(-1, -1, -1, -1, wxSIZE_AUTO_WIDTH | wxSIZE_AUTO_HEIGHT);
224 }
3c299c3a
DW
225 return bRet;
226} // end of wxStaticText::SetFont
d90895ac 227
3c299c3a
DW
228void wxStaticText::SetLabel(
229 const wxString& rsLabel
1f3154c8 230)
d90895ac 231{
e94d504d
SN
232 wxString sLabel = ::wxPMTextToLabel(rsLabel);
233 ::WinSetWindowText(GetHwnd(), (PSZ)sLabel.c_str());
1f3154c8
DW
234
235 //
236 // Adjust the size of the window to fit to the label unless autoresizing is
237 // disabled
238 //
3c299c3a 239 if (!(GetWindowStyle() & wxST_NO_AUTORESIZE))
1f3154c8 240 {
b720b24d
DW
241 wxCoord vX;
242 wxCoord vY;
243 wxCoord vWidth;
244 wxCoord vHeight;
245
246 GetPosition(&vX, &vY);
247 GetSize(&vWidth, &vHeight);
248 if (!(vX == -1 && vY == -1 && vWidth == -1 && vHeight == -1))
249 DoSetSize(vX, vY, vWidth, vHeight, wxSIZE_AUTO_WIDTH | wxSIZE_AUTO_HEIGHT);
250 else
251 DoSetSize(-1, -1, -1, -1, wxSIZE_AUTO_WIDTH | wxSIZE_AUTO_HEIGHT);
1f3154c8 252 }
3c299c3a 253} // end of wxStaticText::SetLabel
1f3154c8
DW
254
255MRESULT wxStaticText::OS2WindowProc(
256 WXUINT uMsg
257, WXWPARAM wParam
258, WXLPARAM lParam
259)
d90895ac 260{
1f3154c8
DW
261 return wxWindow::OS2WindowProc( uMsg
262 ,wParam
263 ,lParam
264 );
265} // end of wxStaticText::OS2WindowProc