1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     Private declarations: as this header is only included by 
   4 //              wxWindows itself, it may contain identifiers which don't start 
   6 // Author:      Julian Smart 
  10 // Copyright:   (c) Julian Smart 
  11 // Licence:     wxWindows licence 
  12 ///////////////////////////////////////////////////////////////////////////// 
  14 #ifndef _WX_PRIVATE_H_ 
  15 #define _WX_PRIVATE_H_ 
  24 #if defined (__WXWINCE__) 
  25     #include <wingdi.h>     // RGB, COLORREF 
  26     #include <winuser.h>    // Global Namespaces ::GetKeyState, ::GetWindowRect 
  31     // Extra prototypes and symbols not defined by MicroWindows 
  32     #include "wx/msw/microwin.h" 
  35 // undefine conflicting symbols which were defined in windows.h 
  36 #include "wx/msw/winundef.h" 
  38 // Include fixes for MSLU: 
  39 #include "wx/msw/mslu.h" 
  43 class WXDLLEXPORT wxFont
; 
  44 class WXDLLEXPORT wxWindow
; 
  46 // --------------------------------------------------------------------------- 
  48 // --------------------------------------------------------------------------- 
  51 static const double METRIC_CONVERSION_CONSTANT 
= 0.0393700787; 
  53 // Scaling factors for various unit conversions 
  54 static const double mm2inches 
= (METRIC_CONVERSION_CONSTANT
); 
  55 static const double inches2mm 
= (1/METRIC_CONVERSION_CONSTANT
); 
  57 static const double mm2twips 
= (METRIC_CONVERSION_CONSTANT
*1440); 
  58 static const double twips2mm 
= (1/(METRIC_CONVERSION_CONSTANT
*1440)); 
  60 static const double mm2pt 
= (METRIC_CONVERSION_CONSTANT
*72); 
  61 static const double pt2mm 
= (1/(METRIC_CONVERSION_CONSTANT
*72)); 
  63 // --------------------------------------------------------------------------- 
  64 // standard icons from the resources 
  65 // --------------------------------------------------------------------------- 
  69 WXDLLEXPORT_DATA(extern HICON
) wxSTD_FRAME_ICON
; 
  70 WXDLLEXPORT_DATA(extern HICON
) wxSTD_MDIPARENTFRAME_ICON
; 
  71 WXDLLEXPORT_DATA(extern HICON
) wxSTD_MDICHILDFRAME_ICON
; 
  72 WXDLLEXPORT_DATA(extern HICON
) wxDEFAULT_FRAME_ICON
; 
  73 WXDLLEXPORT_DATA(extern HICON
) wxDEFAULT_MDIPARENTFRAME_ICON
; 
  74 WXDLLEXPORT_DATA(extern HICON
) wxDEFAULT_MDICHILDFRAME_ICON
; 
  75 WXDLLEXPORT_DATA(extern HFONT
) wxSTATUS_LINE_FONT
; 
  79 // --------------------------------------------------------------------------- 
  80 // define things missing from some compilers' headers 
  81 // --------------------------------------------------------------------------- 
  83 #if defined(__GNUWIN32__) && !wxUSE_NORLANDER_HEADERS 
  85     inline void ZeroMemory(void *buf
, size_t len
) { memset(buf
, 0, len
); } 
  89 // this defines a CASTWNDPROC macro which casts a pointer to the type of a 
  91 #if defined(__WXWINCE__) 
  92     typedef FARPROC WndProcCast
; 
  93 #elif defined(STRICT) || defined(__GNUC__) 
  94     typedef WNDPROC WndProcCast
; 
  96     typedef FARPROC WndProcCast
; 
 100 #define CASTWNDPROC (WndProcCast) 
 102 // --------------------------------------------------------------------------- 
 103 // some stuff for old Windows versions (FIXME: what does it do here??) 
 104 // --------------------------------------------------------------------------- 
 106 #if !defined(APIENTRY)  // NT defines APIENTRY, 3.x not 
 107     #define APIENTRY FAR PASCAL 
 113     #define _EXPORT _export 
 117     typedef signed short int SHORT
; 
 120 #if !defined(__WIN32__)  // 3.x uses FARPROC for dialogs 
 122     #define DLGPROC FARPROC 
 127     WXDLLEXPORT 
void wxRegisterPenWin(); 
 128     WXDLLEXPORT 
void wxCleanUpPenWin(); 
 129     WXDLLEXPORT 
void wxEnablePenAppHooks (bool hook
); 
 130 #endif // wxUSE_PENWIN 
 133     #define IBS_HORZCAPTION    0x4000L 
 134     #define IBS_VERTCAPTION    0x8000L 
 136     UINT    WINAPI 
ibGetCaptionSize( HWND hWnd  
) ; 
 137     UINT    WINAPI 
ibSetCaptionSize( HWND hWnd
, UINT nSize 
) ; 
 138     LRESULT WINAPI 
ibDefWindowProc( HWND hWnd
, UINT uiMsg
, WPARAM wParam
, LPARAM lParam 
) ; 
 139     VOID    WINAPI 
ibAdjustWindowRect( HWND hWnd
, LPRECT lprc 
) ; 
 140 #endif // wxUSE_ITSY_BITSY 
 143     #include "wx/msw/ctl3d/ctl3d.h" 
 144 #endif // wxUSE_CTL3D 
 147  * Decide what window classes we're going to use 
 148  * for this combination of CTl3D/FAFA settings 
 151 #define STATIC_CLASS     wxT("STATIC") 
 152 #define STATIC_FLAGS     (SS_LEFT|WS_CHILD|WS_VISIBLE) 
 153 #define CHECK_CLASS      wxT("BUTTON") 
 154 #define CHECK_FLAGS      (BS_AUTOCHECKBOX|WS_TABSTOP|WS_CHILD) 
 155 #define CHECK_IS_FAFA   FALSE 
 156 #define RADIO_CLASS      wxT("BUTTON") 
 157 #define RADIO_FLAGS      (BS_AUTORADIOBUTTON|WS_CHILD|WS_VISIBLE) 
 158 #define RADIO_SIZE       20 
 159 #define RADIO_IS_FAFA   FALSE 
 161 #define GROUP_CLASS      wxT("BUTTON") 
 162 #define GROUP_FLAGS      (BS_GROUPBOX|WS_CHILD|WS_VISIBLE) 
 165 #define BITCHECK_FLAGS   (FB_BITMAP|FC_BUTTONDRAW|FC_DEFAULT|WS_VISIBLE) 
 166 #define BITRADIO_FLAGS   (FC_BUTTONDRAW|FB_BITMAP|FC_RADIO|WS_CHILD|WS_VISIBLE) 
 169 // --------------------------------------------------------------------------- 
 171 // --------------------------------------------------------------------------- 
 173 #define MEANING_CHARACTER '0' 
 174 #define DEFAULT_ITEM_WIDTH  100 
 175 #define DEFAULT_ITEM_HEIGHT 80 
 177 // Scale font to get edit control height 
 178 //#define EDIT_HEIGHT_FROM_CHAR_HEIGHT(cy)    (3*(cy)/2) 
 179 #define EDIT_HEIGHT_FROM_CHAR_HEIGHT(cy)    (cy+8) 
 181 // Generic subclass proc, for panel item moving/sizing and intercept 
 182 // EDIT control VK_RETURN messages 
 183 extern LONG APIENTRY _EXPORT
 
 184   wxSubclassedGenericControlProc(WXHWND hWnd
, WXUINT message
, WXWPARAM wParam
, WXLPARAM lParam
); 
 186 // --------------------------------------------------------------------------- 
 187 // constants which might miss from some compilers' headers 
 188 // --------------------------------------------------------------------------- 
 190 #if !defined(__WIN32__) && !defined(WS_EX_CLIENTEDGE) 
 191     #define WS_EX_CLIENTEDGE 0 
 194 #if defined(__WIN32__) && !defined(WS_EX_CLIENTEDGE) 
 195     #define WS_EX_CLIENTEDGE 0x00000200L 
 198 #ifndef ENDSESSION_LOGOFF 
 199     #define ENDSESSION_LOGOFF    0x80000000 
 202 // --------------------------------------------------------------------------- 
 203 // useful macros and functions 
 204 // --------------------------------------------------------------------------- 
 206 // a wrapper macro for ZeroMemory() 
 207 #if defined(__WIN32__) && !defined(__WXMICROWIN__) 
 208 #define wxZeroMemory(obj)   ::ZeroMemory(&obj, sizeof(obj)) 
 210 #define wxZeroMemory(obj)   memset((void*) & obj, 0, sizeof(obj)) 
 215 #include <wx/gdicmn.h> 
 217 // make conversion from wxColour and COLORREF a bit less painful 
 218 inline COLORREF 
wxColourToRGB(const wxColour
& c
) 
 220     return RGB(c
.Red(), c
.Green(), c
.Blue()); 
 223 inline COLORREF 
wxColourToPalRGB(const wxColour
& c
) 
 225     return PALETTERGB(c
.Red(), c
.Green(), c
.Blue()); 
 228 inline wxColour 
wxRGBToColour(COLORREF rgb
) 
 230     return wxColour(GetRValue(rgb
), GetGValue(rgb
), GetBValue(rgb
)); 
 233 inline void wxRGBToColour(wxColour
& c
, COLORREF rgb
) 
 235     c
.Set(GetRValue(rgb
), GetGValue(rgb
), GetBValue(rgb
)); 
 238 // get the standard colour map for some standard colours - see comment in this 
 239 // function to understand why is it needed and when should it be used 
 241 // it returns a wxCOLORMAP (can't use COLORMAP itself here as comctl32.dll 
 242 // might be not included/available) array of size wxSTD_COLOUR_MAX 
 244 // NB: if you change these colours, update wxBITMAP_STD_COLOURS in the 
 245 //     resources as well: it must have the same number of pixels! 
 251     wxSTD_COL_BTNHIGHLIGHT
, 
 255 struct WXDLLEXPORT wxCOLORMAP
 
 260 // this function is implemented in src/msw/window.cpp 
 261 extern wxCOLORMAP 
*wxGetStdColourMap(); 
 263 // copy Windows RECT to our wxRect 
 264 inline void wxCopyRECTToRect(const RECT
& r
, wxRect
& rect
) 
 268     rect
.width 
= r
.right 
- r
.left
; 
 269     rect
.height 
= r
.bottom 
- r
.top
; 
 272 // translations between HIMETRIC units (which OLE likes) and pixels (which are 
 273 // liked by all the others) - implemented in msw/utilsexc.cpp 
 274 extern void HIMETRICToPixel(LONG 
*x
, LONG 
*y
); 
 275 extern void PixelToHIMETRIC(LONG 
*x
, LONG 
*y
); 
 277 // Windows convention of the mask is opposed to the wxWindows one, so we need 
 278 // to invert the mask each time we pass one/get one to/from Windows 
 279 extern HBITMAP 
wxInvertMask(HBITMAP hbmpMask
, int w 
= 0, int h 
= 0); 
 281 // get (x, y) from DWORD - notice that HI/LOWORD can *not* be used because they 
 282 // will fail on system with multiple monitors where the coords may be negative 
 284 // these macros are standard now (Win98) but some older headers don't have them 
 286     #define GET_X_LPARAM(lp) ((int)(short)LOWORD(lp)) 
 287     #define GET_Y_LPARAM(lp) ((int)(short)HIWORD(lp)) 
 288 #endif // GET_X_LPARAM 
 290 // get the current state of SHIFT/CTRL keys 
 291 inline bool wxIsShiftDown() 
 293     return (::GetKeyState(VK_SHIFT
) & 0x100) != 0; 
 296 inline bool wxIsCtrlDown() 
 298     return (::GetKeyState(VK_CONTROL
) & 0x100) != 0; 
 301 // wrapper around GetWindowRect() and GetClientRect() APIs doing error checking 
 303 inline RECT 
wxGetWindowRect(HWND hwnd
) 
 307     ::GetWindowRect(hwnd
, &rect
); 
 309     if ( !::GetWindowRect(hwnd
, &rect
) ) 
 311         wxLogLastError(_T("GetWindowRect")); 
 318 inline RECT 
wxGetClientRect(HWND hwnd
) 
 322     ::GetClientRect(hwnd
, &rect
); 
 324     if ( !::GetClientRect(hwnd
, &rect
) ) 
 326         wxLogLastError(_T("GetClientRect")); 
 333 // --------------------------------------------------------------------------- 
 334 // small helper classes 
 335 // --------------------------------------------------------------------------- 
 337 // create an instance of this class and use it as the HDC for screen, will 
 338 // automatically release the DC going out of scope 
 342     ScreenHDC() { m_hdc 
= ::GetDC(NULL
);    } 
 343    ~ScreenHDC() { ::ReleaseDC(NULL
, m_hdc
); } 
 345     operator HDC() const { return m_hdc
; } 
 351 // the same as ScreenHDC but for memory DCs: creates the HDC in ctor and 
 352 // destroys it in dtor 
 356     MemoryHDC() { m_hdc 
= ::CreateCompatibleDC(NULL
); } 
 357    ~MemoryHDC() { ::DeleteObject(m_hdc
);              } 
 359     operator HDC() const { return m_hdc
; } 
 365 // a class which selects a GDI object into a DC in its ctor and deselects in 
 370     SelectInHDC(HDC hdc
, HGDIOBJ hgdiobj
) : m_hdc(hdc
) 
 371         { m_hgdiobj 
= ::SelectObject(hdc
, hgdiobj
); } 
 373    ~SelectInHDC() { ::SelectObject(m_hdc
, m_hgdiobj
); } 
 375    // return true if the object was successfully selected 
 376    operator bool() const { return m_hgdiobj 
!= 0; } 
 383 // --------------------------------------------------------------------------- 
 384 // macros to make casting between WXFOO and FOO a bit easier: the GetFoo() 
 385 // returns Foo cast to the Windows type for oruselves, while GetFooOf() takes 
 386 // an argument which should be a pointer or reference to the object of the 
 387 // corresponding class (this depends on the macro) 
 388 // --------------------------------------------------------------------------- 
 390 #define GetHwnd()               ((HWND)GetHWND()) 
 391 #define GetHwndOf(win)          ((HWND)((win)->GetHWND())) 
 393 #define GetWinHwnd              GetHwndOf 
 395 #define GetHdc()                ((HDC)GetHDC()) 
 396 #define GetHdcOf(dc)            ((HDC)(dc).GetHDC()) 
 398 #define GetHbitmap()            ((HBITMAP)GetHBITMAP()) 
 399 #define GetHbitmapOf(bmp)       ((HBITMAP)(bmp).GetHBITMAP()) 
 401 #define GetHicon()              ((HICON)GetHICON()) 
 402 #define GetHiconOf(icon)        ((HICON)(icon).GetHICON()) 
 404 #define GetHaccel()             ((HACCEL)GetHACCEL()) 
 405 #define GetHaccelOf(table)      ((HACCEL)((table).GetHACCEL())) 
 407 #define GetHmenu()              ((HMENU)GetHMenu()) 
 408 #define GetHmenuOf(menu)        ((HMENU)menu->GetHMenu()) 
 410 #define GetHcursor()            ((HCURSOR)GetHCURSOR()) 
 411 #define GetHcursorOf(cursor)    ((HCURSOR)(cursor).GetHCURSOR()) 
 413 #define GetHfont()              ((HFONT)GetHFONT()) 
 414 #define GetHfontOf(font)        ((HFONT)(font).GetHFONT()) 
 416 #define GetHpalette()           ((HPALETTE)GetHPALETTE()) 
 417 #define GetHpaletteOf(pal)      ((HPALETTE)(pal).GetHPALETTE()) 
 419 #define GetHrgn()               ((HRGN)GetHRGN()) 
 420 #define GetHrgnOf(rgn)          ((HRGN)(rgn).GetHRGN()) 
 424 // --------------------------------------------------------------------------- 
 426 // --------------------------------------------------------------------------- 
 428 WXDLLEXPORT_DATA(extern wxChar
*) wxBuffer
; 
 430 WXDLLEXPORT_DATA(extern HINSTANCE
) wxhInstance
; 
 432 // --------------------------------------------------------------------------- 
 434 // --------------------------------------------------------------------------- 
 438     WXDLLEXPORT HINSTANCE 
wxGetInstance(); 
 441 WXDLLEXPORT 
void wxSetInstance(HINSTANCE hInst
); 
 446 extern HCURSOR 
wxGetCurrentBusyCursor();    // from msw/utils.cpp 
 447 extern const wxCursor 
*wxGetGlobalCursor(); // from msw/cursor.cpp 
 449 WXDLLEXPORT 
void wxGetCharSize(WXHWND wnd
, int *x
, int *y
, const wxFont 
*the_font
); 
 450 WXDLLEXPORT 
void wxFillLogFont(LOGFONT 
*logFont
, const wxFont 
*font
); 
 451 WXDLLEXPORT wxFont 
wxCreateFontFromLogFont(const LOGFONT 
*logFont
); 
 452 WXDLLEXPORT wxFontEncoding 
wxGetFontEncFromCharSet(int charset
); 
 454 WXDLLEXPORT 
void wxSliderEvent(WXHWND control
, WXWORD wParam
, WXWORD pos
); 
 455 WXDLLEXPORT 
void wxScrollBarEvent(WXHWND hbar
, WXWORD wParam
, WXWORD pos
); 
 457 // Find maximum size of window/rectangle 
 458 WXDLLEXPORT 
extern void wxFindMaxSize(WXHWND hwnd
, RECT 
*rect
); 
 460 // Safely get the window text (i.e. without using fixed size buffer) 
 461 WXDLLEXPORT 
extern wxString 
wxGetWindowText(WXHWND hWnd
); 
 463 // get the window class name 
 464 WXDLLEXPORT 
extern wxString 
wxGetWindowClass(WXHWND hWnd
); 
 466 // get the window id (should be unsigned, hence this is not wxWindowID which 
 467 // is, for mainly historical reasons, signed) 
 468 WXDLLEXPORT 
extern WXWORD 
wxGetWindowId(WXHWND hWnd
); 
 470 // check if hWnd's WNDPROC is wndProc. Return true if yes, false if they are 
 472 WXDLLEXPORT 
extern bool wxCheckWindowWndProc(WXHWND hWnd
, WXFARPROC wndProc
); 
 474 // Does this window style specify any border? 
 475 inline bool wxStyleHasBorder(long style
) 
 477     return (style 
& (wxSIMPLE_BORDER 
| wxRAISED_BORDER 
| 
 478                      wxSUNKEN_BORDER 
| wxDOUBLE_BORDER
)) != 0; 
 481 // ---------------------------------------------------------------------------- 
 482 // functions mapping HWND to wxWindow 
 483 // ---------------------------------------------------------------------------- 
 485 // this function simply checks whether the given hWnd corresponds to a wxWindow 
 486 // and returns either that window if it does or NULL otherwise 
 487 WXDLLEXPORT 
extern wxWindow
* wxFindWinFromHandle(WXHWND hWnd
); 
 489 // find the window for HWND which is part of some wxWindow, i.e. unlike 
 490 // wxFindWinFromHandle() above it will also work for "sub controls" of a 
 493 // returns the wxWindow corresponding to the given HWND or NULL. 
 494 WXDLLEXPORT 
extern wxWindow 
*wxGetWindowFromHWND(WXHWND hwnd
); 
 497 // Get the size of an icon 
 498 WXDLLEXPORT 
extern wxSize 
wxGetHiconSize(HICON hicon
);