X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/223d09f6b523aac674ef9b72a883dfa8d37c5d4e..a92b0cfd2bd0bef75b43c071df0b0e028f360d8e:/src/msw/gaugemsw.cpp diff --git a/src/msw/gaugemsw.cpp b/src/msw/gaugemsw.cpp index 5a86380c51..380a30e516 100644 --- a/src/msw/gaugemsw.cpp +++ b/src/msw/gaugemsw.cpp @@ -25,7 +25,7 @@ #include "wx/utils.h" #endif -#if wxUSE_GAUGE +#if wxUSE_GAUGE #include "wx/msw/gaugemsw.h" #include "wx/msw/private.h" @@ -60,9 +60,7 @@ /* public function prototypes */ BOOL FAR PASCAL gaugeInit(HINSTANCE hInstance); -#if !USE_SHARED_LIBRARY IMPLEMENT_DYNAMIC_CLASS(wxGaugeMSW, wxControl) -#endif bool wxGaugeMSW::Create(wxWindow *parent, wxWindowID id, int range, @@ -82,7 +80,9 @@ bool wxGaugeMSW::Create(wxWindow *parent, wxWindowID id, } SetName(name); +#if wxUSE_VALIDATORS SetValidator(validator); +#endif // wxUSE_VALIDATORS if (parent) parent->AddChild(this); m_rangeMax = range; @@ -104,7 +104,13 @@ bool wxGaugeMSW::Create(wxWindow *parent, wxWindowID id, int height = size.y; long msFlags = WS_CHILD | WS_VISIBLE | WS_TABSTOP; - msFlags |= ZYZGS_3D; + bool want3D; + WXDWORD exStyle = Determine3DEffects(WS_EX_CLIENTEDGE, &want3D); + if (want3D) + msFlags |= ZYZGS_3D; + + if ( m_windowStyle & wxCLIP_SIBLINGS ) + msFlags |= WS_CLIPSIBLINGS; HWND wx_button = CreateWindowEx(MakeExtendedStyle(m_windowStyle), wxT("zYzGauge"), NULL, msFlags, @@ -122,12 +128,15 @@ bool wxGaugeMSW::Create(wxWindow *parent, wxWindowID id, wOrient = ZYZG_ORIENT_LEFTTORIGHT; else wOrient = ZYZG_ORIENT_BOTTOMTOTOP; - + SendMessage(wx_button, ZYZG_SETORIENTATION, wOrient, 0); SendMessage(wx_button, ZYZG_SETRANGE, range, 0); - SendMessage(GetHwnd(), ZYZG_SETFGCOLOR, 0, RGB(GetForegroundColour().Red(), GetForegroundColour().Green(), GetForegroundColour().Blue())); - SendMessage(GetHwnd(), ZYZG_SETBKCOLOR, 0, RGB(GetBackgroundColour().Red(), GetBackgroundColour().Green(), GetBackgroundColour().Blue())); + SendMessage(GetHwnd(), ZYZG_SETFGCOLOR, 0, PALETTERGB(GetForegroundColour().Red(), GetForegroundColour().Green(), GetForegroundColour().Blue())); + SendMessage(GetHwnd(), ZYZG_SETBKCOLOR, 0, PALETTERGB(GetBackgroundColour().Red(), GetBackgroundColour().Green(), GetBackgroundColour().Blue())); + + //SetBezelFace(1); + //SetShadowWidth(1); SetFont(parent->GetFont()); @@ -191,7 +200,7 @@ bool wxGaugeMSW::SetForegroundColour(const wxColour& col) if ( !wxControl::SetForegroundColour(col) ) return FALSE; - SendMessage(GetHwnd(), ZYZG_SETFGCOLOR, 0, RGB(col.Red(), col.Green(), col.Blue())); + SendMessage(GetHwnd(), ZYZG_SETFGCOLOR, 0, PALETTERGB(col.Red(), col.Green(), col.Blue())); return TRUE; } @@ -201,7 +210,7 @@ bool wxGaugeMSW::SetBackgroundColour(const wxColour& col) if ( !wxControl::SetBackgroundColour(col) ) return FALSE; - SendMessage(GetHwnd(), ZYZG_SETBKCOLOR, 0, RGB(col.Red(), col.Green(), col.Blue())); + SendMessage(GetHwnd(), ZYZG_SETBKCOLOR, 0, PALETTERGB(col.Red(), col.Green(), col.Blue())); return TRUE; } @@ -209,7 +218,7 @@ bool wxGaugeMSW::SetBackgroundColour(const wxColour& col) /** zyz3d.c * - * DESCRIPTION: + * DESCRIPTION: * This module contains functions for creating nifty 3D borders * around controls like zYzGauge. * @@ -251,7 +260,7 @@ void FAR PASCAL Draw3DLine(HDC, WORD, WORD, WORD, WORD, WORD); /** void FAR PASCAL Draw3DFaceFrame(HDC hdc, LPRECT rc, WORD wWidth) * - * DESCRIPTION: + * DESCRIPTION: * This function draws a flat frame with the current button-face * color. * @@ -321,7 +330,7 @@ void FAR PASCAL Draw3DFaceFrame(HDC hdc, LPRECT rc, WORD wWidth) /** void FAR PASCAL Draw3DRect(HDC, LPRECT, WORD, WORD) * - * DESCRIPTION: + * DESCRIPTION: * Draws a 3D rectangle that is shaded. wFlags can be used to * control how the rectangle looks. * @@ -383,7 +392,7 @@ void FAR PASCAL Draw3DRect(HDC hdc, LPRECT lpRect, /** void FAR PASCAL Draw3DLine(HDC hdc, WORD x, WORD y, WORD nLen, * - * DESCRIPTION: + * DESCRIPTION: * Draws a 3D line that can be used to make a 3D box. * * ARGUMENTS: @@ -422,7 +431,7 @@ void FAR PASCAL Draw3DRect(HDC hdc, LPRECT lpRect, ** cjp */ void FAR PASCAL Draw3DLine(HDC hdc, WORD x, WORD y, WORD nLen, - WORD wShadowWidth, WORD wFlags) + WORD wShadowWidth, WORD wFlags) { HBRUSH hOldBrush; HPEN hOldPen; @@ -437,7 +446,7 @@ void FAR PASCAL Draw3DLine(HDC hdc, WORD x, WORD y, WORD nLen, Point[0].x = x; Point[0].y = y; - /* To do this we'll simply draw a polygon with four sides, using + /* To do this we'll simply draw a polygon with four sides, using * the appropriate brush. I dare you to ask me why this isn't a * switch/case! */ @@ -496,7 +505,7 @@ void FAR PASCAL Draw3DLine(HDC hdc, WORD x, WORD y, WORD nLen, /* select 'dark' brush if 'in'--'light' for 'out' */ fDark = (wFlags & DRAW3D_IN) ? TRUE : FALSE; } - + /* well maybe it's for the right side? */ else if (wFlags & DRAW3D_RIGHTLINE) { @@ -540,7 +549,7 @@ void FAR PASCAL Draw3DLine(HDC hdc, WORD x, WORD y, WORD nLen, /** zyzgauge.c * - * DESCRIPTION: + * DESCRIPTION: * Yet another 'Gas Gauge Custom Control.' This control gives you * a 'progress bar' class (named zYzGauge) for use in your applications. * You can set the range, position, font, color, orientation, and 3d @@ -643,7 +652,7 @@ void FAR PASCAL Draw3DLine(HDC hdc, WORD x, WORD y, WORD nLen, /* static global variables */ static wxChar gszzYzGaugeClass[] = wxT("zYzGauge"); - + /* window word position definitions */ #define ZYZG_WW_PZYZGAUGE 0 @@ -683,7 +692,7 @@ static BOOL fSupport3D; #if !defined(APIENTRY) // NT defines APIENTRY, 3.x not #define APIENTRY FAR PASCAL #endif - + #ifdef __WIN32__ #define _EXPORT /**/ #else @@ -700,7 +709,7 @@ LRESULT APIENTRY _EXPORT gaugeWndProc(HWND, UINT, WPARAM, LPARAM); /** BOOL FAR PASCAL gaugeInit(HINSTANCE hInstance) * - * DESCRIPTION: + * DESCRIPTION: * Registers the window class for the zYzGauge control. Performs * other initialization for the zYzGauge text control. This must * be done before the zYzGauge control is used--or it will fail @@ -724,7 +733,7 @@ BOOL FAR PASCAL gaugeInit(HINSTANCE hInstance) static BOOL fRegistered = FALSE; WNDCLASS wc; HDC hdc; - + /* assume already registered if not first instance */ if (fRegistered) return (TRUE); @@ -767,7 +776,7 @@ BOOL FAR PASCAL gaugeInit(HINSTANCE hInstance) } /* good! we have color: blue foreground, white background */ - else + else { rgbDefTextColor = RGB(0, 0, 255); rgbDefBkColor = RGB(255, 255, 255); @@ -795,7 +804,7 @@ BOOL FAR PASCAL gaugeInit(HINSTANCE hInstance) /** static void PASCAL gaugePaint(HWND hwnd, HDC hdc) * - * DESCRIPTION: + * DESCRIPTION: * This function is responsible for painting the zYzGauge control. * * ARGUMENTS: @@ -867,7 +876,7 @@ static void PASCAL gaugePaint(HWND hwnd, HDC hdc) /* add all the other pixels into the border width */ Offset += (2 * pgauge->wWidth3D) + pgauge->wWidthBezelFace + 1; } - + /* dup--one rc for 'how much filled', one rc for 'how much empty' */ rc2 = rc1; @@ -916,7 +925,7 @@ static void PASCAL gaugePaint(HWND hwnd, HDC hdc) dwExtent = size.cx; #else dwExtent = GetTextExtent(hdc, ach, wGomerX = lstrlen(ach)); -#endif +#endif /* Draw the finished (ie the percent done) side of box. If @@ -940,11 +949,11 @@ static void PASCAL gaugePaint(HWND hwnd, HDC hdc) /* unselect the font */ SelectObject(hdc, hFont); } /* gaugePaint() */ - + /** LRESULT FAR PASCAL gaugeWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam) * - * DESCRIPTION: + * DESCRIPTION: * This is the control's window procedure. Its purpose is to handle * special messages for this custom control. * @@ -959,7 +968,7 @@ static void PASCAL gaugePaint(HWND hwnd, HDC hdc) * ZYZG_SETORIENTATION : Sets the orientation of the gauge. This * can be one of the ZYZG_ORIENT_?? msgs. * - * ZYZG_GETORIENTATION : Gets the current orientation of the + * ZYZG_GETORIENTATION : Gets the current orientation of the * gauge. * * ZYZG_SETPOSITION : Sets the current position of the gauge.