1 /////////////////////////////////////////////////////////////////////////////
2 // Name: src/os2/gauge.cpp
3 // Purpose: wxGauge class
4 // Author: David Webster
8 // Copyright: (c) David Webster
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 #include "wx/wxprec.h"
20 #include "wx/scrolwin.h"
23 #include "wx/os2/private.h"
25 static WXFARPROC fnWndProcGauge
= (WXFARPROC
)NULL
;
26 extern void wxAssociateWinWithHandle( HWND hWnd
30 IMPLEMENT_DYNAMIC_CLASS(wxGauge
, wxGaugeBase
)
32 MRESULT EXPENTRY
wxGaugeWndProc( HWND hWnd
,
37 wxGauge
* pGauge
= (wxGauge
*)::WinQueryWindowULong( hWnd
44 double dPixelToRange
= 0.0;
50 hPS
= ::WinBeginPaint( hWnd
56 ::WinQueryWindowRect(hWnd
, &vRect
);
57 ::GpiCreateLogColorTable( hPS
61 ,(LONG
)wxTheColourDatabase
->m_nSize
62 ,(PLONG
)wxTheColourDatabase
->m_palTable
64 ::GpiCreateLogColorTable( hPS
74 LONG lColor
= 0x00FFFFFF; // White
75 POINTL vPoint
= {vRect
.xLeft
+ 1, vRect
.yBottom
+ 1};
77 ::GpiSetColor(hPS
, lColor
);
78 ::GpiMove(hPS
, &vPoint
);
79 vPoint
.x
= vRect
.xRight
- 1;
80 ::GpiLine(hPS
, &vPoint
);
81 vPoint
.y
= vRect
.yTop
- 1;
82 ::GpiLine(hPS
, &vPoint
);
83 lColor
= 0x000C0C0C; // Darkish Grey to give depth feel
84 ::GpiSetColor(hPS
, lColor
);
85 vPoint
.x
= vRect
.xLeft
+ 1;
86 ::GpiLine(hPS
, &vPoint
);
87 vPoint
.y
= vRect
.yBottom
+ 1;
88 ::GpiLine(hPS
, &vPoint
);
89 vRect3
.xLeft
= vRect
.xLeft
+ 2;
90 vRect3
.xRight
= vRect
.xRight
- 2;
91 vRect3
.yTop
= vRect
.yTop
- 2;
92 vRect3
.yBottom
= vRect
.yBottom
+ 2;
94 if (pGauge
->GetWindowStyleFlag() & wxGA_VERTICAL
)
96 dRange
= (double)(vRect3
.yTop
- vRect3
.yBottom
);
97 dPixelToRange
= dRange
/(double)pGauge
->GetRange();
98 vRect2
.yTop
= (int)(pGauge
->GetValue() * dPixelToRange
);
99 vRect2
.yBottom
= vRect3
.yBottom
;
100 vRect2
.xLeft
= vRect3
.xLeft
;
101 vRect2
.xRight
= vRect3
.xRight
;
102 vRect3
.yBottom
= vRect2
.yTop
;
103 if (vRect3
.yBottom
<= 1)
105 ::WinFillRect(hPS
, &vRect3
, pGauge
->GetBackgroundColour().GetPixel());
106 ::WinFillRect(hPS
, &vRect2
, pGauge
->GetForegroundColour().GetPixel());
110 dRange
= (double)(vRect3
.xRight
- vRect3
.xLeft
);
111 dPixelToRange
= dRange
/(double)pGauge
->GetRange();
112 vRect2
.yTop
= vRect3
.yTop
;
113 vRect2
.yBottom
= vRect3
.yBottom
;
114 vRect2
.xLeft
= vRect3
.xLeft
;
115 vRect2
.xRight
= (int)(pGauge
->GetValue() * dPixelToRange
);
116 vRect3
.xLeft
= vRect2
.xRight
;
117 if (vRect3
.xLeft
<= 1)
119 ::WinFillRect(hPS
, &vRect3
, pGauge
->GetBackgroundColour().GetPixel());
120 ::WinFillRect(hPS
, &vRect2
, pGauge
->GetForegroundColour().GetPixel());
125 return (fnWndProcGauge( hWnd
131 } // end of wxGaugeWndProc
133 bool wxGauge::Create( wxWindowOS2
* pParent
,
139 const wxValidator
& rValidator
,
140 const wxString
& rsName
)
144 int nWidth
= rSize
.x
;
145 int nHeight
= rSize
.y
;
151 SetValidator(rValidator
);
154 pParent
->AddChild(this);
155 m_backgroundColour
.Set(wxString(wxT("LIGHT GREY")));
156 m_foregroundColour
.Set(wxString(wxT("NAVY")));
158 m_nRangeMax
= nRange
;
160 m_windowStyle
= lStyle
;
163 m_windowId
= (int)NewControlId();
167 if (m_windowStyle
& wxCLIP_SIBLINGS
)
168 lMsStyle
|= WS_CLIPSIBLINGS
;
171 // OS/2 will use an edit control for this, since there is not a native gauge
172 // Other choices include using an armless slider but they are more difficult
173 // to control and manipulate
176 lMsStyle
= WS_VISIBLE
| ES_MARGIN
| ES_LEFT
| ES_READONLY
;
177 if (m_windowStyle
& wxCLIP_SIBLINGS
)
178 lMsStyle
|= WS_CLIPSIBLINGS
;
180 m_hWnd
= (WXHWND
)::WinCreateWindow( (HWND
)GetHwndOf(pParent
) // Parent window handle
181 ,WC_ENTRYFIELD
// Window class
182 ,(PSZ
)NULL
// Initial Text
183 ,(ULONG
)lMsStyle
// Style flags
184 ,0L, 0L, 0L, 0L // Origin -- 0 size
185 ,(HWND
)GetHwndOf(pParent
) // owner window handle (same as parent
186 ,HWND_TOP
// initial z position
187 ,(HMENU
)m_windowId
// Window identifier
188 ,NULL
// Slider control data
189 ,NULL
// no Presentation parameters
192 wxAssociateWinWithHandle( m_hWnd
195 ::WinSetWindowULong(GetHwnd(), QWL_USER
, (LONG
)this);
196 fnWndProcGauge
= (WXFARPROC
)::WinSubclassWindow(m_hWnd
, (PFNWP
)wxGaugeWndProc
);
197 ::WinQueryWindowPos(m_hWnd
, &vSwp
);
200 wxFont
* pTextFont
= new wxFont( 10
215 m_nWidth
= nWidth
; // Save for GetBestSize
217 ::WinShowWindow((HWND
)GetHWND(), TRUE
);
220 } // end of wxGauge::Create
222 int wxGauge::GetBezelFace() const
225 } // end of wxGauge::GetBezelFace
227 int wxGauge::GetRange() const
230 } // end of wxGauge::GetRange
232 int wxGauge::GetShadowWidth() const
235 } // end of wxGauge::GetShadowWidth
237 int wxGauge::GetValue() const
240 } // end of wxGauge::GetValue
242 bool wxGauge::SetBackgroundColour( const wxColour
& rColour
)
244 if (!wxControl::SetBackgroundColour(rColour
))
247 LONG lColor
= (LONG
)rColour
.GetPixel();
249 ::WinSetPresParam( GetHwnd()
255 } // end of wxGauge::SetBackgroundColour
257 void wxGauge::SetBezelFace( int WXUNUSED(nWidth
) )
259 } // end of wxGauge::SetBezelFace
261 bool wxGauge::SetForegroundColour( const wxColour
& rColour
)
263 if (!wxControl::SetForegroundColour(rColour
))
266 LONG lColor
= (LONG
)rColour
.GetPixel();
268 ::WinSetPresParam( GetHwnd()
275 } // end of wxGauge::SetForegroundColour
277 void wxGauge::SetRange( int nRange
)
279 m_nRangeMax
= nRange
;
280 } // end of wxGauge::SetRange
282 void wxGauge::SetShadowWidth( int WXUNUSED(nWidth
) )
284 } // end of wxGauge::SetShadowWidth
286 void wxGauge::SetValue( int nPos
)
291 ::WinQueryWindowRect(GetHwnd(), &vRect
);
292 ::WinInvalidateRect(GetHwnd(), &vRect
, FALSE
);
293 } // end of wxGauge::SetValue
295 wxSize
wxGauge::DoGetBestSize() const
297 return wxSize(m_nWidth
,m_nHeight
);
300 #endif // wxUSE_GAUGE