19f62ea84SAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 39f62ea84SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 49f62ea84SAndrew Rist * or more contributor license agreements. See the NOTICE file 59f62ea84SAndrew Rist * distributed with this work for additional information 69f62ea84SAndrew Rist * regarding copyright ownership. The ASF licenses this file 79f62ea84SAndrew Rist * to you under the Apache License, Version 2.0 (the 89f62ea84SAndrew Rist * "License"); you may not use this file except in compliance 99f62ea84SAndrew Rist * with the License. You may obtain a copy of the License at 10cdf0e10cSrcweir * 119f62ea84SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12cdf0e10cSrcweir * 139f62ea84SAndrew Rist * Unless required by applicable law or agreed to in writing, 149f62ea84SAndrew Rist * software distributed under the License is distributed on an 159f62ea84SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 169f62ea84SAndrew Rist * KIND, either express or implied. See the License for the 179f62ea84SAndrew Rist * specific language governing permissions and limitations 189f62ea84SAndrew Rist * under the License. 19cdf0e10cSrcweir * 209f62ea84SAndrew Rist *************************************************************/ 219f62ea84SAndrew Rist 229f62ea84SAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 25cdf0e10cSrcweir #include "precompiled_vcl.hxx" 26cdf0e10cSrcweir 27cdf0e10cSrcweir // i72022: ad-hoc to forcibly enable reconversion 28cdf0e10cSrcweir #if WINVER < 0x0500 29cdf0e10cSrcweir #undef WINVER 30cdf0e10cSrcweir #define WINVER 0x0500 31cdf0e10cSrcweir #endif 32cdf0e10cSrcweir 33cdf0e10cSrcweir #include <com/sun/star/lang/XMultiServiceFactory.hpp> 34cdf0e10cSrcweir #include <com/sun/star/container/XIndexAccess.hpp> 35cdf0e10cSrcweir #include <com/sun/star/beans/XPropertySet.hpp> 36cdf0e10cSrcweir #include <com/sun/star/awt/Rectangle.hpp> 37cdf0e10cSrcweir #include <comphelper/processfactory.hxx> 38cdf0e10cSrcweir #include <unotools/misccfg.hxx> 39cdf0e10cSrcweir 40cdf0e10cSrcweir #include <string.h> 41cdf0e10cSrcweir #include <limits.h> 42cdf0e10cSrcweir 43cdf0e10cSrcweir #include <stdio.h> 44cdf0e10cSrcweir 45cdf0e10cSrcweir #include <tools/svwin.h> 46cdf0e10cSrcweir #ifdef __MINGW32__ 47cdf0e10cSrcweir #include <excpt.h> 48cdf0e10cSrcweir #endif 49cdf0e10cSrcweir 50cdf0e10cSrcweir #include <rtl/string.h> 51cdf0e10cSrcweir #include <rtl/ustring.h> 52cdf0e10cSrcweir 53cdf0e10cSrcweir #include <osl/module.h> 54cdf0e10cSrcweir 55cdf0e10cSrcweir #include <tools/debug.hxx> 56cdf0e10cSrcweir 57cdf0e10cSrcweir #include <vcl/sysdata.hxx> 58cdf0e10cSrcweir #include <vcl/timer.hxx> 59cdf0e10cSrcweir #include <vcl/settings.hxx> 60cdf0e10cSrcweir #include <vcl/keycodes.hxx> 61cdf0e10cSrcweir #include <vcl/window.hxx> 62cdf0e10cSrcweir #include <vcl/wrkwin.hxx> 63cdf0e10cSrcweir #include <vcl/svapp.hxx> 64cdf0e10cSrcweir #include <vcl/impdel.hxx> 65cdf0e10cSrcweir 66cdf0e10cSrcweir // Warning in SDK header 67cdf0e10cSrcweir #if defined(_MSC_VER) && (_MSC_VER > 1400) 68cdf0e10cSrcweir #pragma warning( disable: 4242 4244 ) 69cdf0e10cSrcweir #endif 70cdf0e10cSrcweir #include <win/wincomp.hxx> 71cdf0e10cSrcweir #include <win/salids.hrc> 72cdf0e10cSrcweir #include <win/saldata.hxx> 73cdf0e10cSrcweir #include <win/salinst.h> 74cdf0e10cSrcweir #include <win/salbmp.h> 75cdf0e10cSrcweir #include <win/salgdi.h> 76cdf0e10cSrcweir #include <win/salsys.h> 77cdf0e10cSrcweir #include <win/salframe.h> 78cdf0e10cSrcweir #include <win/salvd.h> 79cdf0e10cSrcweir #include <win/salmenu.h> 80cdf0e10cSrcweir #include <win/salobj.h> 81cdf0e10cSrcweir #include <win/saltimer.h> 82cdf0e10cSrcweir 83cdf0e10cSrcweir #include <impbmp.hxx> 84cdf0e10cSrcweir #include <window.h> 85cdf0e10cSrcweir #include <sallayout.hxx> 86cdf0e10cSrcweir 87cdf0e10cSrcweir #define COMPILE_MULTIMON_STUBS 88cdf0e10cSrcweir #include <multimon.h> 89cdf0e10cSrcweir #include <vector> 90cdf0e10cSrcweir #ifdef __MINGW32__ 91cdf0e10cSrcweir #include <algorithm> 92cdf0e10cSrcweir using ::std::max; 93cdf0e10cSrcweir #endif 94cdf0e10cSrcweir 95df906e24SSteve Yin //IAccessibility2 Implementation 2009----- 96df906e24SSteve Yin #ifdef WNT 97df906e24SSteve Yin #include <oleacc.h> 98df906e24SSteve Yin #include <com/sun/star/accessibility/XMSAAService.hpp> 99df906e24SSteve Yin #ifndef _WIN32_WCE 100df906e24SSteve Yin #define WM_GETOBJECT 0x003D 101df906e24SSteve Yin #endif 102df906e24SSteve Yin #define OBJID_WINDOW ((LONG)0x00000000) 103df906e24SSteve Yin #define OBJID_SYSMENU ((LONG)0xFFFFFFFF) 104df906e24SSteve Yin #define OBJID_TITLEBAR ((LONG)0xFFFFFFFE) 105df906e24SSteve Yin #define OBJID_MENU ((LONG)0xFFFFFFFD) 106df906e24SSteve Yin #define OBJID_CLIENT ((LONG)0xFFFFFFFC) 107df906e24SSteve Yin #define OBJID_VSCROLL ((LONG)0xFFFFFFFB) 108df906e24SSteve Yin #define OBJID_HSCROLL ((LONG)0xFFFFFFFA) 109df906e24SSteve Yin #define OBJID_SIZEGRIP ((LONG)0xFFFFFFF9) 110df906e24SSteve Yin #define OBJID_CARET ((LONG)0xFFFFFFF8) 111df906e24SSteve Yin #define OBJID_CURSOR ((LONG)0xFFFFFFF7) 112df906e24SSteve Yin #define OBJID_ALERT ((LONG)0xFFFFFFF6) 113df906e24SSteve Yin #define OBJID_SOUND ((LONG)0xFFFFFFF5) 114df906e24SSteve Yin #define OBJID_QUERYCLASSNAMEIDX ((LONG)0xFFFFFFF4) 115df906e24SSteve Yin #define OBJID_NATIVEOM ((LONG)0xFFFFFFF0) 116df906e24SSteve Yin #include <win/g_msaasvc.h> 117df906e24SSteve Yin #endif 118df906e24SSteve Yin //-----IAccessibility2 Implementation 2009 119cdf0e10cSrcweir #include <com/sun/star/uno/Exception.hdl> 120cdf0e10cSrcweir 121cdf0e10cSrcweir #include <time.h> 122cdf0e10cSrcweir 123cdf0e10cSrcweir using ::rtl::OUString; 124cdf0e10cSrcweir using namespace ::com::sun::star; 125cdf0e10cSrcweir using namespace ::com::sun::star::uno; 126cdf0e10cSrcweir using namespace ::com::sun::star::lang; 127cdf0e10cSrcweir using namespace ::com::sun::star::container; 128cdf0e10cSrcweir using namespace ::com::sun::star::beans; 129cdf0e10cSrcweir 130cdf0e10cSrcweir // The following defines are newly added in Longhorn 131cdf0e10cSrcweir #ifndef WM_MOUSEHWHEEL 132cdf0e10cSrcweir # define WM_MOUSEHWHEEL 0x020E 133cdf0e10cSrcweir #endif 134cdf0e10cSrcweir #ifndef SPI_GETWHEELSCROLLCHARS 135cdf0e10cSrcweir # define SPI_GETWHEELSCROLLCHARS 0x006C 136cdf0e10cSrcweir #endif 137cdf0e10cSrcweir #ifndef SPI_SETWHEELSCROLLCHARS 138cdf0e10cSrcweir # define SPI_SETWHEELSCROLLCHARS 0x006D 139cdf0e10cSrcweir #endif 140cdf0e10cSrcweir 141cdf0e10cSrcweir 142cdf0e10cSrcweir 143cdf0e10cSrcweir #if OSL_DEBUG_LEVEL > 1 144cdf0e10cSrcweir void MyOutputDebugString( char *s) { OutputDebugString( s ); } 145cdf0e10cSrcweir #endif 146cdf0e10cSrcweir 147cdf0e10cSrcweir // misssing prototypes and constants for LayeredWindows 148cdf0e10cSrcweir extern "C" { 149cdf0e10cSrcweir //WINUSERAPI sal_Bool WINAPI SetLayeredWindowAttributes(HWND,COLORREF,BYTE,DWORD); 150cdf0e10cSrcweir typedef sal_Bool ( WINAPI * SetLayeredWindowAttributes_Proc_T ) (HWND,COLORREF,BYTE,DWORD); 151cdf0e10cSrcweir static SetLayeredWindowAttributes_Proc_T lpfnSetLayeredWindowAttributes; 152cdf0e10cSrcweir }; 153cdf0e10cSrcweir 154cdf0e10cSrcweir // ======================================================================= 155cdf0e10cSrcweir 156cdf0e10cSrcweir const unsigned int WM_USER_SYSTEM_WINDOW_ACTIVATED = RegisterWindowMessageA("SYSTEM_WINDOW_ACTIVATED"); 157cdf0e10cSrcweir 158cdf0e10cSrcweir sal_Bool WinSalFrame::mbInReparent = FALSE; 159cdf0e10cSrcweir 160cdf0e10cSrcweir // ======================================================================= 161cdf0e10cSrcweir 162cdf0e10cSrcweir // Wegen Fehler in Windows-Headerfiles 163cdf0e10cSrcweir #ifndef IMN_OPENCANDIDATE 164cdf0e10cSrcweir #define IMN_OPENCANDIDATE 0x0005 165cdf0e10cSrcweir #endif 166cdf0e10cSrcweir #ifndef IMN_CLOSECANDIDATE 167cdf0e10cSrcweir #define IMN_CLOSECANDIDATE 0x0004 168cdf0e10cSrcweir #endif 169cdf0e10cSrcweir 170cdf0e10cSrcweir #ifndef WM_THEMECHANGED 171cdf0e10cSrcweir #define WM_THEMECHANGED 0x031A 172cdf0e10cSrcweir #endif 173cdf0e10cSrcweir 174cdf0e10cSrcweir // Macros for support of WM_UNICHAR & Keyman 6.0 175cdf0e10cSrcweir #define Uni_UTF32ToSurrogate1(ch) (((unsigned long) (ch) - 0x10000) / 0x400 + 0xD800) 176cdf0e10cSrcweir #define Uni_UTF32ToSurrogate2(ch) (((unsigned long) (ch) - 0x10000) % 0x400 + 0xDC00) 177cdf0e10cSrcweir #define Uni_SupplementaryPlanesStart 0x10000 178cdf0e10cSrcweir 179cdf0e10cSrcweir // ======================================================================= 180df906e24SSteve Yin //IAccessibility2 Implementation 2009----- 181df906e24SSteve Yin #ifdef WNT 182df906e24SSteve Yin using namespace ::com::sun::star::accessibility; 183df906e24SSteve Yin XMSAAService* g_acc_manager1 = NULL; 184df906e24SSteve Yin #endif 185df906e24SSteve Yin //-----IAccessibility2 Implementation 2009 186cdf0e10cSrcweir static void UpdateFrameGeometry( HWND hWnd, WinSalFrame* pFrame ); 187cdf0e10cSrcweir static void SetMaximizedFrameGeometry( HWND hWnd, WinSalFrame* pFrame, RECT* pParentRect = NULL ); 188cdf0e10cSrcweir 189cdf0e10cSrcweir static void ImplSaveFrameState( WinSalFrame* pFrame ) 190cdf0e10cSrcweir { 191cdf0e10cSrcweir // Position, Groesse und Status fuer GetWindowState() merken 192cdf0e10cSrcweir if ( !pFrame->mbFullScreen ) 193cdf0e10cSrcweir { 194cdf0e10cSrcweir sal_Bool bVisible = (GetWindowStyle( pFrame->mhWnd ) & WS_VISIBLE) != 0; 195cdf0e10cSrcweir if ( IsIconic( pFrame->mhWnd ) ) 196cdf0e10cSrcweir { 197cdf0e10cSrcweir pFrame->maState.mnState |= SAL_FRAMESTATE_MINIMIZED; 198cdf0e10cSrcweir if ( bVisible ) 199cdf0e10cSrcweir pFrame->mnShowState = SW_SHOWMAXIMIZED; 200cdf0e10cSrcweir } 201cdf0e10cSrcweir else if ( IsZoomed( pFrame->mhWnd ) ) 202cdf0e10cSrcweir { 203cdf0e10cSrcweir pFrame->maState.mnState &= ~SAL_FRAMESTATE_MINIMIZED; 204cdf0e10cSrcweir pFrame->maState.mnState |= SAL_FRAMESTATE_MAXIMIZED; 205cdf0e10cSrcweir if ( bVisible ) 206cdf0e10cSrcweir pFrame->mnShowState = SW_SHOWMAXIMIZED; 207cdf0e10cSrcweir pFrame->mbRestoreMaximize = TRUE; 208cdf0e10cSrcweir 209cdf0e10cSrcweir WINDOWPLACEMENT aPlacement; 210cdf0e10cSrcweir aPlacement.length = sizeof(aPlacement); 211cdf0e10cSrcweir if( GetWindowPlacement( pFrame->mhWnd, &aPlacement ) ) 212cdf0e10cSrcweir { 213cdf0e10cSrcweir RECT aRect = aPlacement.rcNormalPosition; 214cdf0e10cSrcweir RECT aRect2 = aRect; 215cdf0e10cSrcweir AdjustWindowRectEx( &aRect2, GetWindowStyle( pFrame->mhWnd ), 216cdf0e10cSrcweir FALSE, GetWindowExStyle( pFrame->mhWnd ) ); 217cdf0e10cSrcweir long nTopDeco = abs( aRect.top - aRect2.top ); 218cdf0e10cSrcweir long nLeftDeco = abs( aRect.left - aRect2.left ); 219cdf0e10cSrcweir long nBottomDeco = abs( aRect.bottom - aRect2.bottom ); 220cdf0e10cSrcweir long nRightDeco = abs( aRect.right - aRect2.right ); 221cdf0e10cSrcweir 222cdf0e10cSrcweir pFrame->maState.mnX = aRect.left + nLeftDeco; 223cdf0e10cSrcweir pFrame->maState.mnY = aRect.top + nTopDeco; 224cdf0e10cSrcweir pFrame->maState.mnWidth = aRect.right - aRect.left - nLeftDeco - nRightDeco; 225cdf0e10cSrcweir pFrame->maState.mnHeight = aRect.bottom - aRect.top - nTopDeco - nBottomDeco; 226cdf0e10cSrcweir } 227cdf0e10cSrcweir } 228cdf0e10cSrcweir else 229cdf0e10cSrcweir { 230cdf0e10cSrcweir RECT aRect; 231cdf0e10cSrcweir GetWindowRect( pFrame->mhWnd, &aRect ); 232cdf0e10cSrcweir 233cdf0e10cSrcweir // to be consistent with Unix, the frame state is without(!) decoration 234cdf0e10cSrcweir RECT aRect2 = aRect; 235cdf0e10cSrcweir AdjustWindowRectEx( &aRect2, GetWindowStyle( pFrame->mhWnd ), 236cdf0e10cSrcweir FALSE, GetWindowExStyle( pFrame->mhWnd ) ); 237cdf0e10cSrcweir long nTopDeco = abs( aRect.top - aRect2.top ); 238cdf0e10cSrcweir long nLeftDeco = abs( aRect.left - aRect2.left ); 239cdf0e10cSrcweir long nBottomDeco = abs( aRect.bottom - aRect2.bottom ); 240cdf0e10cSrcweir long nRightDeco = abs( aRect.right - aRect2.right ); 241cdf0e10cSrcweir 242cdf0e10cSrcweir pFrame->maState.mnState &= ~(SAL_FRAMESTATE_MINIMIZED | SAL_FRAMESTATE_MAXIMIZED); 243cdf0e10cSrcweir // subtract decoration 244cdf0e10cSrcweir pFrame->maState.mnX = aRect.left+nLeftDeco; 245cdf0e10cSrcweir pFrame->maState.mnY = aRect.top+nTopDeco; 246cdf0e10cSrcweir pFrame->maState.mnWidth = aRect.right-aRect.left-nLeftDeco-nRightDeco; 247cdf0e10cSrcweir pFrame->maState.mnHeight = aRect.bottom-aRect.top-nTopDeco-nBottomDeco; 248cdf0e10cSrcweir if ( bVisible ) 249cdf0e10cSrcweir pFrame->mnShowState = SW_SHOWNORMAL; 250cdf0e10cSrcweir pFrame->mbRestoreMaximize = FALSE; 251cdf0e10cSrcweir } 252cdf0e10cSrcweir } 253cdf0e10cSrcweir } 254cdf0e10cSrcweir 255cdf0e10cSrcweir // ----------------------------------------------------------------------- 256cdf0e10cSrcweir 257cdf0e10cSrcweir // if pParentRect is set, the workarea of the monitor that contains pParentRect is returned 258cdf0e10cSrcweir void ImplSalGetWorkArea( HWND hWnd, RECT *pRect, const RECT *pParentRect ) 259cdf0e10cSrcweir { 260cdf0e10cSrcweir static int winVerChecked = 0; 261cdf0e10cSrcweir static int winVerOk = 0; 262cdf0e10cSrcweir 263cdf0e10cSrcweir // check if we or our parent is fullscreen, then the taskbar should be ignored 264cdf0e10cSrcweir bool bIgnoreTaskbar = false; 265cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 266cdf0e10cSrcweir if( pFrame ) 267cdf0e10cSrcweir { 268cdf0e10cSrcweir Window *pWin = pFrame->GetWindow(); 269cdf0e10cSrcweir while( pWin ) 270cdf0e10cSrcweir { 271cdf0e10cSrcweir WorkWindow *pWorkWin = (pWin->GetType() == WINDOW_WORKWINDOW) ? (WorkWindow *) pWin : NULL; 272cdf0e10cSrcweir if( pWorkWin && pWorkWin->ImplGetWindowImpl()->mbReallyVisible && pWorkWin->IsFullScreenMode() ) 273cdf0e10cSrcweir { 274cdf0e10cSrcweir bIgnoreTaskbar = true; 275cdf0e10cSrcweir break; 276cdf0e10cSrcweir } 277cdf0e10cSrcweir else 278cdf0e10cSrcweir pWin = pWin->ImplGetWindowImpl()->mpParent; 279cdf0e10cSrcweir } 280cdf0e10cSrcweir } 281cdf0e10cSrcweir 282cdf0e10cSrcweir if( !winVerChecked ) 283cdf0e10cSrcweir { 284cdf0e10cSrcweir winVerChecked = 1; 285cdf0e10cSrcweir winVerOk = 1; 286cdf0e10cSrcweir 287cdf0e10cSrcweir // multi monitor calls not available on Win95/NT 288cdf0e10cSrcweir if ( aSalShlData.maVersionInfo.dwPlatformId == VER_PLATFORM_WIN32_NT ) 289cdf0e10cSrcweir { 290cdf0e10cSrcweir if ( aSalShlData.maVersionInfo.dwMajorVersion <= 4 ) 291cdf0e10cSrcweir winVerOk = 0; // NT 292cdf0e10cSrcweir } 293cdf0e10cSrcweir else if( aSalShlData.maVersionInfo.dwPlatformId == VER_PLATFORM_WIN32_WINDOWS ) 294cdf0e10cSrcweir { 295cdf0e10cSrcweir if ( aSalShlData.maVersionInfo.dwMajorVersion == 4 && aSalShlData.maVersionInfo.dwMinorVersion == 0 ) 296cdf0e10cSrcweir winVerOk = 0; // Win95 297cdf0e10cSrcweir } 298cdf0e10cSrcweir } 299cdf0e10cSrcweir 300cdf0e10cSrcweir // calculates the work area taking multiple monitors into account 301cdf0e10cSrcweir if( winVerOk ) 302cdf0e10cSrcweir { 303cdf0e10cSrcweir static int nMonitors = GetSystemMetrics( SM_CMONITORS ); 304cdf0e10cSrcweir if( nMonitors == 1 ) 305cdf0e10cSrcweir { 306cdf0e10cSrcweir if( bIgnoreTaskbar ) 307cdf0e10cSrcweir { 308cdf0e10cSrcweir pRect->left = pRect->top = 0; 309cdf0e10cSrcweir pRect->right = GetSystemMetrics( SM_CXSCREEN ); 310cdf0e10cSrcweir pRect->bottom = GetSystemMetrics( SM_CYSCREEN ); 311cdf0e10cSrcweir } 312cdf0e10cSrcweir else 313cdf0e10cSrcweir SystemParametersInfo( SPI_GETWORKAREA, 0, pRect, 0 ); 314cdf0e10cSrcweir } 315cdf0e10cSrcweir else 316cdf0e10cSrcweir { 317cdf0e10cSrcweir if( pParentRect != NULL ) 318cdf0e10cSrcweir { 319cdf0e10cSrcweir // return the size of the monitor where pParentRect lives 320cdf0e10cSrcweir HMONITOR hMonitor; 321cdf0e10cSrcweir MONITORINFO mi; 322cdf0e10cSrcweir 323cdf0e10cSrcweir // get the nearest monitor to the passed rect. 324cdf0e10cSrcweir hMonitor = MonitorFromRect(pParentRect, MONITOR_DEFAULTTONEAREST); 325cdf0e10cSrcweir 326cdf0e10cSrcweir // get the work area or entire monitor rect. 327cdf0e10cSrcweir mi.cbSize = sizeof(mi); 328cdf0e10cSrcweir GetMonitorInfo(hMonitor, &mi); 329cdf0e10cSrcweir if( !bIgnoreTaskbar ) 330cdf0e10cSrcweir *pRect = mi.rcWork; 331cdf0e10cSrcweir else 332cdf0e10cSrcweir *pRect = mi.rcMonitor; 333cdf0e10cSrcweir } 334cdf0e10cSrcweir else 335cdf0e10cSrcweir { 336cdf0e10cSrcweir // return the union of all monitors 337cdf0e10cSrcweir pRect->left = GetSystemMetrics( SM_XVIRTUALSCREEN ); 338cdf0e10cSrcweir pRect->top = GetSystemMetrics( SM_YVIRTUALSCREEN ); 339cdf0e10cSrcweir pRect->right = pRect->left + GetSystemMetrics( SM_CXVIRTUALSCREEN ); 340cdf0e10cSrcweir pRect->bottom = pRect->top + GetSystemMetrics( SM_CYVIRTUALSCREEN ); 341cdf0e10cSrcweir 342cdf0e10cSrcweir // virtualscreen does not take taskbar into account, so use the corresponding 343cdf0e10cSrcweir // diffs between screen and workarea from the default screen 344cdf0e10cSrcweir // however, this is still not perfect: the taskbar might not be on the primary screen 345cdf0e10cSrcweir if( !bIgnoreTaskbar ) 346cdf0e10cSrcweir { 347cdf0e10cSrcweir RECT wRect, scrRect; 348cdf0e10cSrcweir SystemParametersInfo( SPI_GETWORKAREA, 0, &wRect, 0 ); 349cdf0e10cSrcweir scrRect.left = 0; 350cdf0e10cSrcweir scrRect.top = 0; 351cdf0e10cSrcweir scrRect.right = GetSystemMetrics( SM_CXSCREEN ); 352cdf0e10cSrcweir scrRect.bottom = GetSystemMetrics( SM_CYSCREEN ); 353cdf0e10cSrcweir 354cdf0e10cSrcweir pRect->left += wRect.left; 355cdf0e10cSrcweir pRect->top += wRect.top; 356cdf0e10cSrcweir pRect->right -= scrRect.right - wRect.right; 357cdf0e10cSrcweir pRect->bottom -= scrRect.bottom - wRect.bottom; 358cdf0e10cSrcweir } 359cdf0e10cSrcweir } 360cdf0e10cSrcweir } 361cdf0e10cSrcweir } 362cdf0e10cSrcweir else 363cdf0e10cSrcweir { 364cdf0e10cSrcweir if( bIgnoreTaskbar ) 365cdf0e10cSrcweir { 366cdf0e10cSrcweir pRect->left = pRect->top = 0; 367cdf0e10cSrcweir pRect->right = GetSystemMetrics( SM_CXSCREEN ); 368cdf0e10cSrcweir pRect->bottom = GetSystemMetrics( SM_CYSCREEN ); 369cdf0e10cSrcweir } 370cdf0e10cSrcweir else 371cdf0e10cSrcweir SystemParametersInfo( SPI_GETWORKAREA, 0, pRect, 0 ); 372cdf0e10cSrcweir } 373cdf0e10cSrcweir } 374cdf0e10cSrcweir 375cdf0e10cSrcweir // ======================================================================= 376cdf0e10cSrcweir 377cdf0e10cSrcweir SalFrame* ImplSalCreateFrame( WinSalInstance* pInst, 378cdf0e10cSrcweir HWND hWndParent, sal_uLong nSalFrameStyle ) 379cdf0e10cSrcweir { 380cdf0e10cSrcweir WinSalFrame* pFrame = new WinSalFrame; 381cdf0e10cSrcweir HWND hWnd; 382cdf0e10cSrcweir DWORD nSysStyle = 0; 383cdf0e10cSrcweir DWORD nExSysStyle = 0; 384cdf0e10cSrcweir sal_Bool bSubFrame = FALSE; 385cdf0e10cSrcweir 386cdf0e10cSrcweir if( getenv( "SAL_SYNCHRONIZE" ) ) // no buffering of drawing commands 387cdf0e10cSrcweir GdiSetBatchLimit( 1 ); 388cdf0e10cSrcweir 389cdf0e10cSrcweir static int bLayeredAPI = -1; 390cdf0e10cSrcweir if( bLayeredAPI == -1 ) 391cdf0e10cSrcweir { 392cdf0e10cSrcweir bLayeredAPI = 0; 393cdf0e10cSrcweir // check for W2k and XP 394cdf0e10cSrcweir if ( aSalShlData.maVersionInfo.dwPlatformId == VER_PLATFORM_WIN32_NT && aSalShlData.maVersionInfo.dwMajorVersion >= 5 ) 395cdf0e10cSrcweir { 396aa150a94SHerbert Dürr oslModule pLib = osl_loadAsciiModule( "user32", SAL_LOADMODULE_DEFAULT ); 397cdf0e10cSrcweir oslGenericFunction pFunc = NULL; 398cdf0e10cSrcweir if( pLib ) 399cdf0e10cSrcweir pFunc = osl_getAsciiFunctionSymbol( pLib, "SetLayeredWindowAttributes" ); 400cdf0e10cSrcweir 401cdf0e10cSrcweir lpfnSetLayeredWindowAttributes = ( SetLayeredWindowAttributes_Proc_T ) pFunc; 402cdf0e10cSrcweir 403cdf0e10cSrcweir bLayeredAPI = pFunc ? 1 : 0; 404cdf0e10cSrcweir } 405cdf0e10cSrcweir } 406cdf0e10cSrcweir static const char* pEnvTransparentFloats = getenv("SAL_TRANSPARENT_FLOATS" ); 407cdf0e10cSrcweir 408cdf0e10cSrcweir // determine creation data 409cdf0e10cSrcweir if ( nSalFrameStyle & (SAL_FRAME_STYLE_PLUG | SAL_FRAME_STYLE_SYSTEMCHILD) ) 410cdf0e10cSrcweir { 411cdf0e10cSrcweir nSysStyle |= WS_CHILD; 412cdf0e10cSrcweir if( nSalFrameStyle & SAL_FRAME_STYLE_SYSTEMCHILD ) 413cdf0e10cSrcweir nSysStyle |= WS_CLIPSIBLINGS; 414cdf0e10cSrcweir } 415cdf0e10cSrcweir else 416cdf0e10cSrcweir { 417cdf0e10cSrcweir // #i87402# commenting out WS_CLIPCHILDREN 418cdf0e10cSrcweir // this breaks SAL_FRAME_STYLE_SYSTEMCHILD handling, which is not 419cdf0e10cSrcweir // used currently. Probably SAL_FRAME_STYLE_SYSTEMCHILD should be 420cdf0e10cSrcweir // removed again. 421cdf0e10cSrcweir 422cdf0e10cSrcweir // nSysStyle |= WS_CLIPCHILDREN; 423cdf0e10cSrcweir if ( hWndParent ) 424cdf0e10cSrcweir { 425cdf0e10cSrcweir nSysStyle |= WS_POPUP; 426cdf0e10cSrcweir bSubFrame = TRUE; 427cdf0e10cSrcweir pFrame->mbNoIcon = TRUE; 428cdf0e10cSrcweir } 429cdf0e10cSrcweir else 430cdf0e10cSrcweir { 431cdf0e10cSrcweir // Only with WS_OVRLAPPED we get a useful default position/size 432cdf0e10cSrcweir if ( (nSalFrameStyle & (SAL_FRAME_STYLE_SIZEABLE | SAL_FRAME_STYLE_MOVEABLE)) == 433cdf0e10cSrcweir (SAL_FRAME_STYLE_SIZEABLE | SAL_FRAME_STYLE_MOVEABLE) ) 434cdf0e10cSrcweir nSysStyle |= WS_OVERLAPPED; 435cdf0e10cSrcweir else 436cdf0e10cSrcweir { 437cdf0e10cSrcweir nSysStyle |= WS_POPUP; 438cdf0e10cSrcweir if ( !(nSalFrameStyle & SAL_FRAME_STYLE_MOVEABLE) ) 439cdf0e10cSrcweir nExSysStyle |= WS_EX_TOOLWINDOW; // avoid taskbar appearance, for eg splash screen 440cdf0e10cSrcweir } 441cdf0e10cSrcweir } 442cdf0e10cSrcweir 443cdf0e10cSrcweir if ( nSalFrameStyle & SAL_FRAME_STYLE_MOVEABLE ) 444cdf0e10cSrcweir { 445cdf0e10cSrcweir pFrame->mbCaption = TRUE; 446cdf0e10cSrcweir nSysStyle |= WS_SYSMENU | WS_CAPTION; 447cdf0e10cSrcweir if ( !hWndParent ) 448cdf0e10cSrcweir nSysStyle |= WS_SYSMENU | WS_MINIMIZEBOX; 449cdf0e10cSrcweir else 450cdf0e10cSrcweir nExSysStyle |= WS_EX_DLGMODALFRAME; 451cdf0e10cSrcweir 452cdf0e10cSrcweir if ( nSalFrameStyle & SAL_FRAME_STYLE_SIZEABLE ) 453cdf0e10cSrcweir { 454cdf0e10cSrcweir pFrame->mbSizeBorder = TRUE; 455cdf0e10cSrcweir nSysStyle |= WS_THICKFRAME; 456cdf0e10cSrcweir if ( !hWndParent ) 457cdf0e10cSrcweir nSysStyle |= WS_MAXIMIZEBOX; 458cdf0e10cSrcweir } 459cdf0e10cSrcweir else 460cdf0e10cSrcweir pFrame->mbFixBorder = TRUE; 461cdf0e10cSrcweir 462cdf0e10cSrcweir if ( nSalFrameStyle & SAL_FRAME_STYLE_DEFAULT ) 463cdf0e10cSrcweir nExSysStyle |= WS_EX_APPWINDOW; 464cdf0e10cSrcweir } 465cdf0e10cSrcweir if( nSalFrameStyle & SAL_FRAME_STYLE_TOOLWINDOW 466cdf0e10cSrcweir // #100656# toolwindows lead to bad alt-tab behaviour, if they have the focus 467cdf0e10cSrcweir // you must press it twice to leave the application 468cdf0e10cSrcweir // so toolwindows are only used for non sizeable windows 469cdf0e10cSrcweir // which are typically small, so a small caption makes sense 470cdf0e10cSrcweir 471cdf0e10cSrcweir // #103578# looked too bad - above changes reverted 472cdf0e10cSrcweir /* && !(nSalFrameStyle & SAL_FRAME_STYLE_SIZEABLE) */ ) 473cdf0e10cSrcweir { 474cdf0e10cSrcweir pFrame->mbNoIcon = TRUE; 475cdf0e10cSrcweir nExSysStyle |= WS_EX_TOOLWINDOW; 476cdf0e10cSrcweir if ( pEnvTransparentFloats && bLayeredAPI == 1 /*&& !(nSalFrameStyle & SAL_FRAME_STYLE_MOVEABLE) */) 477cdf0e10cSrcweir nExSysStyle |= WS_EX_LAYERED; 478cdf0e10cSrcweir } 479cdf0e10cSrcweir } 480cdf0e10cSrcweir if ( nSalFrameStyle & SAL_FRAME_STYLE_FLOAT ) 481cdf0e10cSrcweir { 482cdf0e10cSrcweir nExSysStyle |= WS_EX_TOOLWINDOW; 483cdf0e10cSrcweir pFrame->mbFloatWin = TRUE; 484cdf0e10cSrcweir 485cdf0e10cSrcweir if ( (bLayeredAPI == 1) && (pEnvTransparentFloats /* does not work remote! || (nSalFrameStyle & SAL_FRAME_STYLE_FLOAT_FOCUSABLE) */ ) ) 486cdf0e10cSrcweir nExSysStyle |= WS_EX_LAYERED; 487cdf0e10cSrcweir 488cdf0e10cSrcweir } 489cdf0e10cSrcweir if( (nSalFrameStyle & SAL_FRAME_STYLE_TOOLTIP) || (nSalFrameStyle & SAL_FRAME_STYLE_FLOAT_FOCUSABLE) ) 490cdf0e10cSrcweir nExSysStyle |= WS_EX_TOPMOST; 491cdf0e10cSrcweir 492cdf0e10cSrcweir // init frame data 493cdf0e10cSrcweir pFrame->mnStyle = nSalFrameStyle; 494cdf0e10cSrcweir 495cdf0e10cSrcweir // determine show style 496cdf0e10cSrcweir pFrame->mnShowState = SW_SHOWNORMAL; 497cdf0e10cSrcweir if ( (nSysStyle & (WS_POPUP | WS_MAXIMIZEBOX | WS_THICKFRAME)) == (WS_MAXIMIZEBOX | WS_THICKFRAME) ) 498cdf0e10cSrcweir { 499cdf0e10cSrcweir if ( GetSystemMetrics( SM_CXSCREEN ) <= 1024 ) 500cdf0e10cSrcweir pFrame->mnShowState = SW_SHOWMAXIMIZED; 501cdf0e10cSrcweir else 502cdf0e10cSrcweir { 503cdf0e10cSrcweir if ( nSalFrameStyle & SAL_FRAME_STYLE_DEFAULT ) 504cdf0e10cSrcweir { 505cdf0e10cSrcweir SalData* pSalData = GetSalData(); 506cdf0e10cSrcweir pFrame->mnShowState = pSalData->mnCmdShow; 507cdf0e10cSrcweir if ( (pFrame->mnShowState != SW_SHOWMINIMIZED) && 508cdf0e10cSrcweir (pFrame->mnShowState != SW_MINIMIZE) && 509cdf0e10cSrcweir (pFrame->mnShowState != SW_SHOWMINNOACTIVE) ) 510cdf0e10cSrcweir { 511cdf0e10cSrcweir if ( (pFrame->mnShowState == SW_SHOWMAXIMIZED) || 512cdf0e10cSrcweir (pFrame->mnShowState == SW_MAXIMIZE) ) 513cdf0e10cSrcweir pFrame->mbOverwriteState = FALSE; 514cdf0e10cSrcweir pFrame->mnShowState = SW_SHOWMAXIMIZED; 515cdf0e10cSrcweir } 516cdf0e10cSrcweir else 517cdf0e10cSrcweir pFrame->mbOverwriteState = FALSE; 518cdf0e10cSrcweir } 519cdf0e10cSrcweir else 520cdf0e10cSrcweir { 521cdf0e10cSrcweir // Document Windows are also maximized, if the current Document Window 522cdf0e10cSrcweir // is also maximized 523cdf0e10cSrcweir HWND hWnd = GetForegroundWindow(); 524cdf0e10cSrcweir if ( hWnd && IsMaximized( hWnd ) && 525cdf0e10cSrcweir (GetWindowInstance( hWnd ) == pInst->mhInst) && 526cdf0e10cSrcweir ((GetWindowStyle( hWnd ) & (WS_POPUP | WS_MAXIMIZEBOX | WS_THICKFRAME)) == (WS_MAXIMIZEBOX | WS_THICKFRAME)) ) 527cdf0e10cSrcweir pFrame->mnShowState = SW_SHOWMAXIMIZED; 528cdf0e10cSrcweir } 529cdf0e10cSrcweir } 530cdf0e10cSrcweir } 531cdf0e10cSrcweir 532cdf0e10cSrcweir // create frame 533cdf0e10cSrcweir if( true/*aSalShlData.mbWNT*/ ) 534cdf0e10cSrcweir { 535cdf0e10cSrcweir LPCWSTR pClassName; 536cdf0e10cSrcweir if ( bSubFrame ) 537cdf0e10cSrcweir { 538cdf0e10cSrcweir if ( nSalFrameStyle & (SAL_FRAME_STYLE_MOVEABLE|SAL_FRAME_STYLE_NOSHADOW) ) // check if shadow not wanted 539cdf0e10cSrcweir pClassName = SAL_SUBFRAME_CLASSNAMEW; 540cdf0e10cSrcweir else 541cdf0e10cSrcweir pClassName = SAL_TMPSUBFRAME_CLASSNAMEW; // undecorated floaters will get shadow on XP 542cdf0e10cSrcweir } 543cdf0e10cSrcweir else 544cdf0e10cSrcweir { 545cdf0e10cSrcweir if ( nSalFrameStyle & SAL_FRAME_STYLE_MOVEABLE ) 546cdf0e10cSrcweir pClassName = SAL_FRAME_CLASSNAMEW; 547cdf0e10cSrcweir else 548cdf0e10cSrcweir pClassName = SAL_TMPSUBFRAME_CLASSNAMEW; 549cdf0e10cSrcweir } 550cdf0e10cSrcweir hWnd = CreateWindowExW( nExSysStyle, pClassName, L"", nSysStyle, 551cdf0e10cSrcweir CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, 552cdf0e10cSrcweir hWndParent, 0, pInst->mhInst, (void*)pFrame ); 553cdf0e10cSrcweir if( !hWnd ) 554cdf0e10cSrcweir ImplWriteLastError( GetLastError(), "CreateWindowEx" ); 555cdf0e10cSrcweir #if OSL_DEBUG_LEVEL > 1 556cdf0e10cSrcweir // set transparency value 557cdf0e10cSrcweir if( bLayeredAPI == 1 && GetWindowExStyle( hWnd ) & WS_EX_LAYERED ) 558cdf0e10cSrcweir lpfnSetLayeredWindowAttributes( hWnd, 0, 230, 0x00000002 /*LWA_ALPHA*/ ); 559cdf0e10cSrcweir #endif 560cdf0e10cSrcweir } 561cdf0e10cSrcweir if ( !hWnd ) 562cdf0e10cSrcweir { 563cdf0e10cSrcweir delete pFrame; 564cdf0e10cSrcweir return NULL; 565cdf0e10cSrcweir } 566cdf0e10cSrcweir 567cdf0e10cSrcweir // If we have an Window with an Caption Bar and without 568cdf0e10cSrcweir // an MaximizeBox, we change the SystemMenu 569cdf0e10cSrcweir if ( (nSysStyle & (WS_CAPTION | WS_MAXIMIZEBOX)) == (WS_CAPTION) ) 570cdf0e10cSrcweir { 571cdf0e10cSrcweir HMENU hSysMenu = GetSystemMenu( hWnd, FALSE ); 572cdf0e10cSrcweir if ( hSysMenu ) 573cdf0e10cSrcweir { 574cdf0e10cSrcweir if ( !(nSysStyle & (WS_MINIMIZEBOX | WS_MAXIMIZEBOX)) ) 575cdf0e10cSrcweir DeleteMenu( hSysMenu, SC_RESTORE, MF_BYCOMMAND ); 576cdf0e10cSrcweir else 577cdf0e10cSrcweir EnableMenuItem( hSysMenu, SC_RESTORE, MF_BYCOMMAND | MF_GRAYED | MF_DISABLED ); 578cdf0e10cSrcweir if ( !(nSysStyle & WS_MINIMIZEBOX) ) 579cdf0e10cSrcweir DeleteMenu( hSysMenu, SC_MINIMIZE, MF_BYCOMMAND ); 580cdf0e10cSrcweir if ( !(nSysStyle & WS_MAXIMIZEBOX) ) 581cdf0e10cSrcweir DeleteMenu( hSysMenu, SC_MAXIMIZE, MF_BYCOMMAND ); 582cdf0e10cSrcweir if ( !(nSysStyle & WS_THICKFRAME) ) 583cdf0e10cSrcweir DeleteMenu( hSysMenu, SC_SIZE, MF_BYCOMMAND ); 584cdf0e10cSrcweir } 585cdf0e10cSrcweir } 586cdf0e10cSrcweir if ( (nSysStyle & WS_SYSMENU) && !(nSalFrameStyle & SAL_FRAME_STYLE_CLOSEABLE) ) 587cdf0e10cSrcweir { 588cdf0e10cSrcweir HMENU hSysMenu = GetSystemMenu( hWnd, FALSE ); 589cdf0e10cSrcweir if ( hSysMenu ) 590cdf0e10cSrcweir EnableMenuItem( hSysMenu, SC_CLOSE, MF_BYCOMMAND | MF_GRAYED | MF_DISABLED ); 591cdf0e10cSrcweir } 592cdf0e10cSrcweir 593cdf0e10cSrcweir // reset input context 594cdf0e10cSrcweir pFrame->mhDefIMEContext = ImmAssociateContext( hWnd, 0 ); 595cdf0e10cSrcweir 596cdf0e10cSrcweir // determine output size and state 597cdf0e10cSrcweir RECT aRect; 598cdf0e10cSrcweir GetClientRect( hWnd, &aRect ); 599cdf0e10cSrcweir pFrame->mnWidth = aRect.right; 600cdf0e10cSrcweir pFrame->mnHeight = aRect.bottom; 601cdf0e10cSrcweir ImplSaveFrameState( pFrame ); 602cdf0e10cSrcweir pFrame->mbDefPos = TRUE; 603cdf0e10cSrcweir 604cdf0e10cSrcweir UpdateFrameGeometry( hWnd, pFrame ); 605cdf0e10cSrcweir 606cdf0e10cSrcweir if( pFrame->mnShowState == SW_SHOWMAXIMIZED ) 607cdf0e10cSrcweir { 608cdf0e10cSrcweir // #96084 set a useful internal window size because 609cdf0e10cSrcweir // the window will not be maximized (and the size updated) before show() 610cdf0e10cSrcweir 611cdf0e10cSrcweir SetMaximizedFrameGeometry( hWnd, pFrame ); 612cdf0e10cSrcweir } 613cdf0e10cSrcweir 614cdf0e10cSrcweir return pFrame; 615cdf0e10cSrcweir } 616cdf0e10cSrcweir 617cdf0e10cSrcweir // helper that only creates the HWND 618cdf0e10cSrcweir // to allow for easy reparenting of system windows, (i.e. destroy and create new) 619cdf0e10cSrcweir HWND ImplSalReCreateHWND( HWND hWndParent, HWND oldhWnd, sal_Bool bAsChild ) 620cdf0e10cSrcweir { 621cdf0e10cSrcweir HINSTANCE hInstance = GetSalData()->mhInst; 622cdf0e10cSrcweir ULONG nSysStyle = GetWindowLong( oldhWnd, GWL_STYLE ); 623cdf0e10cSrcweir ULONG nExSysStyle = GetWindowLong( oldhWnd, GWL_EXSTYLE ); 624cdf0e10cSrcweir 625cdf0e10cSrcweir if( bAsChild ) 626cdf0e10cSrcweir { 627cdf0e10cSrcweir nSysStyle = WS_CHILD; 628cdf0e10cSrcweir nExSysStyle = 0; 629cdf0e10cSrcweir } 630cdf0e10cSrcweir 631cdf0e10cSrcweir LPCWSTR pClassName = SAL_SUBFRAME_CLASSNAMEW; 632cdf0e10cSrcweir HWND hWnd = CreateWindowExW( nExSysStyle, pClassName, L"", nSysStyle, 633cdf0e10cSrcweir CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, 634cdf0e10cSrcweir hWndParent, 0, hInstance, (void*)GetWindowPtr( oldhWnd ) ); 635cdf0e10cSrcweir return hWnd; 636cdf0e10cSrcweir } 637cdf0e10cSrcweir 638cdf0e10cSrcweir // ======================================================================= 639cdf0e10cSrcweir 640cdf0e10cSrcweir // Uebersetzungstabelle von System-Keycodes in StarView-Keycodes 641cdf0e10cSrcweir #define KEY_TAB_SIZE 146 642cdf0e10cSrcweir 643cdf0e10cSrcweir static sal_uInt16 aImplTranslateKeyTab[KEY_TAB_SIZE] = 644cdf0e10cSrcweir { 645cdf0e10cSrcweir // StarView-Code System-Code Index 646cdf0e10cSrcweir 0, // 0 647cdf0e10cSrcweir 0, // VK_LBUTTON 1 648cdf0e10cSrcweir 0, // VK_RBUTTON 2 649cdf0e10cSrcweir 0, // VK_CANCEL 3 650cdf0e10cSrcweir 0, // VK_MBUTTON 4 651cdf0e10cSrcweir 0, // 5 652cdf0e10cSrcweir 0, // 6 653cdf0e10cSrcweir 0, // 7 654cdf0e10cSrcweir KEY_BACKSPACE, // VK_BACK 8 655cdf0e10cSrcweir KEY_TAB, // VK_TAB 9 656cdf0e10cSrcweir 0, // 10 657cdf0e10cSrcweir 0, // 11 658cdf0e10cSrcweir 0, // VK_CLEAR 12 659cdf0e10cSrcweir KEY_RETURN, // VK_RETURN 13 660cdf0e10cSrcweir 0, // 14 661cdf0e10cSrcweir 0, // 15 662cdf0e10cSrcweir 0, // VK_SHIFT 16 663cdf0e10cSrcweir 0, // VK_CONTROL 17 664cdf0e10cSrcweir 0, // VK_MENU 18 665cdf0e10cSrcweir 0, // VK_PAUSE 19 666cdf0e10cSrcweir 0, // VK_CAPITAL 20 667cdf0e10cSrcweir 0, // VK_HANGUL 21 668cdf0e10cSrcweir 0, // 22 669cdf0e10cSrcweir 0, // 23 670cdf0e10cSrcweir 0, // 24 671cdf0e10cSrcweir KEY_HANGUL_HANJA, // VK_HANJA 25 672cdf0e10cSrcweir 0, // 26 673cdf0e10cSrcweir KEY_ESCAPE, // VK_ESCAPE 27 674cdf0e10cSrcweir 0, // 28 675cdf0e10cSrcweir 0, // 29 676cdf0e10cSrcweir 0, // 30 677cdf0e10cSrcweir 0, // 31 678cdf0e10cSrcweir KEY_SPACE, // VK_SPACE 32 679cdf0e10cSrcweir KEY_PAGEUP, // VK_PRIOR 33 680cdf0e10cSrcweir KEY_PAGEDOWN, // VK_NEXT 34 681cdf0e10cSrcweir KEY_END, // VK_END 35 682cdf0e10cSrcweir KEY_HOME, // VK_HOME 36 683cdf0e10cSrcweir KEY_LEFT, // VK_LEFT 37 684cdf0e10cSrcweir KEY_UP, // VK_UP 38 685cdf0e10cSrcweir KEY_RIGHT, // VK_RIGHT 39 686cdf0e10cSrcweir KEY_DOWN, // VK_DOWN 40 687cdf0e10cSrcweir 0, // VK_SELECT 41 688cdf0e10cSrcweir 0, // VK_PRINT 42 689cdf0e10cSrcweir 0, // VK_EXECUTE 43 690cdf0e10cSrcweir 0, // VK_SNAPSHOT 44 691cdf0e10cSrcweir KEY_INSERT, // VK_INSERT 45 692cdf0e10cSrcweir KEY_DELETE, // VK_DELETE 46 693cdf0e10cSrcweir KEY_HELP, // VK_HELP 47 694cdf0e10cSrcweir KEY_0, // 48 695cdf0e10cSrcweir KEY_1, // 49 696cdf0e10cSrcweir KEY_2, // 50 697cdf0e10cSrcweir KEY_3, // 51 698cdf0e10cSrcweir KEY_4, // 52 699cdf0e10cSrcweir KEY_5, // 53 700cdf0e10cSrcweir KEY_6, // 54 701cdf0e10cSrcweir KEY_7, // 55 702cdf0e10cSrcweir KEY_8, // 56 703cdf0e10cSrcweir KEY_9, // 57 704cdf0e10cSrcweir 0, // 58 705cdf0e10cSrcweir 0, // 59 706cdf0e10cSrcweir 0, // 60 707cdf0e10cSrcweir 0, // 61 708cdf0e10cSrcweir 0, // 62 709cdf0e10cSrcweir 0, // 63 710cdf0e10cSrcweir 0, // 64 711cdf0e10cSrcweir KEY_A, // 65 712cdf0e10cSrcweir KEY_B, // 66 713cdf0e10cSrcweir KEY_C, // 67 714cdf0e10cSrcweir KEY_D, // 68 715cdf0e10cSrcweir KEY_E, // 69 716cdf0e10cSrcweir KEY_F, // 70 717cdf0e10cSrcweir KEY_G, // 71 718cdf0e10cSrcweir KEY_H, // 72 719cdf0e10cSrcweir KEY_I, // 73 720cdf0e10cSrcweir KEY_J, // 74 721cdf0e10cSrcweir KEY_K, // 75 722cdf0e10cSrcweir KEY_L, // 76 723cdf0e10cSrcweir KEY_M, // 77 724cdf0e10cSrcweir KEY_N, // 78 725cdf0e10cSrcweir KEY_O, // 79 726cdf0e10cSrcweir KEY_P, // 80 727cdf0e10cSrcweir KEY_Q, // 81 728cdf0e10cSrcweir KEY_R, // 82 729cdf0e10cSrcweir KEY_S, // 83 730cdf0e10cSrcweir KEY_T, // 84 731cdf0e10cSrcweir KEY_U, // 85 732cdf0e10cSrcweir KEY_V, // 86 733cdf0e10cSrcweir KEY_W, // 87 734cdf0e10cSrcweir KEY_X, // 88 735cdf0e10cSrcweir KEY_Y, // 89 736cdf0e10cSrcweir KEY_Z, // 90 737cdf0e10cSrcweir 0, // VK_LWIN 91 738cdf0e10cSrcweir 0, // VK_RWIN 92 739cdf0e10cSrcweir KEY_CONTEXTMENU, // VK_APPS 93 740cdf0e10cSrcweir 0, // 94 741cdf0e10cSrcweir 0, // 95 742cdf0e10cSrcweir KEY_0, // VK_NUMPAD0 96 743cdf0e10cSrcweir KEY_1, // VK_NUMPAD1 97 744cdf0e10cSrcweir KEY_2, // VK_NUMPAD2 98 745cdf0e10cSrcweir KEY_3, // VK_NUMPAD3 99 746cdf0e10cSrcweir KEY_4, // VK_NUMPAD4 100 747cdf0e10cSrcweir KEY_5, // VK_NUMPAD5 101 748cdf0e10cSrcweir KEY_6, // VK_NUMPAD6 102 749cdf0e10cSrcweir KEY_7, // VK_NUMPAD7 103 750cdf0e10cSrcweir KEY_8, // VK_NUMPAD8 104 751cdf0e10cSrcweir KEY_9, // VK_NUMPAD9 105 752cdf0e10cSrcweir KEY_MULTIPLY, // VK_MULTIPLY 106 753cdf0e10cSrcweir KEY_ADD, // VK_ADD 107 754cdf0e10cSrcweir KEY_DECIMAL, // VK_SEPARATOR 108 755cdf0e10cSrcweir KEY_SUBTRACT, // VK_SUBTRACT 109 756cdf0e10cSrcweir KEY_DECIMAL, // VK_DECIMAL 110 757cdf0e10cSrcweir KEY_DIVIDE, // VK_DIVIDE 111 758cdf0e10cSrcweir KEY_F1, // VK_F1 112 759cdf0e10cSrcweir KEY_F2, // VK_F2 113 760cdf0e10cSrcweir KEY_F3, // VK_F3 114 761cdf0e10cSrcweir KEY_F4, // VK_F4 115 762cdf0e10cSrcweir KEY_F5, // VK_F5 116 763cdf0e10cSrcweir KEY_F6, // VK_F6 117 764cdf0e10cSrcweir KEY_F7, // VK_F7 118 765cdf0e10cSrcweir KEY_F8, // VK_F8 119 766cdf0e10cSrcweir KEY_F9, // VK_F9 120 767cdf0e10cSrcweir KEY_F10, // VK_F10 121 768cdf0e10cSrcweir KEY_F11, // VK_F11 122 769cdf0e10cSrcweir KEY_F12, // VK_F12 123 770cdf0e10cSrcweir KEY_F13, // VK_F13 124 771cdf0e10cSrcweir KEY_F14, // VK_F14 125 772cdf0e10cSrcweir KEY_F15, // VK_F15 126 773cdf0e10cSrcweir KEY_F16, // VK_F16 127 774cdf0e10cSrcweir KEY_F17, // VK_F17 128 775cdf0e10cSrcweir KEY_F18, // VK_F18 129 776cdf0e10cSrcweir KEY_F19, // VK_F19 130 777cdf0e10cSrcweir KEY_F20, // VK_F20 131 778cdf0e10cSrcweir KEY_F21, // VK_F21 132 779cdf0e10cSrcweir KEY_F22, // VK_F22 133 780cdf0e10cSrcweir KEY_F23, // VK_F23 134 781cdf0e10cSrcweir KEY_F24, // VK_F24 135 782cdf0e10cSrcweir 0, // 136 783cdf0e10cSrcweir 0, // 137 784cdf0e10cSrcweir 0, // 138 785cdf0e10cSrcweir 0, // 139 786cdf0e10cSrcweir 0, // 140 787cdf0e10cSrcweir 0, // 141 788cdf0e10cSrcweir 0, // 142 789cdf0e10cSrcweir 0, // 143 790cdf0e10cSrcweir 0, // NUMLOCK 144 791cdf0e10cSrcweir 0 // SCROLLLOCK 145 792cdf0e10cSrcweir }; 793cdf0e10cSrcweir 794cdf0e10cSrcweir // ======================================================================= 795cdf0e10cSrcweir 796cdf0e10cSrcweir static UINT ImplSalGetWheelScrollLines() 797cdf0e10cSrcweir { 798cdf0e10cSrcweir UINT nScrLines = 0; 799cdf0e10cSrcweir HWND hWndMsWheel = WIN_FindWindow( MSH_WHEELMODULE_CLASS, MSH_WHEELMODULE_TITLE ); 800cdf0e10cSrcweir if ( hWndMsWheel ) 801cdf0e10cSrcweir { 802cdf0e10cSrcweir UINT nGetScrollLinesMsgId = RegisterWindowMessage( MSH_SCROLL_LINES ); 803cdf0e10cSrcweir nScrLines = (UINT)ImplSendMessage( hWndMsWheel, nGetScrollLinesMsgId, 0, 0 ); 804cdf0e10cSrcweir } 805cdf0e10cSrcweir 806cdf0e10cSrcweir if ( !nScrLines ) 807cdf0e10cSrcweir if( !SystemParametersInfo( SPI_GETWHEELSCROLLLINES, 0, &nScrLines, 0 ) ) 808cdf0e10cSrcweir nScrLines = 0 ; 809cdf0e10cSrcweir 810cdf0e10cSrcweir if ( !nScrLines ) 811cdf0e10cSrcweir nScrLines = 3; 812cdf0e10cSrcweir 813cdf0e10cSrcweir return nScrLines; 814cdf0e10cSrcweir } 815cdf0e10cSrcweir 816cdf0e10cSrcweir // ----------------------------------------------------------------------- 817cdf0e10cSrcweir 818cdf0e10cSrcweir static UINT ImplSalGetWheelScrollChars() 819cdf0e10cSrcweir { 820cdf0e10cSrcweir UINT nScrChars = 0; 821cdf0e10cSrcweir if( !SystemParametersInfo( SPI_GETWHEELSCROLLCHARS, 0, &nScrChars, 0 ) ) 822cdf0e10cSrcweir { 823cdf0e10cSrcweir // Depending on Windows version, use proper default or 1 (when 824cdf0e10cSrcweir // driver emulates hscroll) 825cdf0e10cSrcweir if( VER_PLATFORM_WIN32_NT == aSalShlData.maVersionInfo.dwPlatformId && 826cdf0e10cSrcweir aSalShlData.maVersionInfo.dwMajorVersion < 6 ) 827cdf0e10cSrcweir { 828cdf0e10cSrcweir // Windows 2000 & WinXP : emulating driver, use step size 829cdf0e10cSrcweir // of 1 830cdf0e10cSrcweir return 1; 831cdf0e10cSrcweir } 832cdf0e10cSrcweir else 833cdf0e10cSrcweir { 834cdf0e10cSrcweir // Longhorn or above: use proper default value of 3 835cdf0e10cSrcweir return 3; 836cdf0e10cSrcweir } 837cdf0e10cSrcweir } 838cdf0e10cSrcweir 839cdf0e10cSrcweir // system settings successfully read 840cdf0e10cSrcweir return nScrChars; 841cdf0e10cSrcweir } 842cdf0e10cSrcweir 843cdf0e10cSrcweir // ----------------------------------------------------------------------- 844cdf0e10cSrcweir 845cdf0e10cSrcweir static void ImplSalAddBorder( const WinSalFrame* pFrame, int& width, int& height ) 846cdf0e10cSrcweir { 847cdf0e10cSrcweir // transform client size into window size 848cdf0e10cSrcweir RECT aWinRect; 849cdf0e10cSrcweir aWinRect.left = 0; 850cdf0e10cSrcweir aWinRect.right = width-1; 851cdf0e10cSrcweir aWinRect.top = 0; 852cdf0e10cSrcweir aWinRect.bottom = height-1; 853cdf0e10cSrcweir AdjustWindowRectEx( &aWinRect, GetWindowStyle( pFrame->mhWnd ), 854cdf0e10cSrcweir FALSE, GetWindowExStyle( pFrame->mhWnd ) ); 855cdf0e10cSrcweir width = aWinRect.right - aWinRect.left + 1; 856cdf0e10cSrcweir height = aWinRect.bottom - aWinRect.top + 1; 857cdf0e10cSrcweir } 858cdf0e10cSrcweir 859cdf0e10cSrcweir // ----------------------------------------------------------------------- 860cdf0e10cSrcweir 861cdf0e10cSrcweir static void ImplSalCalcFullScreenSize( const WinSalFrame* pFrame, 862cdf0e10cSrcweir int& rX, int& rY, int& rDX, int& rDY ) 863cdf0e10cSrcweir { 864cdf0e10cSrcweir // set window to screen size 865cdf0e10cSrcweir int nFrameX; 866cdf0e10cSrcweir int nFrameY; 867cdf0e10cSrcweir int nCaptionY; 868cdf0e10cSrcweir int nScreenX = 0; 869cdf0e10cSrcweir int nScreenY = 0; 870cdf0e10cSrcweir int nScreenDX = 0; 871cdf0e10cSrcweir int nScreenDY = 0; 872cdf0e10cSrcweir 873cdf0e10cSrcweir if ( pFrame->mbSizeBorder ) 874cdf0e10cSrcweir { 875cdf0e10cSrcweir nFrameX = GetSystemMetrics( SM_CXSIZEFRAME ); 876cdf0e10cSrcweir nFrameY = GetSystemMetrics( SM_CYSIZEFRAME ); 877cdf0e10cSrcweir } 878cdf0e10cSrcweir else if ( pFrame->mbFixBorder ) 879cdf0e10cSrcweir { 880cdf0e10cSrcweir nFrameX = GetSystemMetrics( SM_CXFIXEDFRAME ); 881cdf0e10cSrcweir nFrameY = GetSystemMetrics( SM_CYFIXEDFRAME ); 882cdf0e10cSrcweir } 883cdf0e10cSrcweir else if ( pFrame->mbBorder ) 884cdf0e10cSrcweir { 885cdf0e10cSrcweir nFrameX = GetSystemMetrics( SM_CXBORDER ); 886cdf0e10cSrcweir nFrameY = GetSystemMetrics( SM_CYBORDER ); 887cdf0e10cSrcweir } 888cdf0e10cSrcweir else 889cdf0e10cSrcweir { 890cdf0e10cSrcweir nFrameX = 0; 891cdf0e10cSrcweir nFrameY = 0; 892cdf0e10cSrcweir } 893cdf0e10cSrcweir if ( pFrame->mbCaption ) 894cdf0e10cSrcweir nCaptionY = GetSystemMetrics( SM_CYCAPTION ); 895cdf0e10cSrcweir else 896cdf0e10cSrcweir nCaptionY = 0; 897cdf0e10cSrcweir 898cdf0e10cSrcweir try 899cdf0e10cSrcweir { 900cdf0e10cSrcweir uno::Reference< XMultiServiceFactory > xFactory( ::comphelper::getProcessServiceFactory(), UNO_QUERY_THROW ); 901cdf0e10cSrcweir uno::Reference< XIndexAccess > xMultiMon( xFactory->createInstance(OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.awt.DisplayAccess" ) ) ), UNO_QUERY_THROW ); 902cdf0e10cSrcweir sal_Int32 nMonitors = xMultiMon->getCount(); 903cdf0e10cSrcweir if( (pFrame->mnDisplay >= 0) && (pFrame->mnDisplay < nMonitors) ) 904cdf0e10cSrcweir { 905cdf0e10cSrcweir uno::Reference< XPropertySet > xMonitor( xMultiMon->getByIndex( pFrame->mnDisplay ), UNO_QUERY_THROW ); 906cdf0e10cSrcweir com::sun::star::awt::Rectangle aRect; 907cdf0e10cSrcweir if( xMonitor->getPropertyValue( OUString( RTL_CONSTASCII_USTRINGPARAM( "ScreenArea" ) ) ) >>= aRect ) 908cdf0e10cSrcweir { 909cdf0e10cSrcweir nScreenX = aRect.X; 910cdf0e10cSrcweir nScreenY = aRect.Y; 911cdf0e10cSrcweir nScreenDX = aRect.Width+1; // difference between java/awt convention and vcl 912cdf0e10cSrcweir nScreenDY = aRect.Height+1; // difference between java/awt convention and vcl 913cdf0e10cSrcweir } 914cdf0e10cSrcweir } 915cdf0e10cSrcweir else 916cdf0e10cSrcweir { 917cdf0e10cSrcweir Rectangle aCombined; 918cdf0e10cSrcweir uno::Reference< XPropertySet > xMonitor( xMultiMon->getByIndex( 0 ), UNO_QUERY_THROW ); 919cdf0e10cSrcweir com::sun::star::awt::Rectangle aRect; 920cdf0e10cSrcweir if( xMonitor->getPropertyValue( OUString( RTL_CONSTASCII_USTRINGPARAM( "ScreenArea" ) ) ) >>= aRect ) 921cdf0e10cSrcweir { 922cdf0e10cSrcweir aCombined.Left() = aRect.X; 923cdf0e10cSrcweir aCombined.Top() = aRect.Y; 924cdf0e10cSrcweir aCombined.Right() = aRect.X + aRect.Width; 925cdf0e10cSrcweir aCombined.Bottom() = aRect.Y + aRect.Height; 926cdf0e10cSrcweir for( sal_Int32 i = 1 ; i < nMonitors ; i++ ) 927cdf0e10cSrcweir { 928cdf0e10cSrcweir xMonitor = uno::Reference< XPropertySet >( xMultiMon->getByIndex(i), UNO_QUERY_THROW ); 929cdf0e10cSrcweir if( xMonitor->getPropertyValue( OUString( RTL_CONSTASCII_USTRINGPARAM( "ScreenArea" ) ) ) >>= aRect ) 930cdf0e10cSrcweir { 931cdf0e10cSrcweir aCombined.Union( Rectangle( aRect.X, aRect.Y, aRect.X+aRect.Width, aRect.Y+aRect.Height ) ); 932cdf0e10cSrcweir } 933cdf0e10cSrcweir } 934cdf0e10cSrcweir } 935cdf0e10cSrcweir nScreenX = aCombined.Left(); 936cdf0e10cSrcweir nScreenY = aCombined.Top(); 937cdf0e10cSrcweir nScreenDX = aCombined.GetWidth(); 938cdf0e10cSrcweir nScreenDY = aCombined.GetHeight(); 939cdf0e10cSrcweir } 940cdf0e10cSrcweir } 941cdf0e10cSrcweir catch( Exception& ) 942cdf0e10cSrcweir { 943cdf0e10cSrcweir } 944cdf0e10cSrcweir 945cdf0e10cSrcweir if( !nScreenDX || !nScreenDY ) 946cdf0e10cSrcweir { 947cdf0e10cSrcweir nScreenDX = GetSystemMetrics( SM_CXSCREEN ); 948cdf0e10cSrcweir nScreenDY = GetSystemMetrics( SM_CYSCREEN ); 949cdf0e10cSrcweir } 950cdf0e10cSrcweir 951cdf0e10cSrcweir rX = nScreenX -nFrameX; 952cdf0e10cSrcweir rY = nScreenY -(nFrameY+nCaptionY); 953cdf0e10cSrcweir rDX = nScreenDX+(nFrameX*2); 954cdf0e10cSrcweir rDY = nScreenDY+(nFrameY*2)+nCaptionY; 955cdf0e10cSrcweir } 956cdf0e10cSrcweir 957cdf0e10cSrcweir // ----------------------------------------------------------------------- 958cdf0e10cSrcweir 959cdf0e10cSrcweir static void ImplSalFrameFullScreenPos( WinSalFrame* pFrame, sal_Bool bAlways = FALSE ) 960cdf0e10cSrcweir { 961cdf0e10cSrcweir if ( bAlways || !IsIconic( pFrame->mhWnd ) ) 962cdf0e10cSrcweir { 963cdf0e10cSrcweir // set window to screen size 964cdf0e10cSrcweir int nX; 965cdf0e10cSrcweir int nY; 966cdf0e10cSrcweir int nWidth; 967cdf0e10cSrcweir int nHeight; 968cdf0e10cSrcweir ImplSalCalcFullScreenSize( pFrame, nX, nY, nWidth, nHeight ); 969cdf0e10cSrcweir SetWindowPos( pFrame->mhWnd, 0, 970cdf0e10cSrcweir nX, nY, nWidth, nHeight, 971cdf0e10cSrcweir SWP_NOZORDER | SWP_NOACTIVATE ); 972cdf0e10cSrcweir } 973cdf0e10cSrcweir } 974cdf0e10cSrcweir 975cdf0e10cSrcweir // ----------------------------------------------------------------------- 976cdf0e10cSrcweir 977cdf0e10cSrcweir WinSalFrame::WinSalFrame() 978cdf0e10cSrcweir { 979cdf0e10cSrcweir SalData* pSalData = GetSalData(); 980cdf0e10cSrcweir 981cdf0e10cSrcweir mhWnd = 0; 982cdf0e10cSrcweir mhCursor = LoadCursor( 0, IDC_ARROW ); 983cdf0e10cSrcweir mhDefIMEContext = 0; 984cdf0e10cSrcweir mpGraphics = NULL; 985cdf0e10cSrcweir mpGraphics2 = NULL; 986cdf0e10cSrcweir mnShowState = SW_SHOWNORMAL; 987cdf0e10cSrcweir mnWidth = 0; 988cdf0e10cSrcweir mnHeight = 0; 989cdf0e10cSrcweir mnMinWidth = 0; 990cdf0e10cSrcweir mnMinHeight = 0; 991cdf0e10cSrcweir mnMaxWidth = SHRT_MAX; 992cdf0e10cSrcweir mnMaxHeight = SHRT_MAX; 993cdf0e10cSrcweir mnInputLang = 0; 994cdf0e10cSrcweir mnInputCodePage = 0; 995cdf0e10cSrcweir mbGraphics = FALSE; 996cdf0e10cSrcweir mbCaption = FALSE; 997cdf0e10cSrcweir mbBorder = FALSE; 998cdf0e10cSrcweir mbFixBorder = FALSE; 999cdf0e10cSrcweir mbSizeBorder = FALSE; 1000cdf0e10cSrcweir mbFullScreen = FALSE; 1001cdf0e10cSrcweir mbPresentation = FALSE; 1002cdf0e10cSrcweir mbInShow = FALSE; 1003cdf0e10cSrcweir mbRestoreMaximize = FALSE; 1004cdf0e10cSrcweir mbInMoveMsg = FALSE; 1005cdf0e10cSrcweir mbInSizeMsg = FALSE; 1006cdf0e10cSrcweir mbFullScreenToolWin = FALSE; 1007cdf0e10cSrcweir mbDefPos = TRUE; 1008cdf0e10cSrcweir mbOverwriteState = TRUE; 1009cdf0e10cSrcweir mbIME = FALSE; 1010cdf0e10cSrcweir mbHandleIME = FALSE; 1011cdf0e10cSrcweir mbSpezIME = FALSE; 1012cdf0e10cSrcweir mbAtCursorIME = FALSE; 1013cdf0e10cSrcweir mbCandidateMode = FALSE; 1014cdf0e10cSrcweir mbFloatWin = FALSE; 1015cdf0e10cSrcweir mbNoIcon = FALSE; 1016cdf0e10cSrcweir mSelectedhMenu = 0; 1017cdf0e10cSrcweir mLastActivatedhMenu = 0; 1018cdf0e10cSrcweir mpClipRgnData = NULL; 1019cdf0e10cSrcweir mbFirstClipRect = TRUE; 1020cdf0e10cSrcweir mpNextClipRect = NULL; 1021cdf0e10cSrcweir mnDisplay = 0; 1022cdf0e10cSrcweir 1023cdf0e10cSrcweir memset( &maState, 0, sizeof( SalFrameState ) ); 1024cdf0e10cSrcweir maSysData.nSize = sizeof( SystemEnvData ); 1025cdf0e10cSrcweir 1026cdf0e10cSrcweir memset( &maGeometry, 0, sizeof( maGeometry ) ); 1027cdf0e10cSrcweir 1028cdf0e10cSrcweir // Daten ermitteln, wenn erster Frame angelegt wird 1029cdf0e10cSrcweir if ( !pSalData->mpFirstFrame ) 1030cdf0e10cSrcweir { 1031cdf0e10cSrcweir if ( !aSalShlData.mnWheelMsgId ) 1032cdf0e10cSrcweir aSalShlData.mnWheelMsgId = RegisterWindowMessage( MSH_MOUSEWHEEL ); 1033cdf0e10cSrcweir if ( !aSalShlData.mnWheelScrollLines ) 1034cdf0e10cSrcweir aSalShlData.mnWheelScrollLines = ImplSalGetWheelScrollLines(); 1035cdf0e10cSrcweir if ( !aSalShlData.mnWheelScrollChars ) 1036cdf0e10cSrcweir aSalShlData.mnWheelScrollChars = ImplSalGetWheelScrollChars(); 1037cdf0e10cSrcweir } 1038cdf0e10cSrcweir 1039cdf0e10cSrcweir // insert frame in framelist 1040cdf0e10cSrcweir mpNextFrame = pSalData->mpFirstFrame; 1041cdf0e10cSrcweir pSalData->mpFirstFrame = this; 1042cdf0e10cSrcweir } 1043cdf0e10cSrcweir 1044cdf0e10cSrcweir // ----------------------------------------------------------------------- 1045cdf0e10cSrcweir void WinSalFrame::updateScreenNumber() 1046cdf0e10cSrcweir { 1047cdf0e10cSrcweir if( mnDisplay == -1 ) // spans all monitors 1048cdf0e10cSrcweir return; 1049cdf0e10cSrcweir WinSalSystem* pSys = static_cast<WinSalSystem*>(ImplGetSalSystem()); 1050cdf0e10cSrcweir if( pSys ) 1051cdf0e10cSrcweir { 1052cdf0e10cSrcweir const std::vector<WinSalSystem::DisplayMonitor>& rMonitors = 1053cdf0e10cSrcweir pSys->getMonitors(); 1054cdf0e10cSrcweir Point aPoint( maGeometry.nX, maGeometry.nY ); 1055cdf0e10cSrcweir size_t nMon = rMonitors.size(); 1056cdf0e10cSrcweir for( size_t i = 0; i < nMon; i++ ) 1057cdf0e10cSrcweir { 1058cdf0e10cSrcweir if( rMonitors[i].m_aArea.IsInside( aPoint ) ) 1059cdf0e10cSrcweir { 1060cdf0e10cSrcweir mnDisplay = static_cast<sal_Int32>(i); 1061cdf0e10cSrcweir maGeometry.nScreenNumber = static_cast<unsigned int>(i); 1062cdf0e10cSrcweir } 1063cdf0e10cSrcweir } 1064cdf0e10cSrcweir } 1065cdf0e10cSrcweir } 1066cdf0e10cSrcweir 1067cdf0e10cSrcweir // ----------------------------------------------------------------------- 1068cdf0e10cSrcweir 1069cdf0e10cSrcweir WinSalFrame::~WinSalFrame() 1070cdf0e10cSrcweir { 1071cdf0e10cSrcweir SalData* pSalData = GetSalData(); 1072cdf0e10cSrcweir 1073cdf0e10cSrcweir if( mpClipRgnData ) 1074cdf0e10cSrcweir delete [] (BYTE*)mpClipRgnData; 1075cdf0e10cSrcweir 1076cdf0e10cSrcweir // remove frame from framelist 1077cdf0e10cSrcweir WinSalFrame** ppFrame = &pSalData->mpFirstFrame; 1078cdf0e10cSrcweir for(; (*ppFrame != this) && *ppFrame; ppFrame = &(*ppFrame)->mpNextFrame ); 1079cdf0e10cSrcweir if( *ppFrame ) 1080cdf0e10cSrcweir *ppFrame = mpNextFrame; 1081cdf0e10cSrcweir mpNextFrame = NULL; 1082cdf0e10cSrcweir 1083cdf0e10cSrcweir // Release Cache DC 1084cdf0e10cSrcweir if ( mpGraphics2 && 10855f27b83cSArmin Le Grand mpGraphics2->getHDC() ) 1086cdf0e10cSrcweir ReleaseGraphics( mpGraphics2 ); 1087cdf0e10cSrcweir 1088cdf0e10cSrcweir // destroy saved DC 1089cdf0e10cSrcweir if ( mpGraphics ) 1090cdf0e10cSrcweir { 1091cdf0e10cSrcweir if ( mpGraphics->mhDefPal ) 10925f27b83cSArmin Le Grand SelectPalette( mpGraphics->getHDC(), mpGraphics->mhDefPal, TRUE ); 1093cdf0e10cSrcweir ImplSalDeInitGraphics( mpGraphics ); 10945f27b83cSArmin Le Grand ReleaseDC( mhWnd, mpGraphics->getHDC() ); 1095cdf0e10cSrcweir delete mpGraphics; 1096cdf0e10cSrcweir mpGraphics = NULL; 1097cdf0e10cSrcweir } 1098cdf0e10cSrcweir 1099cdf0e10cSrcweir if ( mhWnd ) 1100cdf0e10cSrcweir { 1101cdf0e10cSrcweir // reset mouse leave data 1102cdf0e10cSrcweir if ( pSalData->mhWantLeaveMsg == mhWnd ) 1103cdf0e10cSrcweir { 1104cdf0e10cSrcweir pSalData->mhWantLeaveMsg = 0; 1105cdf0e10cSrcweir if ( pSalData->mpMouseLeaveTimer ) 1106cdf0e10cSrcweir { 1107cdf0e10cSrcweir delete pSalData->mpMouseLeaveTimer; 1108cdf0e10cSrcweir pSalData->mpMouseLeaveTimer = NULL; 1109cdf0e10cSrcweir } 1110cdf0e10cSrcweir } 1111cdf0e10cSrcweir 1112cdf0e10cSrcweir // destroy system frame 1113cdf0e10cSrcweir if ( !DestroyWindow( mhWnd ) ) 1114cdf0e10cSrcweir SetWindowPtr( mhWnd, 0 ); 1115cdf0e10cSrcweir 1116cdf0e10cSrcweir mhWnd = 0; 1117cdf0e10cSrcweir } 1118cdf0e10cSrcweir } 1119cdf0e10cSrcweir 1120cdf0e10cSrcweir // ----------------------------------------------------------------------- 1121cdf0e10cSrcweir 1122cdf0e10cSrcweir SalGraphics* WinSalFrame::GetGraphics() 1123cdf0e10cSrcweir { 1124cdf0e10cSrcweir if ( mbGraphics ) 1125cdf0e10cSrcweir return NULL; 1126cdf0e10cSrcweir 1127cdf0e10cSrcweir // Other threads get an own DC, because Windows modify in the 1128cdf0e10cSrcweir // other case our DC (changing clip region), when they send a 1129cdf0e10cSrcweir // WM_ERASEBACKGROUND message 1130cdf0e10cSrcweir SalData* pSalData = GetSalData(); 1131cdf0e10cSrcweir if ( pSalData->mnAppThreadId != GetCurrentThreadId() ) 1132cdf0e10cSrcweir { 1133cdf0e10cSrcweir // We use only three CacheDC's for all threads, because W9x is limited 1134cdf0e10cSrcweir // to max. 5 Cache DC's per thread 1135cdf0e10cSrcweir if ( pSalData->mnCacheDCInUse >= 3 ) 1136cdf0e10cSrcweir return NULL; 1137cdf0e10cSrcweir 1138cdf0e10cSrcweir if ( !mpGraphics2 ) 1139cdf0e10cSrcweir { 1140cdf0e10cSrcweir mpGraphics2 = new WinSalGraphics; 11415f27b83cSArmin Le Grand mpGraphics2->setHDC(0); 1142cdf0e10cSrcweir mpGraphics2->mhWnd = mhWnd; 1143cdf0e10cSrcweir mpGraphics2->mbPrinter = FALSE; 1144cdf0e10cSrcweir mpGraphics2->mbVirDev = FALSE; 1145cdf0e10cSrcweir mpGraphics2->mbWindow = TRUE; 1146cdf0e10cSrcweir mpGraphics2->mbScreen = TRUE; 1147cdf0e10cSrcweir } 1148cdf0e10cSrcweir 1149cdf0e10cSrcweir HDC hDC = (HDC)ImplSendMessage( pSalData->mpFirstInstance->mhComWnd, 1150cdf0e10cSrcweir SAL_MSG_GETDC, 1151cdf0e10cSrcweir (WPARAM)mhWnd, 0 ); 1152cdf0e10cSrcweir if ( hDC ) 1153cdf0e10cSrcweir { 11545f27b83cSArmin Le Grand mpGraphics2->setHDC(hDC); 1155cdf0e10cSrcweir if ( pSalData->mhDitherPal ) 1156cdf0e10cSrcweir { 1157cdf0e10cSrcweir mpGraphics2->mhDefPal = SelectPalette( hDC, pSalData->mhDitherPal, TRUE ); 1158cdf0e10cSrcweir RealizePalette( hDC ); 1159cdf0e10cSrcweir } 1160cdf0e10cSrcweir ImplSalInitGraphics( mpGraphics2 ); 1161cdf0e10cSrcweir mbGraphics = TRUE; 1162cdf0e10cSrcweir 1163cdf0e10cSrcweir pSalData->mnCacheDCInUse++; 1164cdf0e10cSrcweir return mpGraphics2; 1165cdf0e10cSrcweir } 1166cdf0e10cSrcweir else 1167cdf0e10cSrcweir return NULL; 1168cdf0e10cSrcweir } 1169cdf0e10cSrcweir else 1170cdf0e10cSrcweir { 1171cdf0e10cSrcweir if ( !mpGraphics ) 1172cdf0e10cSrcweir { 1173cdf0e10cSrcweir HDC hDC = GetDC( mhWnd ); 1174cdf0e10cSrcweir if ( hDC ) 1175cdf0e10cSrcweir { 1176cdf0e10cSrcweir mpGraphics = new WinSalGraphics; 11775f27b83cSArmin Le Grand mpGraphics->setHDC(hDC); 1178cdf0e10cSrcweir mpGraphics->mhWnd = mhWnd; 1179cdf0e10cSrcweir mpGraphics->mbPrinter = FALSE; 1180cdf0e10cSrcweir mpGraphics->mbVirDev = FALSE; 1181cdf0e10cSrcweir mpGraphics->mbWindow = TRUE; 1182cdf0e10cSrcweir mpGraphics->mbScreen = TRUE; 1183cdf0e10cSrcweir if ( pSalData->mhDitherPal ) 1184cdf0e10cSrcweir { 1185cdf0e10cSrcweir mpGraphics->mhDefPal = SelectPalette( hDC, pSalData->mhDitherPal, TRUE ); 1186cdf0e10cSrcweir RealizePalette( hDC ); 1187cdf0e10cSrcweir } 1188cdf0e10cSrcweir ImplSalInitGraphics( mpGraphics ); 1189cdf0e10cSrcweir mbGraphics = TRUE; 1190cdf0e10cSrcweir } 1191cdf0e10cSrcweir } 1192cdf0e10cSrcweir else 1193cdf0e10cSrcweir mbGraphics = TRUE; 1194cdf0e10cSrcweir 1195cdf0e10cSrcweir return mpGraphics; 1196cdf0e10cSrcweir } 1197cdf0e10cSrcweir } 1198cdf0e10cSrcweir 1199cdf0e10cSrcweir // ----------------------------------------------------------------------- 1200cdf0e10cSrcweir 1201cdf0e10cSrcweir void WinSalFrame::ReleaseGraphics( SalGraphics* pGraphics ) 1202cdf0e10cSrcweir { 1203cdf0e10cSrcweir if ( mpGraphics2 == pGraphics ) 1204cdf0e10cSrcweir { 12055f27b83cSArmin Le Grand if ( mpGraphics2->getHDC() ) 1206cdf0e10cSrcweir { 1207cdf0e10cSrcweir SalData* pSalData = GetSalData(); 1208cdf0e10cSrcweir if ( mpGraphics2->mhDefPal ) 12095f27b83cSArmin Le Grand SelectPalette( mpGraphics2->getHDC(), mpGraphics2->mhDefPal, TRUE ); 1210cdf0e10cSrcweir ImplSalDeInitGraphics( mpGraphics2 ); 1211cdf0e10cSrcweir ImplSendMessage( pSalData->mpFirstInstance->mhComWnd, 1212cdf0e10cSrcweir SAL_MSG_RELEASEDC, 1213cdf0e10cSrcweir (WPARAM)mhWnd, 12145f27b83cSArmin Le Grand (LPARAM)mpGraphics2->getHDC() ); 12155f27b83cSArmin Le Grand mpGraphics2->setHDC(0); 1216cdf0e10cSrcweir pSalData->mnCacheDCInUse--; 1217cdf0e10cSrcweir } 1218cdf0e10cSrcweir } 1219cdf0e10cSrcweir 1220cdf0e10cSrcweir mbGraphics = FALSE; 1221cdf0e10cSrcweir } 1222cdf0e10cSrcweir 1223cdf0e10cSrcweir // ----------------------------------------------------------------------- 1224cdf0e10cSrcweir 1225cdf0e10cSrcweir sal_Bool WinSalFrame::PostEvent( void* pData ) 1226cdf0e10cSrcweir { 1227cdf0e10cSrcweir return (sal_Bool)ImplPostMessage( mhWnd, SAL_MSG_USEREVENT, 0, (LPARAM)pData ); 1228cdf0e10cSrcweir } 1229cdf0e10cSrcweir 1230cdf0e10cSrcweir // ----------------------------------------------------------------------- 1231cdf0e10cSrcweir 1232cdf0e10cSrcweir void WinSalFrame::SetTitle( const XubString& rTitle ) 1233cdf0e10cSrcweir { 1234cdf0e10cSrcweir DBG_ASSERT( sizeof( WCHAR ) == sizeof( xub_Unicode ), "WinSalFrame::SetTitle(): WCHAR != sal_Unicode" ); 1235cdf0e10cSrcweir 1236cdf0e10cSrcweir if ( !SetWindowTextW( mhWnd, reinterpret_cast<LPCWSTR>(rTitle.GetBuffer()) ) ) 1237cdf0e10cSrcweir { 1238cdf0e10cSrcweir ByteString aAnsiTitle = ImplSalGetWinAnsiString( rTitle ); 1239cdf0e10cSrcweir SetWindowTextA( mhWnd, aAnsiTitle.GetBuffer() ); 1240cdf0e10cSrcweir } 1241cdf0e10cSrcweir } 1242cdf0e10cSrcweir 1243cdf0e10cSrcweir // ----------------------------------------------------------------------- 1244cdf0e10cSrcweir 1245cdf0e10cSrcweir void WinSalFrame::SetIcon( sal_uInt16 nIcon ) 1246cdf0e10cSrcweir { 1247cdf0e10cSrcweir // If we have a window without an Icon (for example a dialog), ignore this call 1248cdf0e10cSrcweir if ( mbNoIcon ) 1249cdf0e10cSrcweir return; 1250cdf0e10cSrcweir 1251cdf0e10cSrcweir // 0 means default (class) icon 1252cdf0e10cSrcweir HICON hIcon = NULL, hSmIcon = NULL; 1253cdf0e10cSrcweir if ( !nIcon ) 1254cdf0e10cSrcweir nIcon = 1; 1255cdf0e10cSrcweir 1256cdf0e10cSrcweir ImplLoadSalIcon( nIcon, hIcon, hSmIcon ); 1257cdf0e10cSrcweir 1258cdf0e10cSrcweir DBG_ASSERT( hIcon , "WinSalFrame::SetIcon(): Could not load large icon !" ); 1259cdf0e10cSrcweir DBG_ASSERT( hSmIcon , "WinSalFrame::SetIcon(): Could not load small icon !" ); 1260cdf0e10cSrcweir 1261cdf0e10cSrcweir ImplSendMessage( mhWnd, WM_SETICON, ICON_BIG, (LPARAM)hIcon ); 1262cdf0e10cSrcweir ImplSendMessage( mhWnd, WM_SETICON, ICON_SMALL, (LPARAM)hSmIcon ); 1263cdf0e10cSrcweir } 1264cdf0e10cSrcweir 1265cdf0e10cSrcweir // ----------------------------------------------------------------------- 1266cdf0e10cSrcweir 1267cdf0e10cSrcweir void WinSalFrame::SetMenu( SalMenu* pSalMenu ) 1268cdf0e10cSrcweir { 1269cdf0e10cSrcweir WinSalMenu* pWMenu = static_cast<WinSalMenu*>(pSalMenu); 1270cdf0e10cSrcweir if( pSalMenu && pWMenu->mbMenuBar ) 1271cdf0e10cSrcweir ::SetMenu( mhWnd, pWMenu->mhMenu ); 1272cdf0e10cSrcweir } 1273cdf0e10cSrcweir 1274cdf0e10cSrcweir void WinSalFrame::DrawMenuBar() 1275cdf0e10cSrcweir { 1276cdf0e10cSrcweir ::DrawMenuBar( mhWnd ); 1277cdf0e10cSrcweir } 1278cdf0e10cSrcweir 1279cdf0e10cSrcweir // ----------------------------------------------------------------------- 1280cdf0e10cSrcweir HWND ImplGetParentHwnd( HWND hWnd ) 1281cdf0e10cSrcweir { 1282cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 1283cdf0e10cSrcweir if( !pFrame || !pFrame->GetWindow()) 1284cdf0e10cSrcweir return ::GetParent( hWnd ); 1285cdf0e10cSrcweir Window *pRealParent = pFrame->GetWindow()->ImplGetWindowImpl()->mpRealParent; 1286cdf0e10cSrcweir if( pRealParent ) 1287cdf0e10cSrcweir return static_cast<WinSalFrame*>(pRealParent->ImplGetWindowImpl()->mpFrame)->mhWnd; 1288cdf0e10cSrcweir else 1289cdf0e10cSrcweir return ::GetParent( hWnd ); 1290cdf0e10cSrcweir 1291cdf0e10cSrcweir } 1292cdf0e10cSrcweir 1293cdf0e10cSrcweir // ----------------------------------------------------------------------- 1294cdf0e10cSrcweir 1295cdf0e10cSrcweir SalFrame* WinSalFrame::GetParent() const 1296cdf0e10cSrcweir { 1297cdf0e10cSrcweir return GetWindowPtr( ImplGetParentHwnd( mhWnd ) ); 1298cdf0e10cSrcweir } 1299cdf0e10cSrcweir 1300cdf0e10cSrcweir // ----------------------------------------------------------------------- 1301cdf0e10cSrcweir 1302cdf0e10cSrcweir static void ImplSalShow( HWND hWnd, sal_Bool bVisible, sal_Bool bNoActivate ) 1303cdf0e10cSrcweir { 1304cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 1305cdf0e10cSrcweir if ( !pFrame ) 1306cdf0e10cSrcweir return; 1307cdf0e10cSrcweir 1308cdf0e10cSrcweir if ( bVisible ) 1309cdf0e10cSrcweir { 1310cdf0e10cSrcweir pFrame->mbDefPos = FALSE; 1311cdf0e10cSrcweir pFrame->mbOverwriteState = TRUE; 1312cdf0e10cSrcweir pFrame->mbInShow = TRUE; 1313cdf0e10cSrcweir 1314cdf0e10cSrcweir // #i4715, save position 1315cdf0e10cSrcweir RECT aRectPreMatrox, aRectPostMatrox; 1316cdf0e10cSrcweir GetWindowRect( hWnd, &aRectPreMatrox ); 1317cdf0e10cSrcweir 1318cdf0e10cSrcweir vcl::DeletionListener aDogTag( pFrame ); 1319cdf0e10cSrcweir if( bNoActivate ) 1320cdf0e10cSrcweir ShowWindow( hWnd, SW_SHOWNOACTIVATE ); 1321cdf0e10cSrcweir else 1322cdf0e10cSrcweir ShowWindow( hWnd, pFrame->mnShowState ); 1323cdf0e10cSrcweir if( aDogTag.isDeleted() ) 1324cdf0e10cSrcweir return; 1325cdf0e10cSrcweir 1326cdf0e10cSrcweir if ( aSalShlData.mbWXP && pFrame->mbFloatWin && !(pFrame->mnStyle & SAL_FRAME_STYLE_NOSHADOW)) 1327cdf0e10cSrcweir { 1328cdf0e10cSrcweir // erase the window immediately to improve XP shadow effect 1329cdf0e10cSrcweir // otherwise the shadow may appears long time before the rest of the window 1330cdf0e10cSrcweir // especially when accessibility is on 1331cdf0e10cSrcweir HDC dc = GetDC( hWnd ); 1332cdf0e10cSrcweir RECT aRect; 1333cdf0e10cSrcweir GetClientRect( hWnd, &aRect ); 1334cdf0e10cSrcweir FillRect( dc, &aRect, (HBRUSH) (COLOR_MENU+1) ); // choose the menucolor, because its mostly noticeable for menues 1335cdf0e10cSrcweir ReleaseDC( hWnd, dc ); 1336cdf0e10cSrcweir } 1337cdf0e10cSrcweir 1338cdf0e10cSrcweir // #i4715, matrox centerpopup might have changed our position 1339cdf0e10cSrcweir // reposition popups without caption (menues, dropdowns, tooltips) 1340cdf0e10cSrcweir GetWindowRect( hWnd, &aRectPostMatrox ); 1341cdf0e10cSrcweir if( (GetWindowStyle( hWnd ) & WS_POPUP) && 1342cdf0e10cSrcweir !pFrame->mbCaption && 1343cdf0e10cSrcweir (aRectPreMatrox.left != aRectPostMatrox.left || aRectPreMatrox.top != aRectPostMatrox.top) ) 1344cdf0e10cSrcweir SetWindowPos( hWnd, 0, aRectPreMatrox.left, aRectPreMatrox.top, 0, 0, SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOSIZE ); 1345cdf0e10cSrcweir 1346cdf0e10cSrcweir if( aDogTag.isDeleted() ) 1347cdf0e10cSrcweir return; 1348cdf0e10cSrcweir Window *pClientWin = pFrame->GetWindow()->ImplGetClientWindow(); 1349cdf0e10cSrcweir if ( pFrame->mbFloatWin || ( pClientWin && (pClientWin->GetStyle() & WB_SYSTEMFLOATWIN) ) ) 1350cdf0e10cSrcweir pFrame->mnShowState = SW_SHOWNOACTIVATE; 1351cdf0e10cSrcweir else 1352cdf0e10cSrcweir pFrame->mnShowState = SW_SHOW; 1353cdf0e10cSrcweir // Damit Taskleiste unter W98 auch gleich ausgeblendet wird 1354cdf0e10cSrcweir if ( pFrame->mbPresentation ) 1355cdf0e10cSrcweir { 1356cdf0e10cSrcweir HWND hWndParent = ::GetParent( hWnd ); 1357cdf0e10cSrcweir if ( hWndParent ) 1358cdf0e10cSrcweir SetForegroundWindow( hWndParent ); 1359cdf0e10cSrcweir SetForegroundWindow( hWnd ); 1360cdf0e10cSrcweir } 1361cdf0e10cSrcweir 1362cdf0e10cSrcweir pFrame->mbInShow = FALSE; 1363cdf0e10cSrcweir pFrame->updateScreenNumber(); 1364cdf0e10cSrcweir 1365cdf0e10cSrcweir // Direct Paint only, if we get the SolarMutx 1366cdf0e10cSrcweir if ( ImplSalYieldMutexTryToAcquire() ) 1367cdf0e10cSrcweir { 1368cdf0e10cSrcweir UpdateWindow( hWnd ); 1369cdf0e10cSrcweir ImplSalYieldMutexRelease(); 1370cdf0e10cSrcweir } 1371cdf0e10cSrcweir } 1372cdf0e10cSrcweir else 1373cdf0e10cSrcweir { 1374cdf0e10cSrcweir // See also Bug #91813# and #68467# 1375cdf0e10cSrcweir if ( pFrame->mbFullScreen && 1376cdf0e10cSrcweir pFrame->mbPresentation && 1377cdf0e10cSrcweir (aSalShlData.mnVersion < 500) && 1378cdf0e10cSrcweir !::GetParent( hWnd ) ) 1379cdf0e10cSrcweir { 1380cdf0e10cSrcweir // Damit im Impress-Player in der Taskleiste nicht durch 1381cdf0e10cSrcweir // einen Windows-Fehler hin- und wieder mal ein leerer 1382cdf0e10cSrcweir // Button stehen bleibt, muessen wir hier die Taskleiste 1383cdf0e10cSrcweir // etwas austricksen. Denn wenn wir im FullScreenMode sind 1384cdf0e10cSrcweir // und das Fenster hiden kommt Windows anscheinend etwas aus 1385cdf0e10cSrcweir // dem tritt und somit minimieren wir das Fenster damit es 1386cdf0e10cSrcweir // nicht flackert 1387cdf0e10cSrcweir ANIMATIONINFO aInfo; 1388cdf0e10cSrcweir aInfo.cbSize = sizeof( aInfo ); 1389cdf0e10cSrcweir SystemParametersInfo( SPI_GETANIMATION, 0, &aInfo, 0 ); 1390cdf0e10cSrcweir if ( aInfo.iMinAnimate ) 1391cdf0e10cSrcweir { 1392cdf0e10cSrcweir int nOldAni = aInfo.iMinAnimate; 1393cdf0e10cSrcweir aInfo.iMinAnimate = 0; 1394cdf0e10cSrcweir SystemParametersInfo( SPI_SETANIMATION, 0, &aInfo, 0 ); 1395cdf0e10cSrcweir ShowWindow( pFrame->mhWnd, SW_SHOWMINNOACTIVE ); 1396cdf0e10cSrcweir aInfo.iMinAnimate = nOldAni; 1397cdf0e10cSrcweir SystemParametersInfo( SPI_SETANIMATION, 0, &aInfo, 0 ); 1398cdf0e10cSrcweir } 1399cdf0e10cSrcweir else 1400cdf0e10cSrcweir ShowWindow( hWnd, SW_SHOWMINNOACTIVE ); 1401cdf0e10cSrcweir ShowWindow( hWnd, SW_HIDE ); 1402cdf0e10cSrcweir } 1403cdf0e10cSrcweir else 1404cdf0e10cSrcweir ShowWindow( hWnd, SW_HIDE ); 1405cdf0e10cSrcweir } 1406cdf0e10cSrcweir } 1407cdf0e10cSrcweir 1408cdf0e10cSrcweir // ----------------------------------------------------------------------- 1409cdf0e10cSrcweir 1410cdf0e10cSrcweir 1411cdf0e10cSrcweir void WinSalFrame::SetExtendedFrameStyle( SalExtStyle ) 1412cdf0e10cSrcweir { 1413cdf0e10cSrcweir } 1414cdf0e10cSrcweir 1415cdf0e10cSrcweir // ----------------------------------------------------------------------- 1416cdf0e10cSrcweir 1417cdf0e10cSrcweir void WinSalFrame::Show( sal_Bool bVisible, sal_Bool bNoActivate ) 1418cdf0e10cSrcweir { 1419cdf0e10cSrcweir // Post this Message to the window, because this only works 1420cdf0e10cSrcweir // in the thread of the window, which has create this window. 1421cdf0e10cSrcweir // We post this message to avoid deadlocks 1422cdf0e10cSrcweir if ( GetSalData()->mnAppThreadId != GetCurrentThreadId() ) 1423cdf0e10cSrcweir ImplPostMessage( mhWnd, SAL_MSG_SHOW, bVisible, bNoActivate ); 1424cdf0e10cSrcweir else 1425cdf0e10cSrcweir ImplSalShow( mhWnd, bVisible, bNoActivate ); 1426cdf0e10cSrcweir } 1427cdf0e10cSrcweir 1428cdf0e10cSrcweir // ----------------------------------------------------------------------- 1429cdf0e10cSrcweir 1430cdf0e10cSrcweir void WinSalFrame::Enable( sal_Bool bEnable ) 1431cdf0e10cSrcweir { 1432cdf0e10cSrcweir EnableWindow( mhWnd, bEnable ); 1433cdf0e10cSrcweir } 1434cdf0e10cSrcweir 1435cdf0e10cSrcweir // ----------------------------------------------------------------------- 1436cdf0e10cSrcweir 1437cdf0e10cSrcweir void WinSalFrame::SetMinClientSize( long nWidth, long nHeight ) 1438cdf0e10cSrcweir { 1439cdf0e10cSrcweir mnMinWidth = nWidth; 1440cdf0e10cSrcweir mnMinHeight = nHeight; 1441cdf0e10cSrcweir } 1442cdf0e10cSrcweir 1443cdf0e10cSrcweir void WinSalFrame::SetMaxClientSize( long nWidth, long nHeight ) 1444cdf0e10cSrcweir { 1445cdf0e10cSrcweir mnMaxWidth = nWidth; 1446cdf0e10cSrcweir mnMaxHeight = nHeight; 1447cdf0e10cSrcweir } 1448cdf0e10cSrcweir 1449cdf0e10cSrcweir // ----------------------------------------------------------------------- 1450cdf0e10cSrcweir 1451cdf0e10cSrcweir void WinSalFrame::SetPosSize( long nX, long nY, long nWidth, long nHeight, 1452cdf0e10cSrcweir sal_uInt16 nFlags ) 1453cdf0e10cSrcweir { 1454cdf0e10cSrcweir sal_Bool bVisible = (GetWindowStyle( mhWnd ) & WS_VISIBLE) != 0; 1455cdf0e10cSrcweir if ( !bVisible ) 1456cdf0e10cSrcweir { 1457cdf0e10cSrcweir Window *pClientWin = GetWindow()->ImplGetClientWindow(); 1458cdf0e10cSrcweir if ( mbFloatWin || ( pClientWin && (pClientWin->GetStyle() & WB_SYSTEMFLOATWIN) ) ) 1459cdf0e10cSrcweir mnShowState = SW_SHOWNOACTIVATE; 1460cdf0e10cSrcweir else 1461cdf0e10cSrcweir mnShowState = SW_SHOWNORMAL; 1462cdf0e10cSrcweir } 1463cdf0e10cSrcweir else 1464cdf0e10cSrcweir { 1465cdf0e10cSrcweir if ( IsIconic( mhWnd ) || IsZoomed( mhWnd ) ) 1466cdf0e10cSrcweir ShowWindow( mhWnd, SW_RESTORE ); 1467cdf0e10cSrcweir } 1468cdf0e10cSrcweir 1469cdf0e10cSrcweir sal_uInt16 nEvent = 0; 1470cdf0e10cSrcweir UINT nPosSize = 0; 1471cdf0e10cSrcweir RECT aClientRect, aWindowRect; 1472cdf0e10cSrcweir GetClientRect( mhWnd, &aClientRect ); // x,y always 0,0, but width and height without border 1473cdf0e10cSrcweir GetWindowRect( mhWnd, &aWindowRect ); // x,y in screen coordinates, width and height with border 1474cdf0e10cSrcweir 1475cdf0e10cSrcweir if ( !(nFlags & (SAL_FRAME_POSSIZE_X | SAL_FRAME_POSSIZE_Y)) ) 1476cdf0e10cSrcweir nPosSize |= SWP_NOMOVE; 1477cdf0e10cSrcweir else 1478cdf0e10cSrcweir { 1479cdf0e10cSrcweir //DBG_ASSERT( nX && nY, " Windowposition of (0,0) requested!" ); 1480cdf0e10cSrcweir nEvent = SALEVENT_MOVE; 1481cdf0e10cSrcweir } 1482cdf0e10cSrcweir if ( !(nFlags & (SAL_FRAME_POSSIZE_WIDTH | SAL_FRAME_POSSIZE_HEIGHT)) ) 1483cdf0e10cSrcweir nPosSize |= SWP_NOSIZE; 1484cdf0e10cSrcweir else 1485cdf0e10cSrcweir nEvent = (nEvent == SALEVENT_MOVE) ? SALEVENT_MOVERESIZE : SALEVENT_RESIZE; 1486cdf0e10cSrcweir 1487cdf0e10cSrcweir if ( !(nFlags & SAL_FRAME_POSSIZE_X) ) 1488cdf0e10cSrcweir nX = aWindowRect.left; 1489cdf0e10cSrcweir if ( !(nFlags & SAL_FRAME_POSSIZE_Y) ) 1490cdf0e10cSrcweir nY = aWindowRect.top; 1491cdf0e10cSrcweir if ( !(nFlags & SAL_FRAME_POSSIZE_WIDTH) ) 1492cdf0e10cSrcweir nWidth = aClientRect.right-aClientRect.left; 1493cdf0e10cSrcweir if ( !(nFlags & SAL_FRAME_POSSIZE_HEIGHT) ) 1494cdf0e10cSrcweir nHeight = aClientRect.bottom-aClientRect.top; 1495cdf0e10cSrcweir 1496cdf0e10cSrcweir // Calculate window size including the border 1497cdf0e10cSrcweir RECT aWinRect; 1498cdf0e10cSrcweir aWinRect.left = 0; 1499cdf0e10cSrcweir aWinRect.right = (int)nWidth-1; 1500cdf0e10cSrcweir aWinRect.top = 0; 1501cdf0e10cSrcweir aWinRect.bottom = (int)nHeight-1; 1502cdf0e10cSrcweir AdjustWindowRectEx( &aWinRect, GetWindowStyle( mhWnd ), 1503cdf0e10cSrcweir FALSE, GetWindowExStyle( mhWnd ) ); 1504cdf0e10cSrcweir nWidth = aWinRect.right - aWinRect.left + 1; 1505cdf0e10cSrcweir nHeight = aWinRect.bottom - aWinRect.top + 1; 1506cdf0e10cSrcweir 1507cdf0e10cSrcweir if ( !(nPosSize & SWP_NOMOVE) && ::GetParent( mhWnd ) ) 1508cdf0e10cSrcweir { 1509cdf0e10cSrcweir // --- RTL --- (mirror window pos) 1510cdf0e10cSrcweir RECT aParentRect; 1511cdf0e10cSrcweir GetClientRect( ImplGetParentHwnd( mhWnd ), &aParentRect ); 1512cdf0e10cSrcweir if( Application::GetSettings().GetLayoutRTL() ) 1513cdf0e10cSrcweir nX = (aParentRect.right - aParentRect.left) - nWidth-1 - nX; 1514cdf0e10cSrcweir 1515cdf0e10cSrcweir //#110386#, do not transform coordinates for system child windows 1516cdf0e10cSrcweir if( !(GetWindowStyle( mhWnd ) & WS_CHILD) ) 1517cdf0e10cSrcweir { 1518cdf0e10cSrcweir POINT aPt; 1519cdf0e10cSrcweir aPt.x = nX; 1520cdf0e10cSrcweir aPt.y = nY; 1521cdf0e10cSrcweir 1522cdf0e10cSrcweir HWND parentHwnd = ImplGetParentHwnd( mhWnd ); 1523cdf0e10cSrcweir WinSalFrame* pParentFrame = GetWindowPtr( parentHwnd ); 1524cdf0e10cSrcweir if ( pParentFrame && pParentFrame->mnShowState == SW_SHOWMAXIMIZED ) 1525cdf0e10cSrcweir { 1526cdf0e10cSrcweir // #i42485#: parent will be shown maximized in which case 1527cdf0e10cSrcweir // a ClientToScreen uses the wrong coordinates (i.e. those from the restore pos) 1528cdf0e10cSrcweir // so use the (already updated) frame geometry for the transformation 1529cdf0e10cSrcweir aPt.x += pParentFrame->maGeometry.nX; 1530cdf0e10cSrcweir aPt.y += pParentFrame->maGeometry.nY; 1531cdf0e10cSrcweir } 1532cdf0e10cSrcweir else 1533cdf0e10cSrcweir ClientToScreen( parentHwnd, &aPt ); 1534cdf0e10cSrcweir 1535cdf0e10cSrcweir nX = aPt.x; 1536cdf0e10cSrcweir nY = aPt.y; 1537cdf0e10cSrcweir } 1538cdf0e10cSrcweir } 1539cdf0e10cSrcweir 1540cdf0e10cSrcweir // #i3338# to be conformant to UNIX we must position the client window, ie without the decoration 1541cdf0e10cSrcweir // #i43250# if the position was read from the system (GetWindowRect(), see above), it must not be modified 1542cdf0e10cSrcweir if ( nFlags & SAL_FRAME_POSSIZE_X ) 1543cdf0e10cSrcweir nX += aWinRect.left; 1544cdf0e10cSrcweir if ( nFlags & SAL_FRAME_POSSIZE_Y ) 1545cdf0e10cSrcweir nY += aWinRect.top; 1546cdf0e10cSrcweir 1547cdf0e10cSrcweir int nScreenX; 1548cdf0e10cSrcweir int nScreenY; 1549cdf0e10cSrcweir int nScreenWidth; 1550cdf0e10cSrcweir int nScreenHeight; 1551cdf0e10cSrcweir 1552cdf0e10cSrcweir 1553cdf0e10cSrcweir RECT aRect; 1554cdf0e10cSrcweir ImplSalGetWorkArea( mhWnd, &aRect, NULL ); 1555cdf0e10cSrcweir nScreenX = aRect.left; 1556cdf0e10cSrcweir nScreenY = aRect.top; 1557cdf0e10cSrcweir nScreenWidth = aRect.right-aRect.left; 1558cdf0e10cSrcweir nScreenHeight = aRect.bottom-aRect.top; 1559cdf0e10cSrcweir 1560cdf0e10cSrcweir if ( mbDefPos && (nPosSize & SWP_NOMOVE)) // we got no positioning request, so choose default position 1561cdf0e10cSrcweir { 1562cdf0e10cSrcweir // center window 1563cdf0e10cSrcweir 1564cdf0e10cSrcweir HWND hWndParent = ::GetParent( mhWnd ); 1565cdf0e10cSrcweir // Search for TopLevel Frame 1566cdf0e10cSrcweir while ( hWndParent && (GetWindowStyle( hWndParent ) & WS_CHILD) ) 1567cdf0e10cSrcweir hWndParent = ::GetParent( hWndParent ); 1568cdf0e10cSrcweir // if the Window has a Parent, than center the window to 1569cdf0e10cSrcweir // the parent, in the other case to the screen 1570cdf0e10cSrcweir if ( hWndParent && !IsIconic( hWndParent ) && 1571cdf0e10cSrcweir (GetWindowStyle( hWndParent ) & WS_VISIBLE) ) 1572cdf0e10cSrcweir { 1573cdf0e10cSrcweir RECT aParentRect; 1574cdf0e10cSrcweir GetWindowRect( hWndParent, &aParentRect ); 1575cdf0e10cSrcweir int nParentWidth = aParentRect.right-aParentRect.left; 1576cdf0e10cSrcweir int nParentHeight = aParentRect.bottom-aParentRect.top; 1577cdf0e10cSrcweir 1578cdf0e10cSrcweir // We don't center, when Parent is smaller than our window 1579cdf0e10cSrcweir if ( (nParentWidth-GetSystemMetrics( SM_CXFIXEDFRAME ) <= nWidth) && 1580cdf0e10cSrcweir (nParentHeight-GetSystemMetrics( SM_CYFIXEDFRAME ) <= nHeight) ) 1581cdf0e10cSrcweir { 1582cdf0e10cSrcweir int nOff = GetSystemMetrics( SM_CYSIZEFRAME ) + GetSystemMetrics( SM_CYCAPTION ); 1583cdf0e10cSrcweir nX = aParentRect.left+nOff; 1584cdf0e10cSrcweir nY = aParentRect.top+nOff; 1585cdf0e10cSrcweir } 1586cdf0e10cSrcweir else 1587cdf0e10cSrcweir { 1588cdf0e10cSrcweir nX = (nParentWidth-nWidth)/2 + aParentRect.left; 1589cdf0e10cSrcweir nY = (nParentHeight-nHeight)/2 + aParentRect.top; 1590cdf0e10cSrcweir } 1591cdf0e10cSrcweir } 1592cdf0e10cSrcweir else 1593cdf0e10cSrcweir { 1594cdf0e10cSrcweir POINT pt; 1595cdf0e10cSrcweir GetCursorPos( &pt ); 1596cdf0e10cSrcweir RECT aRect; 1597cdf0e10cSrcweir aRect.left = pt.x; 1598cdf0e10cSrcweir aRect.top = pt.y; 1599cdf0e10cSrcweir aRect.right = pt.x+2; 1600cdf0e10cSrcweir aRect.bottom = pt.y+2; 1601cdf0e10cSrcweir 1602cdf0e10cSrcweir // dualmonitor support: 1603cdf0e10cSrcweir // Get screensize of the monitor whith the mouse pointer 1604cdf0e10cSrcweir ImplSalGetWorkArea( mhWnd, &aRect, &aRect ); 1605cdf0e10cSrcweir 1606cdf0e10cSrcweir nX = ((aRect.right-aRect.left)-nWidth)/2 + aRect.left; 1607cdf0e10cSrcweir nY = ((aRect.bottom-aRect.top)-nHeight)/2 + aRect.top; 1608cdf0e10cSrcweir } 1609cdf0e10cSrcweir 1610cdf0e10cSrcweir 1611cdf0e10cSrcweir //if ( bVisible ) 1612cdf0e10cSrcweir // mbDefPos = FALSE; 1613cdf0e10cSrcweir 1614cdf0e10cSrcweir mbDefPos = FALSE; // center only once 1615cdf0e10cSrcweir nPosSize &= ~SWP_NOMOVE; // activate positioning 1616cdf0e10cSrcweir nEvent = SALEVENT_MOVERESIZE; 1617cdf0e10cSrcweir } 1618cdf0e10cSrcweir 1619cdf0e10cSrcweir 1620cdf0e10cSrcweir // Adjust Window in the screen 1621cdf0e10cSrcweir sal_Bool bCheckOffScreen = TRUE; 1622cdf0e10cSrcweir 1623cdf0e10cSrcweir // but don't do this for floaters or ownerdraw windows that are currently moved interactively 1624cdf0e10cSrcweir if( (mnStyle & SAL_FRAME_STYLE_FLOAT) && !(mnStyle & SAL_FRAME_STYLE_OWNERDRAWDECORATION) ) 1625cdf0e10cSrcweir bCheckOffScreen = FALSE; 1626cdf0e10cSrcweir 1627cdf0e10cSrcweir if( mnStyle & SAL_FRAME_STYLE_OWNERDRAWDECORATION ) 1628cdf0e10cSrcweir { 1629cdf0e10cSrcweir // may be the window is currently being moved (mouse is captured), then no check is required 1630cdf0e10cSrcweir if( mhWnd == ::GetCapture() ) 1631cdf0e10cSrcweir bCheckOffScreen = FALSE; 1632cdf0e10cSrcweir else 1633cdf0e10cSrcweir bCheckOffScreen = TRUE; 1634cdf0e10cSrcweir } 1635cdf0e10cSrcweir 1636cdf0e10cSrcweir if( bCheckOffScreen ) 1637cdf0e10cSrcweir { 1638cdf0e10cSrcweir if ( nX+nWidth > nScreenX+nScreenWidth ) 1639cdf0e10cSrcweir nX = (nScreenX+nScreenWidth) - nWidth; 1640cdf0e10cSrcweir if ( nY+nHeight > nScreenY+nScreenHeight ) 1641cdf0e10cSrcweir nY = (nScreenY+nScreenHeight) - nHeight; 1642cdf0e10cSrcweir if ( nX < nScreenX ) 1643cdf0e10cSrcweir nX = nScreenX; 1644cdf0e10cSrcweir if ( nY < nScreenY ) 1645cdf0e10cSrcweir nY = nScreenY; 1646cdf0e10cSrcweir } 1647cdf0e10cSrcweir 1648cdf0e10cSrcweir UINT nPosFlags = SWP_NOACTIVATE | SWP_NOOWNERZORDER | nPosSize; 1649cdf0e10cSrcweir // bring floating windows always to top 1650cdf0e10cSrcweir if( !(mnStyle & SAL_FRAME_STYLE_FLOAT) ) 1651cdf0e10cSrcweir nPosFlags |= SWP_NOZORDER; // do not change z-order 1652cdf0e10cSrcweir 1653cdf0e10cSrcweir SetWindowPos( mhWnd, HWND_TOP, nX, nY, (int)nWidth, (int)nHeight, nPosFlags ); 1654cdf0e10cSrcweir 1655cdf0e10cSrcweir UpdateFrameGeometry( mhWnd, this ); 1656cdf0e10cSrcweir 1657cdf0e10cSrcweir // Notification -- really ??? 1658cdf0e10cSrcweir if( nEvent ) 1659cdf0e10cSrcweir CallCallback( nEvent, NULL ); 1660cdf0e10cSrcweir } 1661cdf0e10cSrcweir 1662cdf0e10cSrcweir // ----------------------------------------------------------------------- 1663cdf0e10cSrcweir 1664cdf0e10cSrcweir static void ImplSetParentFrame( WinSalFrame* pThis, HWND hNewParentWnd, sal_Bool bAsChild ) 1665cdf0e10cSrcweir { 1666cdf0e10cSrcweir // save hwnd, will be overwritten in WM_CREATE during createwindow 1667cdf0e10cSrcweir HWND hWndOld = pThis->mhWnd; 1668cdf0e10cSrcweir HWND hWndOldParent = ::GetParent( hWndOld ); 1669cdf0e10cSrcweir SalData* pSalData = GetSalData(); 1670cdf0e10cSrcweir 1671cdf0e10cSrcweir if( hNewParentWnd == hWndOldParent ) 1672cdf0e10cSrcweir return; 1673cdf0e10cSrcweir 1674cdf0e10cSrcweir ::std::vector< WinSalFrame* > children; 1675cdf0e10cSrcweir ::std::vector< WinSalObject* > systemChildren; 1676cdf0e10cSrcweir 1677cdf0e10cSrcweir // search child windows 1678cdf0e10cSrcweir WinSalFrame *pFrame = pSalData->mpFirstFrame; 1679cdf0e10cSrcweir while( pFrame ) 1680cdf0e10cSrcweir { 1681cdf0e10cSrcweir HWND hWndParent = ::GetParent( pFrame->mhWnd ); 1682cdf0e10cSrcweir if( pThis->mhWnd == hWndParent ) 1683cdf0e10cSrcweir children.push_back( pFrame ); 1684cdf0e10cSrcweir pFrame = pFrame->mpNextFrame; 1685cdf0e10cSrcweir } 1686cdf0e10cSrcweir 1687cdf0e10cSrcweir // search system child windows (plugins etc.) 1688cdf0e10cSrcweir WinSalObject *pObject = pSalData->mpFirstObject; 1689cdf0e10cSrcweir while( pObject ) 1690cdf0e10cSrcweir { 1691cdf0e10cSrcweir HWND hWndParent = ::GetParent( pObject->mhWnd ); 1692cdf0e10cSrcweir if( pThis->mhWnd == hWndParent ) 1693cdf0e10cSrcweir systemChildren.push_back( pObject ); 1694cdf0e10cSrcweir pObject = pObject->mpNextObject; 1695cdf0e10cSrcweir } 1696cdf0e10cSrcweir 1697cdf0e10cSrcweir sal_Bool bNeedGraphics = pThis->mbGraphics; 1698cdf0e10cSrcweir sal_Bool bNeedCacheDC = FALSE; 1699cdf0e10cSrcweir 1700cdf0e10cSrcweir HFONT hFont = NULL; 1701cdf0e10cSrcweir HPEN hPen = NULL; 1702cdf0e10cSrcweir HBRUSH hBrush = NULL; 1703cdf0e10cSrcweir 1704cdf0e10cSrcweir #if OSL_DEBUG_LEVEL > 0 1705cdf0e10cSrcweir int oldCount = pSalData->mnCacheDCInUse; 1706cdf0e10cSrcweir (void)oldCount; 1707cdf0e10cSrcweir #endif 1708cdf0e10cSrcweir 1709cdf0e10cSrcweir // Release Cache DC 1710cdf0e10cSrcweir if ( pThis->mpGraphics2 && 17115f27b83cSArmin Le Grand pThis->mpGraphics2->getHDC() ) 1712cdf0e10cSrcweir { 1713cdf0e10cSrcweir // save current gdi objects before hdc is gone 17145f27b83cSArmin Le Grand hFont = (HFONT) GetCurrentObject( pThis->mpGraphics2->getHDC(), OBJ_FONT); 17155f27b83cSArmin Le Grand hPen = (HPEN) GetCurrentObject( pThis->mpGraphics2->getHDC(), OBJ_PEN); 17165f27b83cSArmin Le Grand hBrush = (HBRUSH) GetCurrentObject( pThis->mpGraphics2->getHDC(), OBJ_BRUSH); 1717cdf0e10cSrcweir pThis->ReleaseGraphics( pThis->mpGraphics2 ); 1718cdf0e10cSrcweir 1719cdf0e10cSrcweir // recreate cache dc only if it was destroyed 1720cdf0e10cSrcweir bNeedCacheDC = TRUE; 1721cdf0e10cSrcweir } 1722cdf0e10cSrcweir 1723cdf0e10cSrcweir // destroy saved DC 1724cdf0e10cSrcweir if ( pThis->mpGraphics ) 1725cdf0e10cSrcweir { 1726cdf0e10cSrcweir if ( pThis->mpGraphics->mhDefPal ) 17275f27b83cSArmin Le Grand SelectPalette( pThis->mpGraphics->getHDC(), pThis->mpGraphics->mhDefPal, TRUE ); 1728cdf0e10cSrcweir ImplSalDeInitGraphics( pThis->mpGraphics ); 17295f27b83cSArmin Le Grand ReleaseDC( pThis->mhWnd, pThis->mpGraphics->getHDC() ); 1730cdf0e10cSrcweir } 1731cdf0e10cSrcweir 1732cdf0e10cSrcweir // create a new hwnd with the same styles 1733cdf0e10cSrcweir HWND hWndParent = hNewParentWnd; 1734cdf0e10cSrcweir // forward to main thread 1735cdf0e10cSrcweir HWND hWnd = (HWND) ImplSendMessage( pSalData->mpFirstInstance->mhComWnd, 1736cdf0e10cSrcweir bAsChild ? SAL_MSG_RECREATECHILDHWND : SAL_MSG_RECREATEHWND, 1737cdf0e10cSrcweir (WPARAM) hWndParent, (LPARAM)pThis->mhWnd ); 1738cdf0e10cSrcweir 1739cdf0e10cSrcweir // succeeded ? 1740cdf0e10cSrcweir DBG_ASSERT( IsWindow( hWnd ), "WinSalFrame::SetParent not successful"); 1741cdf0e10cSrcweir 1742cdf0e10cSrcweir // recreate DCs 1743cdf0e10cSrcweir if( bNeedGraphics ) 1744cdf0e10cSrcweir { 1745cdf0e10cSrcweir if( pThis->mpGraphics2 ) 1746cdf0e10cSrcweir { 1747cdf0e10cSrcweir pThis->mpGraphics2->mhWnd = hWnd; 1748cdf0e10cSrcweir 1749cdf0e10cSrcweir if( bNeedCacheDC ) 1750cdf0e10cSrcweir { 1751cdf0e10cSrcweir // re-create cached DC 1752cdf0e10cSrcweir HDC hDC = (HDC)ImplSendMessage( pSalData->mpFirstInstance->mhComWnd, 1753cdf0e10cSrcweir SAL_MSG_GETDC, 1754cdf0e10cSrcweir (WPARAM) hWnd, 0 ); 1755cdf0e10cSrcweir if ( hDC ) 1756cdf0e10cSrcweir { 17575f27b83cSArmin Le Grand pThis->mpGraphics2->setHDC(hDC); 1758cdf0e10cSrcweir if ( pSalData->mhDitherPal ) 1759cdf0e10cSrcweir { 1760cdf0e10cSrcweir pThis->mpGraphics2->mhDefPal = SelectPalette( hDC, pSalData->mhDitherPal, TRUE ); 1761cdf0e10cSrcweir RealizePalette( hDC ); 1762cdf0e10cSrcweir } 1763cdf0e10cSrcweir ImplSalInitGraphics( pThis->mpGraphics2 ); 1764cdf0e10cSrcweir 1765cdf0e10cSrcweir // re-select saved gdi objects 1766cdf0e10cSrcweir if( hFont ) 1767cdf0e10cSrcweir SelectObject( hDC, hFont ); 1768cdf0e10cSrcweir if( hPen ) 1769cdf0e10cSrcweir SelectObject( hDC, hPen ); 1770cdf0e10cSrcweir if( hBrush ) 1771cdf0e10cSrcweir SelectObject( hDC, hBrush ); 1772cdf0e10cSrcweir 1773cdf0e10cSrcweir pThis->mbGraphics = TRUE; 1774cdf0e10cSrcweir 1775cdf0e10cSrcweir pSalData->mnCacheDCInUse++; 1776cdf0e10cSrcweir 1777cdf0e10cSrcweir DBG_ASSERT( oldCount == pSalData->mnCacheDCInUse, "WinSalFrame::SetParent() hDC count corrupted"); 1778cdf0e10cSrcweir } 1779cdf0e10cSrcweir } 1780cdf0e10cSrcweir } 1781cdf0e10cSrcweir 1782cdf0e10cSrcweir if( pThis->mpGraphics ) 1783cdf0e10cSrcweir { 1784cdf0e10cSrcweir // re-create DC 1785cdf0e10cSrcweir pThis->mpGraphics->mhWnd = hWnd; 17865f27b83cSArmin Le Grand pThis->mpGraphics->setHDC( GetDC( hWnd ) ); 1787cdf0e10cSrcweir if ( GetSalData()->mhDitherPal ) 1788cdf0e10cSrcweir { 17895f27b83cSArmin Le Grand pThis->mpGraphics->mhDefPal = SelectPalette( pThis->mpGraphics->getHDC(), GetSalData()->mhDitherPal, TRUE ); 17905f27b83cSArmin Le Grand RealizePalette( pThis->mpGraphics->getHDC() ); 1791cdf0e10cSrcweir } 1792cdf0e10cSrcweir ImplSalInitGraphics( pThis->mpGraphics ); 1793cdf0e10cSrcweir pThis->mbGraphics = TRUE; 1794cdf0e10cSrcweir } 1795cdf0e10cSrcweir } 1796cdf0e10cSrcweir 1797cdf0e10cSrcweir 1798cdf0e10cSrcweir // TODO: add SetParent() call for SalObjects 1799cdf0e10cSrcweir DBG_ASSERT( systemChildren.empty(), "WinSalFrame::SetParent() parent of living system child window will be destroyed!"); 1800cdf0e10cSrcweir 1801cdf0e10cSrcweir // reparent children before old parent is destroyed 1802cdf0e10cSrcweir for( ::std::vector< WinSalFrame* >::iterator iChild = children.begin(); iChild != children.end(); iChild++ ) 1803cdf0e10cSrcweir ImplSetParentFrame( *iChild, hWnd, FALSE ); 1804cdf0e10cSrcweir 1805cdf0e10cSrcweir children.clear(); 1806cdf0e10cSrcweir systemChildren.clear(); 1807cdf0e10cSrcweir 1808cdf0e10cSrcweir // Now destroy original HWND in the thread where it was created. 1809cdf0e10cSrcweir ImplSendMessage( GetSalData()->mpFirstInstance->mhComWnd, 1810cdf0e10cSrcweir SAL_MSG_DESTROYHWND, (WPARAM) 0, (LPARAM)hWndOld); 1811cdf0e10cSrcweir } 1812cdf0e10cSrcweir 1813cdf0e10cSrcweir // ----------------------------------------------------------------------- 1814cdf0e10cSrcweir 1815cdf0e10cSrcweir void WinSalFrame::SetParent( SalFrame* pNewParent ) 1816cdf0e10cSrcweir { 1817cdf0e10cSrcweir WinSalFrame::mbInReparent = TRUE; 1818cdf0e10cSrcweir ImplSetParentFrame( this, static_cast<WinSalFrame*>(pNewParent)->mhWnd, FALSE ); 1819cdf0e10cSrcweir WinSalFrame::mbInReparent = FALSE; 1820cdf0e10cSrcweir } 1821cdf0e10cSrcweir 1822cdf0e10cSrcweir bool WinSalFrame::SetPluginParent( SystemParentData* pNewParent ) 1823cdf0e10cSrcweir { 1824cdf0e10cSrcweir if ( pNewParent->hWnd == 0 ) 1825cdf0e10cSrcweir { 1826cdf0e10cSrcweir pNewParent->hWnd = GetDesktopWindow(); 1827cdf0e10cSrcweir } 1828cdf0e10cSrcweir 1829cdf0e10cSrcweir WinSalFrame::mbInReparent = TRUE; 1830cdf0e10cSrcweir ImplSetParentFrame( this, pNewParent->hWnd, TRUE ); 1831cdf0e10cSrcweir WinSalFrame::mbInReparent = FALSE; 1832cdf0e10cSrcweir return true; 1833cdf0e10cSrcweir } 1834cdf0e10cSrcweir 1835cdf0e10cSrcweir 1836cdf0e10cSrcweir // ----------------------------------------------------------------------- 1837cdf0e10cSrcweir 1838cdf0e10cSrcweir void WinSalFrame::GetWorkArea( Rectangle &rRect ) 1839cdf0e10cSrcweir { 1840cdf0e10cSrcweir RECT aRect; 1841cdf0e10cSrcweir ImplSalGetWorkArea( mhWnd, &aRect, NULL ); 1842cdf0e10cSrcweir rRect.nLeft = aRect.left; 1843cdf0e10cSrcweir rRect.nRight = aRect.right-1; 1844cdf0e10cSrcweir rRect.nTop = aRect.top; 1845cdf0e10cSrcweir rRect.nBottom = aRect.bottom-1; 1846cdf0e10cSrcweir } 1847cdf0e10cSrcweir 1848cdf0e10cSrcweir // ----------------------------------------------------------------------- 1849cdf0e10cSrcweir 1850cdf0e10cSrcweir void WinSalFrame::GetClientSize( long& rWidth, long& rHeight ) 1851cdf0e10cSrcweir { 1852cdf0e10cSrcweir rWidth = maGeometry.nWidth; 1853cdf0e10cSrcweir rHeight = maGeometry.nHeight; 1854cdf0e10cSrcweir } 1855cdf0e10cSrcweir 1856cdf0e10cSrcweir // ----------------------------------------------------------------------- 1857cdf0e10cSrcweir 1858cdf0e10cSrcweir void WinSalFrame::SetWindowState( const SalFrameState* pState ) 1859cdf0e10cSrcweir { 1860cdf0e10cSrcweir // Wir testen, ob das Fenster ueberhaupt auf den Bildschirm passt, damit 1861cdf0e10cSrcweir // nicht wenn die Bildschirm-Aufloesung geaendert wurde, das Fenster aus 1862cdf0e10cSrcweir // diesem herausragt 1863cdf0e10cSrcweir int nX; 1864cdf0e10cSrcweir int nY; 1865cdf0e10cSrcweir int nWidth; 1866cdf0e10cSrcweir int nHeight; 1867cdf0e10cSrcweir int nScreenX; 1868cdf0e10cSrcweir int nScreenY; 1869cdf0e10cSrcweir int nScreenWidth; 1870cdf0e10cSrcweir int nScreenHeight; 1871cdf0e10cSrcweir 1872cdf0e10cSrcweir RECT aRect; 1873cdf0e10cSrcweir ImplSalGetWorkArea( mhWnd, &aRect, NULL ); 1874cdf0e10cSrcweir // #102500# allow some overlap, the window could have been made a little larger than the physical screen 1875cdf0e10cSrcweir nScreenX = aRect.left-10; 1876cdf0e10cSrcweir nScreenY = aRect.top-10; 1877cdf0e10cSrcweir nScreenWidth = aRect.right-aRect.left+20; 1878cdf0e10cSrcweir nScreenHeight = aRect.bottom-aRect.top+20; 1879cdf0e10cSrcweir 1880cdf0e10cSrcweir UINT nPosSize = 0; 1881cdf0e10cSrcweir RECT aWinRect; 1882cdf0e10cSrcweir GetWindowRect( mhWnd, &aWinRect ); 1883cdf0e10cSrcweir 1884cdf0e10cSrcweir // to be consistent with Unix, the frame state is without(!) decoration 1885cdf0e10cSrcweir // ->add the decoration 1886cdf0e10cSrcweir RECT aRect2 = aWinRect; 1887cdf0e10cSrcweir AdjustWindowRectEx( &aRect2, GetWindowStyle( mhWnd ), 1888cdf0e10cSrcweir FALSE, GetWindowExStyle( mhWnd ) ); 1889cdf0e10cSrcweir long nTopDeco = abs( aWinRect.top - aRect2.top ); 1890cdf0e10cSrcweir long nLeftDeco = abs( aWinRect.left - aRect2.left ); 1891cdf0e10cSrcweir long nBottomDeco = abs( aWinRect.bottom - aRect2.bottom ); 1892cdf0e10cSrcweir long nRightDeco = abs( aWinRect.right - aRect2.right ); 1893cdf0e10cSrcweir 1894cdf0e10cSrcweir // Fenster-Position/Groesse in den Bildschirm einpassen 1895cdf0e10cSrcweir if ( !(pState->mnMask & (SAL_FRAMESTATE_MASK_X | SAL_FRAMESTATE_MASK_Y)) ) 1896cdf0e10cSrcweir nPosSize |= SWP_NOMOVE; 1897cdf0e10cSrcweir if ( !(pState->mnMask & (SAL_FRAMESTATE_MASK_WIDTH | SAL_FRAMESTATE_MASK_HEIGHT)) ) 1898cdf0e10cSrcweir nPosSize |= SWP_NOSIZE; 1899cdf0e10cSrcweir if ( pState->mnMask & SAL_FRAMESTATE_MASK_X ) 1900cdf0e10cSrcweir nX = (int)pState->mnX - nLeftDeco; 1901cdf0e10cSrcweir else 1902cdf0e10cSrcweir nX = aWinRect.left; 1903cdf0e10cSrcweir if ( pState->mnMask & SAL_FRAMESTATE_MASK_Y ) 1904cdf0e10cSrcweir nY = (int)pState->mnY - nTopDeco; 1905cdf0e10cSrcweir else 1906cdf0e10cSrcweir nY = aWinRect.top; 1907cdf0e10cSrcweir if ( pState->mnMask & SAL_FRAMESTATE_MASK_WIDTH ) 1908cdf0e10cSrcweir nWidth = (int)pState->mnWidth + nLeftDeco + nRightDeco; 1909cdf0e10cSrcweir else 1910cdf0e10cSrcweir nWidth = aWinRect.right-aWinRect.left; 1911cdf0e10cSrcweir if ( pState->mnMask & SAL_FRAMESTATE_MASK_HEIGHT ) 1912cdf0e10cSrcweir nHeight = (int)pState->mnHeight + nTopDeco + nBottomDeco; 1913cdf0e10cSrcweir else 1914cdf0e10cSrcweir nHeight = aWinRect.bottom-aWinRect.top; 1915cdf0e10cSrcweir 1916cdf0e10cSrcweir // Adjust Window in the screen: 1917cdf0e10cSrcweir // if it does not fit into the screen do nothing, ie default pos/size will be used 1918cdf0e10cSrcweir // if there is an overlap with the screen border move the window while keeping its size 1919cdf0e10cSrcweir 1920cdf0e10cSrcweir if( nWidth > nScreenWidth || nHeight > nScreenHeight ) 1921cdf0e10cSrcweir nPosSize |= (SWP_NOMOVE | SWP_NOSIZE); 1922cdf0e10cSrcweir 1923cdf0e10cSrcweir if ( nX+nWidth > nScreenX+nScreenWidth ) 1924cdf0e10cSrcweir nX = (nScreenX+nScreenWidth) - nWidth; 1925cdf0e10cSrcweir if ( nY+nHeight > nScreenY+nScreenHeight ) 1926cdf0e10cSrcweir nY = (nScreenY+nScreenHeight) - nHeight; 1927cdf0e10cSrcweir if ( nX < nScreenX ) 1928cdf0e10cSrcweir nX = nScreenX; 1929cdf0e10cSrcweir if ( nY < nScreenY ) 1930cdf0e10cSrcweir nY = nScreenY; 1931cdf0e10cSrcweir 1932cdf0e10cSrcweir // Restore-Position setzen 1933cdf0e10cSrcweir WINDOWPLACEMENT aPlacement; 1934cdf0e10cSrcweir aPlacement.length = sizeof( aPlacement ); 1935cdf0e10cSrcweir GetWindowPlacement( mhWnd, &aPlacement ); 1936cdf0e10cSrcweir 1937cdf0e10cSrcweir // Status setzen 1938cdf0e10cSrcweir sal_Bool bVisible = (GetWindowStyle( mhWnd ) & WS_VISIBLE) != 0; 1939cdf0e10cSrcweir sal_Bool bUpdateHiddenFramePos = FALSE; 1940cdf0e10cSrcweir if ( !bVisible ) 1941cdf0e10cSrcweir { 1942cdf0e10cSrcweir aPlacement.showCmd = SW_HIDE; 1943cdf0e10cSrcweir 1944cdf0e10cSrcweir if ( mbOverwriteState ) 1945cdf0e10cSrcweir { 1946cdf0e10cSrcweir if ( pState->mnMask & SAL_FRAMESTATE_MASK_STATE ) 1947cdf0e10cSrcweir { 1948cdf0e10cSrcweir if ( pState->mnState & SAL_FRAMESTATE_MINIMIZED ) 1949cdf0e10cSrcweir mnShowState = SW_SHOWMINIMIZED; 1950cdf0e10cSrcweir else if ( pState->mnState & SAL_FRAMESTATE_MAXIMIZED ) 1951cdf0e10cSrcweir { 1952cdf0e10cSrcweir mnShowState = SW_SHOWMAXIMIZED; 1953cdf0e10cSrcweir bUpdateHiddenFramePos = TRUE; 1954cdf0e10cSrcweir } 1955cdf0e10cSrcweir else if ( pState->mnState & SAL_FRAMESTATE_NORMAL ) 1956cdf0e10cSrcweir mnShowState = SW_SHOWNORMAL; 1957cdf0e10cSrcweir } 1958cdf0e10cSrcweir } 1959cdf0e10cSrcweir } 1960cdf0e10cSrcweir else 1961cdf0e10cSrcweir { 1962cdf0e10cSrcweir if ( pState->mnMask & SAL_FRAMESTATE_MASK_STATE ) 1963cdf0e10cSrcweir { 1964cdf0e10cSrcweir if ( pState->mnState & SAL_FRAMESTATE_MINIMIZED ) 1965cdf0e10cSrcweir { 1966cdf0e10cSrcweir if ( pState->mnState & SAL_FRAMESTATE_MAXIMIZED ) 1967cdf0e10cSrcweir aPlacement.flags |= WPF_RESTORETOMAXIMIZED; 1968cdf0e10cSrcweir aPlacement.showCmd = SW_SHOWMINIMIZED; 1969cdf0e10cSrcweir } 1970cdf0e10cSrcweir else if ( pState->mnState & SAL_FRAMESTATE_MAXIMIZED ) 1971cdf0e10cSrcweir aPlacement.showCmd = SW_SHOWMAXIMIZED; 1972cdf0e10cSrcweir else if ( pState->mnState & SAL_FRAMESTATE_NORMAL ) 1973cdf0e10cSrcweir aPlacement.showCmd = SW_RESTORE; 1974cdf0e10cSrcweir } 1975cdf0e10cSrcweir } 1976cdf0e10cSrcweir 1977cdf0e10cSrcweir // if a window is neither minimized nor maximized or need not be 1978cdf0e10cSrcweir // positioned visibly (that is in visible state), do not use 1979cdf0e10cSrcweir // SetWindowPlacement since it calculates including the TaskBar 1980cdf0e10cSrcweir if ( !IsIconic( mhWnd ) && !IsZoomed( mhWnd ) && 1981cdf0e10cSrcweir (!bVisible || (aPlacement.showCmd == SW_RESTORE)) ) 1982cdf0e10cSrcweir { 1983cdf0e10cSrcweir if( bUpdateHiddenFramePos ) 1984cdf0e10cSrcweir { 1985cdf0e10cSrcweir RECT aStateRect; 1986cdf0e10cSrcweir aStateRect.left = nX; 1987cdf0e10cSrcweir aStateRect.top = nY; 1988cdf0e10cSrcweir aStateRect.right = nX+nWidth; 1989cdf0e10cSrcweir aStateRect.bottom = nY+nHeight; 1990cdf0e10cSrcweir // #96084 set a useful internal window size because 1991cdf0e10cSrcweir // the window will not be maximized (and the size updated) before show() 1992cdf0e10cSrcweir SetMaximizedFrameGeometry( mhWnd, this, &aStateRect ); 1993cdf0e10cSrcweir SetWindowPos( mhWnd, 0, 1994cdf0e10cSrcweir maGeometry.nX, maGeometry.nY, maGeometry.nWidth, maGeometry.nHeight, 1995cdf0e10cSrcweir SWP_NOZORDER | SWP_NOACTIVATE | nPosSize ); 1996cdf0e10cSrcweir } 1997cdf0e10cSrcweir else 1998cdf0e10cSrcweir SetWindowPos( mhWnd, 0, 1999cdf0e10cSrcweir nX, nY, nWidth, nHeight, 2000cdf0e10cSrcweir SWP_NOZORDER | SWP_NOACTIVATE | nPosSize ); 2001cdf0e10cSrcweir } 2002cdf0e10cSrcweir else 2003cdf0e10cSrcweir { 2004cdf0e10cSrcweir if( !(nPosSize & (SWP_NOMOVE|SWP_NOSIZE)) ) 2005cdf0e10cSrcweir { 2006cdf0e10cSrcweir aPlacement.rcNormalPosition.left = nX-nScreenX; 2007cdf0e10cSrcweir aPlacement.rcNormalPosition.top = nY-nScreenY; 2008cdf0e10cSrcweir aPlacement.rcNormalPosition.right = nX+nWidth-nScreenX; 2009cdf0e10cSrcweir aPlacement.rcNormalPosition.bottom = nY+nHeight-nScreenY; 2010cdf0e10cSrcweir } 2011cdf0e10cSrcweir SetWindowPlacement( mhWnd, &aPlacement ); 2012cdf0e10cSrcweir } 2013cdf0e10cSrcweir 2014cdf0e10cSrcweir if( !(nPosSize & SWP_NOMOVE) ) 2015cdf0e10cSrcweir mbDefPos = FALSE; // window was positioned 2016cdf0e10cSrcweir } 2017cdf0e10cSrcweir 2018cdf0e10cSrcweir // ----------------------------------------------------------------------- 2019cdf0e10cSrcweir 2020cdf0e10cSrcweir sal_Bool WinSalFrame::GetWindowState( SalFrameState* pState ) 2021cdf0e10cSrcweir { 2022cdf0e10cSrcweir if ( maState.mnWidth && maState.mnHeight ) 2023cdf0e10cSrcweir { 2024cdf0e10cSrcweir *pState = maState; 2025cdf0e10cSrcweir // #94144# allow Minimize again, should be masked out when read from configuration 2026cdf0e10cSrcweir // 91625 - Don't save minimize 2027cdf0e10cSrcweir //if ( !(pState->mnState & SAL_FRAMESTATE_MAXIMIZED) ) 2028cdf0e10cSrcweir if ( !(pState->mnState & (SAL_FRAMESTATE_MINIMIZED | SAL_FRAMESTATE_MAXIMIZED)) ) 2029cdf0e10cSrcweir pState->mnState |= SAL_FRAMESTATE_NORMAL; 2030cdf0e10cSrcweir return TRUE; 2031cdf0e10cSrcweir } 2032cdf0e10cSrcweir 2033cdf0e10cSrcweir return FALSE; 2034cdf0e10cSrcweir } 2035cdf0e10cSrcweir 2036cdf0e10cSrcweir // ----------------------------------------------------------------------- 2037cdf0e10cSrcweir 2038cdf0e10cSrcweir void WinSalFrame::SetScreenNumber( unsigned int nNewScreen ) 2039cdf0e10cSrcweir { 2040cdf0e10cSrcweir WinSalSystem* pSys = static_cast<WinSalSystem*>(ImplGetSalSystem()); 2041cdf0e10cSrcweir if( pSys ) 2042cdf0e10cSrcweir { 2043cdf0e10cSrcweir const std::vector<WinSalSystem::DisplayMonitor>& rMonitors = 2044cdf0e10cSrcweir pSys->getMonitors(); 2045cdf0e10cSrcweir size_t nMon = rMonitors.size(); 2046cdf0e10cSrcweir if( nNewScreen < nMon ) 2047cdf0e10cSrcweir { 2048cdf0e10cSrcweir Point aOldMonPos, aNewMonPos( rMonitors[nNewScreen].m_aArea.TopLeft() ); 2049cdf0e10cSrcweir Point aCurPos( maGeometry.nX, maGeometry.nY ); 2050cdf0e10cSrcweir for( size_t i = 0; i < nMon; i++ ) 2051cdf0e10cSrcweir { 2052cdf0e10cSrcweir if( rMonitors[i].m_aArea.IsInside( aCurPos ) ) 2053cdf0e10cSrcweir { 2054cdf0e10cSrcweir aOldMonPos = rMonitors[i].m_aArea.TopLeft(); 2055cdf0e10cSrcweir break; 2056cdf0e10cSrcweir } 2057cdf0e10cSrcweir } 2058cdf0e10cSrcweir mnDisplay = nNewScreen; 2059cdf0e10cSrcweir maGeometry.nScreenNumber = nNewScreen; 2060cdf0e10cSrcweir SetPosSize( aNewMonPos.X() + (maGeometry.nX - aOldMonPos.X()), 2061cdf0e10cSrcweir aNewMonPos.Y() + (maGeometry.nY - aOldMonPos.Y()), 2062cdf0e10cSrcweir 0, 0, 2063cdf0e10cSrcweir SAL_FRAME_POSSIZE_X | SAL_FRAME_POSSIZE_Y ); 2064cdf0e10cSrcweir } 2065cdf0e10cSrcweir } 2066cdf0e10cSrcweir } 2067cdf0e10cSrcweir 2068cdf0e10cSrcweir // ----------------------------------------------------------------------- 2069cdf0e10cSrcweir 2070cdf0e10cSrcweir void WinSalFrame::ShowFullScreen( sal_Bool bFullScreen, sal_Int32 nDisplay ) 2071cdf0e10cSrcweir { 2072cdf0e10cSrcweir if ( (mbFullScreen == bFullScreen) && (!bFullScreen || (mnDisplay == nDisplay)) ) 2073cdf0e10cSrcweir return; 2074cdf0e10cSrcweir 2075cdf0e10cSrcweir mbFullScreen = bFullScreen; 2076cdf0e10cSrcweir mnDisplay = nDisplay; 2077cdf0e10cSrcweir 2078cdf0e10cSrcweir if ( bFullScreen ) 2079cdf0e10cSrcweir { 2080cdf0e10cSrcweir // Damit Taskleiste von Windows ausgeblendet wird 2081cdf0e10cSrcweir DWORD nExStyle = GetWindowExStyle( mhWnd ); 2082cdf0e10cSrcweir if ( nExStyle & WS_EX_TOOLWINDOW ) 2083cdf0e10cSrcweir { 2084cdf0e10cSrcweir mbFullScreenToolWin = TRUE; 2085cdf0e10cSrcweir nExStyle &= ~WS_EX_TOOLWINDOW; 2086cdf0e10cSrcweir SetWindowExStyle( mhWnd, nExStyle ); 2087cdf0e10cSrcweir } 2088cdf0e10cSrcweir // save old position 2089cdf0e10cSrcweir GetWindowRect( mhWnd, &maFullScreenRect ); 2090cdf0e10cSrcweir 2091cdf0e10cSrcweir // save show state 2092cdf0e10cSrcweir mnFullScreenShowState = mnShowState; 2093cdf0e10cSrcweir if ( !(GetWindowStyle( mhWnd ) & WS_VISIBLE) ) 2094cdf0e10cSrcweir mnShowState = SW_SHOW; 2095cdf0e10cSrcweir 2096cdf0e10cSrcweir // set window to screen size 2097cdf0e10cSrcweir ImplSalFrameFullScreenPos( this, TRUE ); 2098cdf0e10cSrcweir } 2099cdf0e10cSrcweir else 2100cdf0e10cSrcweir { 2101cdf0e10cSrcweir // wenn ShowState wieder hergestellt werden muss, hiden wir zuerst 2102cdf0e10cSrcweir // das Fenster, damit es nicht so sehr flackert 2103cdf0e10cSrcweir sal_Bool bVisible = (GetWindowStyle( mhWnd ) & WS_VISIBLE) != 0; 2104cdf0e10cSrcweir if ( bVisible && (mnShowState != mnFullScreenShowState) ) 2105cdf0e10cSrcweir ShowWindow( mhWnd, SW_HIDE ); 2106cdf0e10cSrcweir 2107cdf0e10cSrcweir if ( mbFullScreenToolWin ) 2108cdf0e10cSrcweir SetWindowExStyle( mhWnd, GetWindowExStyle( mhWnd ) | WS_EX_TOOLWINDOW ); 2109cdf0e10cSrcweir mbFullScreenToolWin = FALSE; 2110cdf0e10cSrcweir 2111cdf0e10cSrcweir SetWindowPos( mhWnd, 0, 2112cdf0e10cSrcweir maFullScreenRect.left, 2113cdf0e10cSrcweir maFullScreenRect.top, 2114cdf0e10cSrcweir maFullScreenRect.right-maFullScreenRect.left, 2115cdf0e10cSrcweir maFullScreenRect.bottom-maFullScreenRect.top, 2116cdf0e10cSrcweir SWP_NOZORDER | SWP_NOACTIVATE ); 2117cdf0e10cSrcweir 2118cdf0e10cSrcweir // restore show state 2119cdf0e10cSrcweir if ( mnShowState != mnFullScreenShowState ) 2120cdf0e10cSrcweir { 2121cdf0e10cSrcweir mnShowState = mnFullScreenShowState; 2122cdf0e10cSrcweir if ( bVisible ) 2123cdf0e10cSrcweir { 2124cdf0e10cSrcweir mbInShow = TRUE; 2125cdf0e10cSrcweir ShowWindow( mhWnd, mnShowState ); 2126cdf0e10cSrcweir mbInShow = FALSE; 2127cdf0e10cSrcweir UpdateWindow( mhWnd ); 2128cdf0e10cSrcweir } 2129cdf0e10cSrcweir } 2130cdf0e10cSrcweir } 2131cdf0e10cSrcweir } 2132cdf0e10cSrcweir 2133cdf0e10cSrcweir // ----------------------------------------------------------------------- 2134cdf0e10cSrcweir 2135cdf0e10cSrcweir void WinSalFrame::StartPresentation( sal_Bool bStart ) 2136cdf0e10cSrcweir { 2137cdf0e10cSrcweir if ( mbPresentation == bStart ) 2138cdf0e10cSrcweir return; 2139cdf0e10cSrcweir 2140cdf0e10cSrcweir mbPresentation = bStart; 2141cdf0e10cSrcweir 2142cdf0e10cSrcweir SalData* pSalData = GetSalData(); 2143cdf0e10cSrcweir if ( bStart ) 2144cdf0e10cSrcweir { 2145cdf0e10cSrcweir if ( !pSalData->mpSageEnableProc ) 2146cdf0e10cSrcweir { 2147cdf0e10cSrcweir if ( pSalData->mnSageStatus != DISABLE_AGENT ) 2148cdf0e10cSrcweir { 2149cdf0e10cSrcweir OFSTRUCT aOS; 2150cdf0e10cSrcweir OpenFile( "SAGE.DLL", &aOS, OF_EXIST ); 2151cdf0e10cSrcweir 2152cdf0e10cSrcweir if ( !aOS.nErrCode ) 2153cdf0e10cSrcweir { 2154aa150a94SHerbert Dürr oslModule mhSageInst = osl_loadAsciiModule( aOS.szPathName, SAL_LOADMODULE_DEFAULT ); 2155cdf0e10cSrcweir pSalData->mpSageEnableProc = (SysAgt_Enable_PROC)osl_getAsciiFunctionSymbol( mhSageInst, "System_Agent_Enable" ); 2156cdf0e10cSrcweir } 2157cdf0e10cSrcweir else 2158cdf0e10cSrcweir pSalData->mnSageStatus = DISABLE_AGENT; 2159cdf0e10cSrcweir } 2160cdf0e10cSrcweir } 2161cdf0e10cSrcweir 2162cdf0e10cSrcweir if ( pSalData->mpSageEnableProc ) 2163cdf0e10cSrcweir { 2164cdf0e10cSrcweir pSalData->mnSageStatus = pSalData->mpSageEnableProc( GET_AGENT_STATUS ); 2165cdf0e10cSrcweir if ( pSalData->mnSageStatus == ENABLE_AGENT ) 2166cdf0e10cSrcweir pSalData->mpSageEnableProc( DISABLE_AGENT ); 2167cdf0e10cSrcweir } 2168cdf0e10cSrcweir 2169cdf0e10cSrcweir // Bildschirmschoner ausschalten, wenn Praesentation laueft 2170cdf0e10cSrcweir SystemParametersInfo( SPI_GETSCREENSAVEACTIVE, 0, 2171cdf0e10cSrcweir &(pSalData->mbScrSvrEnabled), 0 ); 2172cdf0e10cSrcweir if ( pSalData->mbScrSvrEnabled ) 2173cdf0e10cSrcweir SystemParametersInfo( SPI_SETSCREENSAVEACTIVE, FALSE, 0, 0 ); 2174cdf0e10cSrcweir } 2175cdf0e10cSrcweir else 2176cdf0e10cSrcweir { 2177cdf0e10cSrcweir // Bildschirmschoner wieder einschalten 2178cdf0e10cSrcweir if ( pSalData->mbScrSvrEnabled ) 2179cdf0e10cSrcweir SystemParametersInfo( SPI_SETSCREENSAVEACTIVE, pSalData->mbScrSvrEnabled, 0, 0 ); 2180cdf0e10cSrcweir 2181cdf0e10cSrcweir // Systemagenten wieder aktivieren 2182cdf0e10cSrcweir if ( pSalData->mnSageStatus == ENABLE_AGENT ) 2183cdf0e10cSrcweir pSalData->mpSageEnableProc( pSalData->mnSageStatus ); 2184cdf0e10cSrcweir } 2185cdf0e10cSrcweir } 2186cdf0e10cSrcweir 2187cdf0e10cSrcweir // ----------------------------------------------------------------------- 2188cdf0e10cSrcweir 2189cdf0e10cSrcweir void WinSalFrame::SetAlwaysOnTop( sal_Bool bOnTop ) 2190cdf0e10cSrcweir { 2191cdf0e10cSrcweir HWND hWnd; 2192cdf0e10cSrcweir if ( bOnTop ) 2193cdf0e10cSrcweir hWnd = HWND_TOPMOST; 2194cdf0e10cSrcweir else 2195cdf0e10cSrcweir hWnd = HWND_NOTOPMOST; 2196cdf0e10cSrcweir SetWindowPos( mhWnd, hWnd, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE | SWP_NOACTIVATE ); 2197cdf0e10cSrcweir } 2198cdf0e10cSrcweir 2199cdf0e10cSrcweir // ----------------------------------------------------------------------- 2200cdf0e10cSrcweir 2201cdf0e10cSrcweir static void ImplSalToTop( HWND hWnd, sal_uInt16 nFlags ) 2202cdf0e10cSrcweir { 2203cdf0e10cSrcweir WinSalFrame* pToTopFrame = GetWindowPtr( hWnd ); 2204cdf0e10cSrcweir if( pToTopFrame && (pToTopFrame->mnStyle & SAL_FRAME_STYLE_SYSTEMCHILD) != 0 ) 2205cdf0e10cSrcweir BringWindowToTop( hWnd ); 2206cdf0e10cSrcweir 2207cdf0e10cSrcweir if ( nFlags & SAL_FRAME_TOTOP_FOREGROUNDTASK ) 2208cdf0e10cSrcweir { 2209cdf0e10cSrcweir // This magic code is necessary to connect the input focus of the 2210cdf0e10cSrcweir // current window thread and the thread which owns the window that 2211cdf0e10cSrcweir // should be the new foreground window. 2212cdf0e10cSrcweir HWND hCurrWnd = GetForegroundWindow(); 2213cdf0e10cSrcweir DWORD myThreadID = GetCurrentThreadId(); 2214cdf0e10cSrcweir DWORD currThreadID = GetWindowThreadProcessId(hCurrWnd,NULL); 2215cdf0e10cSrcweir AttachThreadInput(myThreadID, currThreadID,TRUE); 2216cdf0e10cSrcweir SetForegroundWindow(hWnd); 2217cdf0e10cSrcweir AttachThreadInput(myThreadID,currThreadID,FALSE); 2218cdf0e10cSrcweir } 2219cdf0e10cSrcweir 2220cdf0e10cSrcweir if ( nFlags & SAL_FRAME_TOTOP_RESTOREWHENMIN ) 2221cdf0e10cSrcweir { 2222cdf0e10cSrcweir HWND hIconicWnd = hWnd; 2223cdf0e10cSrcweir while ( hIconicWnd ) 2224cdf0e10cSrcweir { 2225cdf0e10cSrcweir if ( IsIconic( hIconicWnd ) ) 2226cdf0e10cSrcweir { 2227cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hIconicWnd ); 2228cdf0e10cSrcweir if ( pFrame ) 2229cdf0e10cSrcweir { 2230cdf0e10cSrcweir if ( GetWindowPtr( hWnd )->mbRestoreMaximize ) 2231cdf0e10cSrcweir ShowWindow( hIconicWnd, SW_MAXIMIZE ); 2232cdf0e10cSrcweir else 2233cdf0e10cSrcweir ShowWindow( hIconicWnd, SW_RESTORE ); 2234cdf0e10cSrcweir } 2235cdf0e10cSrcweir else 2236cdf0e10cSrcweir ShowWindow( hIconicWnd, SW_RESTORE ); 2237cdf0e10cSrcweir } 2238cdf0e10cSrcweir 2239cdf0e10cSrcweir hIconicWnd = ::GetParent( hIconicWnd ); 2240cdf0e10cSrcweir } 2241cdf0e10cSrcweir } 2242cdf0e10cSrcweir 2243cdf0e10cSrcweir if ( !IsIconic( hWnd ) && IsWindowVisible( hWnd ) ) 2244cdf0e10cSrcweir { 2245cdf0e10cSrcweir SetFocus( hWnd ); 2246cdf0e10cSrcweir 2247cdf0e10cSrcweir // Windows behauptet oefters mal, das man den Focus hat, obwohl 2248cdf0e10cSrcweir // man diesen nicht hat. Wenn dies der Fall ist, dann versuchen 2249cdf0e10cSrcweir // wir diesen auch ganz richtig zu bekommen. 2250cdf0e10cSrcweir if ( ::GetFocus() == hWnd ) 2251cdf0e10cSrcweir SetForegroundWindow( hWnd ); 2252cdf0e10cSrcweir } 2253cdf0e10cSrcweir } 2254cdf0e10cSrcweir 2255cdf0e10cSrcweir // ----------------------------------------------------------------------- 2256cdf0e10cSrcweir 2257cdf0e10cSrcweir void WinSalFrame::ToTop( sal_uInt16 nFlags ) 2258cdf0e10cSrcweir { 2259cdf0e10cSrcweir nFlags &= ~SAL_FRAME_TOTOP_GRABFOCUS; // this flag is not needed on win32 2260cdf0e10cSrcweir // Post this Message to the window, because this only works 2261cdf0e10cSrcweir // in the thread of the window, which has create this window. 2262cdf0e10cSrcweir // We post this message to avoid deadlocks 2263cdf0e10cSrcweir if ( GetSalData()->mnAppThreadId != GetCurrentThreadId() ) 2264cdf0e10cSrcweir ImplPostMessage( mhWnd, SAL_MSG_TOTOP, nFlags, 0 ); 2265cdf0e10cSrcweir else 2266cdf0e10cSrcweir ImplSalToTop( mhWnd, nFlags ); 2267cdf0e10cSrcweir } 2268cdf0e10cSrcweir 2269cdf0e10cSrcweir // ----------------------------------------------------------------------- 2270cdf0e10cSrcweir 2271cdf0e10cSrcweir void WinSalFrame::SetPointer( PointerStyle ePointerStyle ) 2272cdf0e10cSrcweir { 2273cdf0e10cSrcweir struct ImplPtrData 2274cdf0e10cSrcweir { 2275cdf0e10cSrcweir HCURSOR mhCursor; 2276cdf0e10cSrcweir LPCSTR mnSysId; 2277cdf0e10cSrcweir UINT mnOwnId; 2278cdf0e10cSrcweir }; 2279cdf0e10cSrcweir 2280cdf0e10cSrcweir static ImplPtrData aImplPtrTab[POINTER_COUNT] = 2281cdf0e10cSrcweir { 2282cdf0e10cSrcweir { 0, IDC_ARROW, 0 }, // POINTER_ARROW 2283cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_NULL }, // POINTER_NULL 2284cdf0e10cSrcweir { 0, IDC_WAIT, 0 }, // POINTER_WAIT 2285cdf0e10cSrcweir { 0, IDC_IBEAM, 0 }, // POINTER_TEXT 2286cdf0e10cSrcweir { 0, IDC_HELP, 0 }, // POINTER_HELP 2287cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_CROSS }, // POINTER_CROSS 2288cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MOVE }, // POINTER_MOVE 2289cdf0e10cSrcweir { 0, IDC_SIZENS, 0 }, // POINTER_NSIZE 2290cdf0e10cSrcweir { 0, IDC_SIZENS, 0 }, // POINTER_SSIZE 2291cdf0e10cSrcweir { 0, IDC_SIZEWE, 0 }, // POINTER_WSIZE 2292cdf0e10cSrcweir { 0, IDC_SIZEWE, 0 }, // POINTER_ESIZE 2293cdf0e10cSrcweir { 0, IDC_SIZENWSE, 0 }, // POINTER_NWSIZE 2294cdf0e10cSrcweir { 0, IDC_SIZENESW, 0 }, // POINTER_NESIZE 2295cdf0e10cSrcweir { 0, IDC_SIZENESW, 0 }, // POINTER_SWSIZE 2296cdf0e10cSrcweir { 0, IDC_SIZENWSE, 0 }, // POINTER_SESIZE 2297cdf0e10cSrcweir { 0, IDC_SIZENS, 0 }, // POINTER_WINDOW_NSIZE 2298cdf0e10cSrcweir { 0, IDC_SIZENS, 0 }, // POINTER_WINDOW_SSIZE 2299cdf0e10cSrcweir { 0, IDC_SIZEWE, 0 }, // POINTER_WINDOW_WSIZE 2300cdf0e10cSrcweir { 0, IDC_SIZEWE, 0 }, // POINTER_WINDOW_ESIZE 2301cdf0e10cSrcweir { 0, IDC_SIZENWSE, 0 }, // POINTER_WINDOW_NWSIZE 2302cdf0e10cSrcweir { 0, IDC_SIZENESW, 0 }, // POINTER_WINDOW_NESIZE 2303cdf0e10cSrcweir { 0, IDC_SIZENESW, 0 }, // POINTER_WINDOW_SWSIZE 2304cdf0e10cSrcweir { 0, IDC_SIZENWSE, 0 }, // POINTER_WINDOW_SESIZE 2305cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_HSPLIT }, // POINTER_HSPLIT 2306cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_VSPLIT }, // POINTER_VSPLIT 2307cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_HSIZEBAR }, // POINTER_HSIZEBAR 2308cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_VSIZEBAR }, // POINTER_VSIZEBAR 2309cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_HAND }, // POINTER_HAND 2310cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_REFHAND }, // POINTER_REFHAND 2311cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_PEN }, // POINTER_PEN 2312cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MAGNIFY }, // POINTER_MAGNIFY 2313cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_FILL }, // POINTER_FILL 2314cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_ROTATE }, // POINTER_ROTATE 2315cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_HSHEAR }, // POINTER_HSHEAR 2316cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_VSHEAR }, // POINTER_VSHEAR 2317cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MIRROR }, // POINTER_MIRROR 2318cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_CROOK }, // POINTER_CROOK 2319cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_CROP }, // POINTER_CROP 2320cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MOVEPOINT }, // POINTER_MOVEPOINT 2321cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MOVEBEZIERWEIGHT }, // POINTER_MOVEBEZIERWEIGHT 2322cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MOVEDATA }, // POINTER_MOVEDATA 2323cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_COPYDATA }, // POINTER_COPYDATA 2324cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_LINKDATA }, // POINTER_LINKDATA 2325cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MOVEDATALINK }, // POINTER_MOVEDATALINK 2326cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_COPYDATALINK }, // POINTER_COPYDATALINK 2327cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MOVEFILE }, // POINTER_MOVEFILE 2328cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_COPYFILE }, // POINTER_COPYFILE 2329cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_LINKFILE }, // POINTER_LINKFILE 2330cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MOVEFILELINK }, // POINTER_MOVEFILELINK 2331cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_COPYFILELINK }, // POINTER_COPYFILELINK 2332cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_MOVEFILES }, // POINTER_MOVEFILES 2333cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_COPYFILES }, // POINTER_COPYFILES 2334cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_NOTALLOWED }, // POINTER_NOTALLOWED 2335cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_LINE }, // POINTER_DRAW_LINE 2336cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_RECT }, // POINTER_DRAW_RECT 2337cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_POLYGON }, // POINTER_DRAW_POLYGON 2338cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_BEZIER }, // POINTER_DRAW_BEZIER 2339cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_ARC }, // POINTER_DRAW_ARC 2340cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_PIE }, // POINTER_DRAW_PIE 2341cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_CIRCLECUT }, // POINTER_DRAW_CIRCLECUT 2342cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_ELLIPSE }, // POINTER_DRAW_ELLIPSE 2343cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_FREEHAND }, // POINTER_DRAW_FREEHAND 2344cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_CONNECT }, // POINTER_DRAW_CONNECT 2345cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_TEXT }, // POINTER_DRAW_TEXT 2346cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DRAW_CAPTION }, // POINTER_DRAW_CAPTION 2347cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_CHART }, // POINTER_CHART 2348cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_DETECTIVE }, // POINTER_DETECTIVE 2349cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_PIVOT_COL }, // POINTER_PIVOT_COL 2350cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_PIVOT_ROW }, // POINTER_PIVOT_ROW 2351cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_PIVOT_FIELD }, // POINTER_PIVOT_FIELD 2352cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_CHAIN }, // POINTER_CHAIN 2353cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_CHAIN_NOTALLOWED }, // POINTER_CHAIN_NOTALLOWED 2354cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_TIMEEVENT_MOVE }, // POINTER_TIMEEVENT_MOVE 2355cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_TIMEEVENT_SIZE }, // POINTER_TIMEEVENT_SIZE 2356cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_N }, // POINTER_AUTOSCROLL_N 2357cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_S }, // POINTER_AUTOSCROLL_S 2358cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_W }, // POINTER_AUTOSCROLL_W 2359cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_E }, // POINTER_AUTOSCROLL_E 2360cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_NW }, // POINTER_AUTOSCROLL_NW 2361cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_NE }, // POINTER_AUTOSCROLL_NE 2362cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_SW }, // POINTER_AUTOSCROLL_SW 2363cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_SE }, // POINTER_AUTOSCROLL_SE 2364cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_NS }, // POINTER_AUTOSCROLL_NS 2365cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_WE }, // POINTER_AUTOSCROLL_WE 2366cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AUTOSCROLL_NSWE }, // POINTER_AUTOSCROLL_NSWE 2367cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_AIRBRUSH }, // POINTER_AIRBRUSH 2368cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_TEXT_VERTICAL }, // POINTER_TEXT_VERTICAL 2369cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_PIVOT_DELETE }, // POINTER_PIVOT_DELETE 2370cdf0e10cSrcweir 2371cdf0e10cSrcweir // --> FME 2004-07-30 #i32329# Enhanced table selection 2372cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_TAB_SELECT_S }, // POINTER_TAB_SELECT_S 2373cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_TAB_SELECT_E }, // POINTER_TAB_SELECT_E 2374cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_TAB_SELECT_SE }, // POINTER_TAB_SELECT_SE 2375cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_TAB_SELECT_W }, // POINTER_TAB_SELECT_W 2376cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_TAB_SELECT_SW }, // POINTER_TAB_SELECT_SW 2377cdf0e10cSrcweir // <-- 2378cdf0e10cSrcweir 2379cdf0e10cSrcweir // --> FME 2004-08-16 #i20119# Paintbrush tool 2380cdf0e10cSrcweir { 0, 0, SAL_RESID_POINTER_PAINTBRUSH } // POINTER_PAINTBRUSH 2381cdf0e10cSrcweir // <-- 2382cdf0e10cSrcweir 2383cdf0e10cSrcweir }; 2384cdf0e10cSrcweir 2385cdf0e10cSrcweir #if POINTER_COUNT != 94 2386cdf0e10cSrcweir #error New Pointer must be defined! 2387cdf0e10cSrcweir #endif 2388cdf0e10cSrcweir 2389cdf0e10cSrcweir // Mousepointer loaded ? 2390cdf0e10cSrcweir if ( !aImplPtrTab[ePointerStyle].mhCursor ) 2391cdf0e10cSrcweir { 2392cdf0e10cSrcweir if ( aImplPtrTab[ePointerStyle].mnOwnId ) 2393cdf0e10cSrcweir aImplPtrTab[ePointerStyle].mhCursor = ImplLoadSalCursor( aImplPtrTab[ePointerStyle].mnOwnId ); 2394cdf0e10cSrcweir else 2395cdf0e10cSrcweir aImplPtrTab[ePointerStyle].mhCursor = LoadCursor( 0, aImplPtrTab[ePointerStyle].mnSysId ); 2396cdf0e10cSrcweir } 2397cdf0e10cSrcweir 2398cdf0e10cSrcweir // Unterscheidet sich der Mauspointer, dann den neuen setzen 2399cdf0e10cSrcweir if ( mhCursor != aImplPtrTab[ePointerStyle].mhCursor ) 2400cdf0e10cSrcweir { 2401cdf0e10cSrcweir mhCursor = aImplPtrTab[ePointerStyle].mhCursor; 2402cdf0e10cSrcweir SetCursor( mhCursor ); 2403cdf0e10cSrcweir } 2404cdf0e10cSrcweir } 2405cdf0e10cSrcweir 2406cdf0e10cSrcweir // ----------------------------------------------------------------------- 2407cdf0e10cSrcweir 2408cdf0e10cSrcweir void WinSalFrame::CaptureMouse( sal_Bool bCapture ) 2409cdf0e10cSrcweir { 2410cdf0e10cSrcweir // Send this Message to the window, because CaptureMouse() only work 2411cdf0e10cSrcweir // in the thread of the window, which has create this window 2412cdf0e10cSrcweir int nMsg; 2413cdf0e10cSrcweir if ( bCapture ) 2414cdf0e10cSrcweir nMsg = SAL_MSG_CAPTUREMOUSE; 2415cdf0e10cSrcweir else 2416cdf0e10cSrcweir nMsg = SAL_MSG_RELEASEMOUSE; 2417cdf0e10cSrcweir ImplSendMessage( mhWnd, nMsg, 0, 0 ); 2418cdf0e10cSrcweir } 2419cdf0e10cSrcweir 2420cdf0e10cSrcweir // ----------------------------------------------------------------------- 2421cdf0e10cSrcweir 2422cdf0e10cSrcweir void WinSalFrame::SetPointerPos( long nX, long nY ) 2423cdf0e10cSrcweir { 2424cdf0e10cSrcweir POINT aPt; 2425cdf0e10cSrcweir aPt.x = (int)nX; 2426cdf0e10cSrcweir aPt.y = (int)nY; 2427cdf0e10cSrcweir ClientToScreen( mhWnd, &aPt ); 2428cdf0e10cSrcweir SetCursorPos( aPt.x, aPt.y ); 2429cdf0e10cSrcweir } 2430cdf0e10cSrcweir 2431cdf0e10cSrcweir // ----------------------------------------------------------------------- 2432cdf0e10cSrcweir 2433cdf0e10cSrcweir void WinSalFrame::Flush() 2434cdf0e10cSrcweir { 2435cdf0e10cSrcweir GdiFlush(); 2436cdf0e10cSrcweir } 2437cdf0e10cSrcweir 2438cdf0e10cSrcweir // ----------------------------------------------------------------------- 2439cdf0e10cSrcweir 2440cdf0e10cSrcweir void WinSalFrame::Sync() 2441cdf0e10cSrcweir { 2442cdf0e10cSrcweir GdiFlush(); 2443cdf0e10cSrcweir } 2444cdf0e10cSrcweir 2445cdf0e10cSrcweir // ----------------------------------------------------------------------- 2446cdf0e10cSrcweir 2447cdf0e10cSrcweir static void ImplSalFrameSetInputContext( HWND hWnd, const SalInputContext* pContext ) 2448cdf0e10cSrcweir { 2449cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 2450cdf0e10cSrcweir sal_Bool bIME = (pContext->mnOptions & SAL_INPUTCONTEXT_TEXT) != 0; 2451cdf0e10cSrcweir if ( bIME ) 2452cdf0e10cSrcweir { 2453cdf0e10cSrcweir if ( !pFrame->mbIME ) 2454cdf0e10cSrcweir { 2455cdf0e10cSrcweir pFrame->mbIME = TRUE; 2456cdf0e10cSrcweir 2457cdf0e10cSrcweir if ( pFrame->mhDefIMEContext ) 2458cdf0e10cSrcweir { 2459cdf0e10cSrcweir ImmAssociateContext( pFrame->mhWnd, pFrame->mhDefIMEContext ); 2460cdf0e10cSrcweir UINT nImeProps = ImmGetProperty( GetKeyboardLayout( 0 ), IGP_PROPERTY ); 2461cdf0e10cSrcweir pFrame->mbSpezIME = (nImeProps & IME_PROP_SPECIAL_UI) != 0; 2462cdf0e10cSrcweir pFrame->mbAtCursorIME = (nImeProps & IME_PROP_AT_CARET) != 0; 2463cdf0e10cSrcweir pFrame->mbHandleIME = !pFrame->mbSpezIME; 2464cdf0e10cSrcweir } 2465cdf0e10cSrcweir } 2466cdf0e10cSrcweir 2467cdf0e10cSrcweir // When the application can't handle IME messages, then the 2468cdf0e10cSrcweir // System should handle the IME handling 2469cdf0e10cSrcweir if ( !(pContext->mnOptions & SAL_INPUTCONTEXT_EXTTEXTINPUT) ) 2470cdf0e10cSrcweir pFrame->mbHandleIME = FALSE; 2471cdf0e10cSrcweir 2472cdf0e10cSrcweir // Set the Font for IME Handling 2473cdf0e10cSrcweir if ( pContext->mpFont ) 2474cdf0e10cSrcweir { 2475cdf0e10cSrcweir HIMC hIMC = ImmGetContext( pFrame->mhWnd ); 2476cdf0e10cSrcweir if ( hIMC ) 2477cdf0e10cSrcweir { 2478cdf0e10cSrcweir LOGFONTW aLogFont; 2479cdf0e10cSrcweir HDC hDC = GetDC( pFrame->mhWnd ); 2480cdf0e10cSrcweir // In case of vertical writing, always append a '@' to the 2481cdf0e10cSrcweir // Windows font name, not only if such a Windows font really is 2482cdf0e10cSrcweir // available (bTestVerticalAvail == false in the below call): 2483cdf0e10cSrcweir // The Windows IME's candidates window seems to always use a 2484cdf0e10cSrcweir // font that has all necessary glyphs, not necessarily the one 2485cdf0e10cSrcweir // specified by this font name; but it seems to decide whether 2486cdf0e10cSrcweir // to use that font's horizontal or vertical variant based on a 2487cdf0e10cSrcweir // '@' in front of this font name. 2488cdf0e10cSrcweir ImplGetLogFontFromFontSelect( hDC, pContext->mpFont, aLogFont, 2489cdf0e10cSrcweir false ); 2490cdf0e10cSrcweir ReleaseDC( pFrame->mhWnd, hDC ); 2491cdf0e10cSrcweir ImmSetCompositionFontW( hIMC, &aLogFont ); 2492cdf0e10cSrcweir ImmReleaseContext( pFrame->mhWnd, hIMC ); 2493cdf0e10cSrcweir } 2494cdf0e10cSrcweir } 2495cdf0e10cSrcweir } 2496cdf0e10cSrcweir else 2497cdf0e10cSrcweir { 2498cdf0e10cSrcweir if ( pFrame->mbIME ) 2499cdf0e10cSrcweir { 2500cdf0e10cSrcweir pFrame->mbIME = FALSE; 2501cdf0e10cSrcweir pFrame->mbHandleIME = FALSE; 2502cdf0e10cSrcweir ImmAssociateContext( pFrame->mhWnd, 0 ); 2503cdf0e10cSrcweir } 2504cdf0e10cSrcweir } 2505cdf0e10cSrcweir } 2506cdf0e10cSrcweir 2507cdf0e10cSrcweir // ----------------------------------------------------------------------- 2508cdf0e10cSrcweir 2509cdf0e10cSrcweir void WinSalFrame::SetInputContext( SalInputContext* pContext ) 2510cdf0e10cSrcweir { 2511cdf0e10cSrcweir // Must be called in the main thread! 2512cdf0e10cSrcweir ImplSendMessage( mhWnd, SAL_MSG_SETINPUTCONTEXT, 0, (LPARAM)(void*)pContext ); 2513cdf0e10cSrcweir } 2514cdf0e10cSrcweir 2515cdf0e10cSrcweir // ----------------------------------------------------------------------- 2516cdf0e10cSrcweir 2517cdf0e10cSrcweir static void ImplSalFrameEndExtTextInput( HWND hWnd, sal_uInt16 nFlags ) 2518cdf0e10cSrcweir { 2519cdf0e10cSrcweir HIMC hIMC = ImmGetContext( hWnd ); 2520cdf0e10cSrcweir if ( hIMC ) 2521cdf0e10cSrcweir { 2522cdf0e10cSrcweir DWORD nIndex; 2523cdf0e10cSrcweir if ( nFlags & SAL_FRAME_ENDEXTTEXTINPUT_COMPLETE ) 2524cdf0e10cSrcweir nIndex = CPS_COMPLETE; 2525cdf0e10cSrcweir else 2526cdf0e10cSrcweir nIndex = CPS_CANCEL; 2527cdf0e10cSrcweir 2528cdf0e10cSrcweir ImmNotifyIME( hIMC, NI_COMPOSITIONSTR, nIndex, 0 ); 2529cdf0e10cSrcweir ImmReleaseContext( hWnd, hIMC ); 2530cdf0e10cSrcweir } 2531cdf0e10cSrcweir } 2532cdf0e10cSrcweir 2533cdf0e10cSrcweir // ----------------------------------------------------------------------- 2534cdf0e10cSrcweir 2535cdf0e10cSrcweir void WinSalFrame::EndExtTextInput( sal_uInt16 nFlags ) 2536cdf0e10cSrcweir { 2537cdf0e10cSrcweir // Must be called in the main thread! 2538cdf0e10cSrcweir ImplSendMessage( mhWnd, SAL_MSG_ENDEXTTEXTINPUT, (WPARAM)nFlags, 0 ); 2539cdf0e10cSrcweir } 2540cdf0e10cSrcweir 2541cdf0e10cSrcweir // ----------------------------------------------------------------------- 2542cdf0e10cSrcweir 2543cdf0e10cSrcweir static void ImplGetKeyNameText( LONG lParam, sal_Unicode* pBuf, 2544cdf0e10cSrcweir UINT& rCount, UINT nMaxSize, 2545cdf0e10cSrcweir const sal_Char* pReplace ) 2546cdf0e10cSrcweir { 2547cdf0e10cSrcweir DBG_ASSERT( sizeof( WCHAR ) == sizeof( xub_Unicode ), "WinSalFrame::ImplGetKeyNameTextW(): WCHAR != sal_Unicode" ); 2548cdf0e10cSrcweir 2549cdf0e10cSrcweir static const int nMaxKeyLen = 350; 2550cdf0e10cSrcweir WCHAR aKeyBuf[ nMaxKeyLen ]; 2551cdf0e10cSrcweir int nKeyLen = 0; 2552cdf0e10cSrcweir if ( lParam ) 2553cdf0e10cSrcweir { 2554cdf0e10cSrcweir if ( true/*aSalShlData.mbWNT*/ ) 2555cdf0e10cSrcweir { 2556cdf0e10cSrcweir nKeyLen = GetKeyNameTextW( lParam, aKeyBuf, nMaxKeyLen ); 2557cdf0e10cSrcweir DBG_ASSERT( nKeyLen <= nMaxKeyLen, "Invalid key name length!" ); 2558cdf0e10cSrcweir if( nKeyLen > nMaxKeyLen ) 2559cdf0e10cSrcweir nKeyLen = 0; 2560cdf0e10cSrcweir else if( nKeyLen > 0 ) 2561cdf0e10cSrcweir { 2562cdf0e10cSrcweir // Capitalize just the first letter of key names 2563cdf0e10cSrcweir CharLowerBuffW( aKeyBuf, nKeyLen ); 2564cdf0e10cSrcweir 2565cdf0e10cSrcweir bool bUpper = true; 2566cdf0e10cSrcweir for( WCHAR *pW=aKeyBuf, *pE=pW+nKeyLen; pW < pE; ++pW ) 2567cdf0e10cSrcweir { 2568cdf0e10cSrcweir if( bUpper ) 2569cdf0e10cSrcweir CharUpperBuffW( pW, 1 ); 2570cdf0e10cSrcweir bUpper = (*pW=='+') || (*pW=='-') || (*pW==' ') || (*pW=='.'); 2571cdf0e10cSrcweir } 2572cdf0e10cSrcweir } 2573cdf0e10cSrcweir } 2574cdf0e10cSrcweir } 2575cdf0e10cSrcweir 2576cdf0e10cSrcweir if ( (nKeyLen > 0) || pReplace ) 2577cdf0e10cSrcweir { 2578cdf0e10cSrcweir if( (rCount > 0) && (rCount < nMaxSize) ) 2579cdf0e10cSrcweir { 2580cdf0e10cSrcweir pBuf[rCount] = '+'; 2581cdf0e10cSrcweir rCount++; 2582cdf0e10cSrcweir } 2583cdf0e10cSrcweir 2584cdf0e10cSrcweir if( nKeyLen > 0 ) 2585cdf0e10cSrcweir { 2586cdf0e10cSrcweir if( nKeyLen + rCount > nMaxSize ) 2587cdf0e10cSrcweir nKeyLen = nMaxSize - rCount; 2588cdf0e10cSrcweir memcpy( pBuf+rCount, aKeyBuf, nKeyLen*sizeof( sal_Unicode ) ); 2589cdf0e10cSrcweir rCount += nKeyLen; 2590cdf0e10cSrcweir } 2591cdf0e10cSrcweir else // fall back to provided default name 2592cdf0e10cSrcweir { 2593cdf0e10cSrcweir while( *pReplace && (rCount < nMaxSize) ) 2594cdf0e10cSrcweir { 2595cdf0e10cSrcweir pBuf[rCount] = *pReplace; 2596cdf0e10cSrcweir rCount++; 2597cdf0e10cSrcweir pReplace++; 2598cdf0e10cSrcweir } 2599cdf0e10cSrcweir } 2600cdf0e10cSrcweir } 2601cdf0e10cSrcweir else 2602cdf0e10cSrcweir rCount = 0; 2603cdf0e10cSrcweir } 2604cdf0e10cSrcweir 2605cdf0e10cSrcweir // ----------------------------------------------------------------------- 2606cdf0e10cSrcweir 2607cdf0e10cSrcweir XubString WinSalFrame::GetKeyName( sal_uInt16 nKeyCode ) 2608cdf0e10cSrcweir { 2609cdf0e10cSrcweir static const int nMaxKeyLen = 350; 2610cdf0e10cSrcweir sal_Unicode aKeyBuf[ nMaxKeyLen ]; 2611cdf0e10cSrcweir UINT nKeyBufLen = 0; 2612cdf0e10cSrcweir UINT nSysCode = 0; 2613cdf0e10cSrcweir 2614cdf0e10cSrcweir if ( nKeyCode & KEY_MOD1 ) 2615cdf0e10cSrcweir { 2616cdf0e10cSrcweir nSysCode = MapVirtualKey( VK_CONTROL, 0 ); 2617cdf0e10cSrcweir nSysCode = (nSysCode << 16) | (((sal_uLong)1) << 25); 2618cdf0e10cSrcweir ImplGetKeyNameText( nSysCode, aKeyBuf, nKeyBufLen, nMaxKeyLen, "Ctrl" ); 2619cdf0e10cSrcweir } 2620cdf0e10cSrcweir 2621cdf0e10cSrcweir if ( nKeyCode & KEY_MOD2 ) 2622cdf0e10cSrcweir { 2623cdf0e10cSrcweir nSysCode = MapVirtualKey( VK_MENU, 0 ); 2624cdf0e10cSrcweir nSysCode = (nSysCode << 16) | (((sal_uLong)1) << 25); 2625cdf0e10cSrcweir ImplGetKeyNameText( nSysCode, aKeyBuf, nKeyBufLen, nMaxKeyLen, "Alt" ); 2626cdf0e10cSrcweir } 2627cdf0e10cSrcweir 2628cdf0e10cSrcweir if ( nKeyCode & KEY_SHIFT ) 2629cdf0e10cSrcweir { 2630cdf0e10cSrcweir nSysCode = MapVirtualKey( VK_SHIFT, 0 ); 2631cdf0e10cSrcweir nSysCode = (nSysCode << 16) | (((sal_uLong)1) << 25); 2632cdf0e10cSrcweir ImplGetKeyNameText( nSysCode, aKeyBuf, nKeyBufLen, nMaxKeyLen, "Shift" ); 2633cdf0e10cSrcweir } 2634cdf0e10cSrcweir 2635cdf0e10cSrcweir sal_uInt16 nCode = nKeyCode & 0x0FFF; 2636cdf0e10cSrcweir sal_uLong nSysCode2 = 0; 2637cdf0e10cSrcweir sal_Char* pReplace = NULL; 2638cdf0e10cSrcweir sal_Unicode cSVCode = 0; 2639cdf0e10cSrcweir sal_Char aFBuf[4]; 2640cdf0e10cSrcweir nSysCode = 0; 2641cdf0e10cSrcweir 2642cdf0e10cSrcweir if ( (nCode >= KEY_0) && (nCode <= KEY_9) ) 2643cdf0e10cSrcweir cSVCode = '0' + (nCode - KEY_0); 2644cdf0e10cSrcweir else if ( (nCode >= KEY_A) && (nCode <= KEY_Z) ) 2645cdf0e10cSrcweir cSVCode = 'A' + (nCode - KEY_A); 2646cdf0e10cSrcweir else if ( (nCode >= KEY_F1) && (nCode <= KEY_F26) ) 2647cdf0e10cSrcweir { 2648cdf0e10cSrcweir nSysCode = VK_F1 + (nCode - KEY_F1); 2649cdf0e10cSrcweir aFBuf[0] = 'F'; 2650cdf0e10cSrcweir if ( (nCode >= KEY_F1) && (nCode <= KEY_F9) ) 2651cdf0e10cSrcweir { 2652cdf0e10cSrcweir aFBuf[1] = sal::static_int_cast<sal_Char>('1' + (nCode - KEY_F1)); 2653cdf0e10cSrcweir aFBuf[2] = 0; 2654cdf0e10cSrcweir } 2655cdf0e10cSrcweir else if ( (nCode >= KEY_F10) && (nCode <= KEY_F19) ) 2656cdf0e10cSrcweir { 2657cdf0e10cSrcweir aFBuf[1] = '1'; 2658cdf0e10cSrcweir aFBuf[2] = sal::static_int_cast<sal_Char>('0' + (nCode - KEY_F10)); 2659cdf0e10cSrcweir aFBuf[3] = 0; 2660cdf0e10cSrcweir } 2661cdf0e10cSrcweir else 2662cdf0e10cSrcweir { 2663cdf0e10cSrcweir aFBuf[1] = '2'; 2664cdf0e10cSrcweir aFBuf[2] = sal::static_int_cast<sal_Char>('0' + (nCode - KEY_F20)); 2665cdf0e10cSrcweir aFBuf[3] = 0; 2666cdf0e10cSrcweir } 2667cdf0e10cSrcweir pReplace = aFBuf; 2668cdf0e10cSrcweir } 2669cdf0e10cSrcweir else 2670cdf0e10cSrcweir { 2671cdf0e10cSrcweir switch ( nCode ) 2672cdf0e10cSrcweir { 2673cdf0e10cSrcweir case KEY_DOWN: 2674cdf0e10cSrcweir nSysCode = VK_DOWN; 2675cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2676cdf0e10cSrcweir pReplace = "Down"; 2677cdf0e10cSrcweir break; 2678cdf0e10cSrcweir case KEY_UP: 2679cdf0e10cSrcweir nSysCode = VK_UP; 2680cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2681cdf0e10cSrcweir pReplace = "Up"; 2682cdf0e10cSrcweir break; 2683cdf0e10cSrcweir case KEY_LEFT: 2684cdf0e10cSrcweir nSysCode = VK_LEFT; 2685cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2686cdf0e10cSrcweir pReplace = "Left"; 2687cdf0e10cSrcweir break; 2688cdf0e10cSrcweir case KEY_RIGHT: 2689cdf0e10cSrcweir nSysCode = VK_RIGHT; 2690cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2691cdf0e10cSrcweir pReplace = "Right"; 2692cdf0e10cSrcweir break; 2693cdf0e10cSrcweir case KEY_HOME: 2694cdf0e10cSrcweir nSysCode = VK_HOME; 2695cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2696cdf0e10cSrcweir pReplace = "Home"; 2697cdf0e10cSrcweir break; 2698cdf0e10cSrcweir case KEY_END: 2699cdf0e10cSrcweir nSysCode = VK_END; 2700cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2701cdf0e10cSrcweir pReplace = "End"; 2702cdf0e10cSrcweir break; 2703cdf0e10cSrcweir case KEY_PAGEUP: 2704cdf0e10cSrcweir nSysCode = VK_PRIOR; 2705cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2706cdf0e10cSrcweir pReplace = "Page Up"; 2707cdf0e10cSrcweir break; 2708cdf0e10cSrcweir case KEY_PAGEDOWN: 2709cdf0e10cSrcweir nSysCode = VK_NEXT; 2710cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2711cdf0e10cSrcweir pReplace = "Page Down"; 2712cdf0e10cSrcweir break; 2713cdf0e10cSrcweir case KEY_RETURN: 2714cdf0e10cSrcweir nSysCode = VK_RETURN; 2715cdf0e10cSrcweir pReplace = "Enter"; 2716cdf0e10cSrcweir break; 2717cdf0e10cSrcweir case KEY_ESCAPE: 2718cdf0e10cSrcweir nSysCode = VK_ESCAPE; 2719cdf0e10cSrcweir pReplace = "Escape"; 2720cdf0e10cSrcweir break; 2721cdf0e10cSrcweir case KEY_TAB: 2722cdf0e10cSrcweir nSysCode = VK_TAB; 2723cdf0e10cSrcweir pReplace = "Tab"; 2724cdf0e10cSrcweir break; 2725cdf0e10cSrcweir case KEY_BACKSPACE: 2726cdf0e10cSrcweir nSysCode = VK_BACK; 2727cdf0e10cSrcweir pReplace = "Backspace"; 2728cdf0e10cSrcweir break; 2729cdf0e10cSrcweir case KEY_SPACE: 2730cdf0e10cSrcweir nSysCode = VK_SPACE; 2731cdf0e10cSrcweir pReplace = "Space"; 2732cdf0e10cSrcweir break; 2733cdf0e10cSrcweir case KEY_INSERT: 2734cdf0e10cSrcweir nSysCode = VK_INSERT; 2735cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2736cdf0e10cSrcweir pReplace = "Insert"; 2737cdf0e10cSrcweir break; 2738cdf0e10cSrcweir case KEY_DELETE: 2739cdf0e10cSrcweir nSysCode = VK_DELETE; 2740cdf0e10cSrcweir nSysCode2 = (((sal_uLong)1) << 24); 2741cdf0e10cSrcweir pReplace = "Delete"; 2742cdf0e10cSrcweir break; 2743cdf0e10cSrcweir 2744cdf0e10cSrcweir case KEY_ADD: 2745cdf0e10cSrcweir cSVCode = '+'; 2746cdf0e10cSrcweir break; 2747cdf0e10cSrcweir case KEY_SUBTRACT: 2748cdf0e10cSrcweir cSVCode = '-'; 2749cdf0e10cSrcweir break; 2750cdf0e10cSrcweir case KEY_MULTIPLY: 2751cdf0e10cSrcweir cSVCode = '*'; 2752cdf0e10cSrcweir break; 2753cdf0e10cSrcweir case KEY_DIVIDE: 2754cdf0e10cSrcweir cSVCode = '/'; 2755cdf0e10cSrcweir break; 2756cdf0e10cSrcweir case KEY_POINT: 2757cdf0e10cSrcweir cSVCode = '.'; 2758cdf0e10cSrcweir break; 2759cdf0e10cSrcweir case KEY_COMMA: 2760cdf0e10cSrcweir cSVCode = ','; 2761cdf0e10cSrcweir break; 2762cdf0e10cSrcweir case KEY_LESS: 2763cdf0e10cSrcweir cSVCode = '<'; 2764cdf0e10cSrcweir break; 2765cdf0e10cSrcweir case KEY_GREATER: 2766cdf0e10cSrcweir cSVCode = '>'; 2767cdf0e10cSrcweir break; 2768cdf0e10cSrcweir case KEY_EQUAL: 2769cdf0e10cSrcweir cSVCode = '='; 2770cdf0e10cSrcweir break; 2771cdf0e10cSrcweir } 2772cdf0e10cSrcweir } 2773cdf0e10cSrcweir 2774cdf0e10cSrcweir if ( nSysCode ) 2775cdf0e10cSrcweir { 2776cdf0e10cSrcweir nSysCode = MapVirtualKey( (UINT)nSysCode, 0 ); 2777cdf0e10cSrcweir if ( nSysCode ) 2778cdf0e10cSrcweir nSysCode = (nSysCode << 16) | nSysCode2; 2779cdf0e10cSrcweir ImplGetKeyNameText( nSysCode, aKeyBuf, nKeyBufLen, nMaxKeyLen, pReplace ); 2780cdf0e10cSrcweir } 2781cdf0e10cSrcweir else 2782cdf0e10cSrcweir { 2783cdf0e10cSrcweir if ( cSVCode ) 2784cdf0e10cSrcweir { 2785cdf0e10cSrcweir if ( nKeyBufLen > 0 ) 2786cdf0e10cSrcweir aKeyBuf[ nKeyBufLen++ ] = '+'; 2787cdf0e10cSrcweir if( nKeyBufLen < nMaxKeyLen ) 2788cdf0e10cSrcweir aKeyBuf[ nKeyBufLen++ ] = cSVCode; 2789cdf0e10cSrcweir } 2790cdf0e10cSrcweir } 2791cdf0e10cSrcweir 2792cdf0e10cSrcweir if( !nKeyBufLen ) 2793cdf0e10cSrcweir return XubString(); 2794cdf0e10cSrcweir 2795cdf0e10cSrcweir return XubString( aKeyBuf, sal::static_int_cast< sal_uInt16 >(nKeyBufLen) ); 2796cdf0e10cSrcweir } 2797cdf0e10cSrcweir 2798cdf0e10cSrcweir // ----------------------------------------------------------------------- 2799cdf0e10cSrcweir 2800cdf0e10cSrcweir XubString WinSalFrame::GetSymbolKeyName( const XubString&, sal_uInt16 nKeyCode ) 2801cdf0e10cSrcweir { 2802cdf0e10cSrcweir return GetKeyName( nKeyCode ); 2803cdf0e10cSrcweir } 2804cdf0e10cSrcweir 2805cdf0e10cSrcweir // ----------------------------------------------------------------------- 2806cdf0e10cSrcweir 2807cdf0e10cSrcweir inline Color ImplWinColorToSal( COLORREF nColor ) 2808cdf0e10cSrcweir { 2809cdf0e10cSrcweir return Color( GetRValue( nColor ), GetGValue( nColor ), GetBValue( nColor ) ); 2810cdf0e10cSrcweir } 2811cdf0e10cSrcweir 2812cdf0e10cSrcweir // ----------------------------------------------------------------------- 2813cdf0e10cSrcweir 2814cdf0e10cSrcweir static void ImplSalUpdateStyleFontA( HDC hDC, const LOGFONTA& rLogFont, Font& rFont ) 2815cdf0e10cSrcweir { 2816cdf0e10cSrcweir ImplSalLogFontToFontA( hDC, rLogFont, rFont ); 2817cdf0e10cSrcweir 2818cdf0e10cSrcweir // On Windows 9x, Windows NT we get sometimes very small sizes 2819cdf0e10cSrcweir // (for example for the small Caption height). 2820cdf0e10cSrcweir // So if it is MS Sans Serif, a none scalable font we use 2821cdf0e10cSrcweir // 8 Point as the minimum control height, in all other cases 2822cdf0e10cSrcweir // 6 Point is the smallest one 2823cdf0e10cSrcweir if ( rFont.GetHeight() < 8 ) 2824cdf0e10cSrcweir { 2825cdf0e10cSrcweir if ( rtl_str_compareIgnoreAsciiCase( rLogFont.lfFaceName, "MS Sans Serif" ) == 0 ) 2826cdf0e10cSrcweir rFont.SetHeight( 8 ); 2827cdf0e10cSrcweir else if ( rFont.GetHeight() < 6 ) 2828cdf0e10cSrcweir rFont.SetHeight( 6 ); 2829cdf0e10cSrcweir } 2830cdf0e10cSrcweir } 2831cdf0e10cSrcweir 2832cdf0e10cSrcweir // ----------------------------------------------------------------------- 2833cdf0e10cSrcweir 2834cdf0e10cSrcweir static void ImplSalUpdateStyleFontW( HDC hDC, const LOGFONTW& rLogFont, Font& rFont ) 2835cdf0e10cSrcweir { 2836cdf0e10cSrcweir ImplSalLogFontToFontW( hDC, rLogFont, rFont ); 2837cdf0e10cSrcweir 2838cdf0e10cSrcweir // On Windows 9x, Windows NT we get sometimes very small sizes 2839cdf0e10cSrcweir // (for example for the small Caption height). 2840cdf0e10cSrcweir // So if it is MS Sans Serif, a none scalable font we use 2841cdf0e10cSrcweir // 8 Point as the minimum control height, in all other cases 2842cdf0e10cSrcweir // 6 Point is the smallest one 2843cdf0e10cSrcweir if ( rFont.GetHeight() < 8 ) 2844cdf0e10cSrcweir { 2845cdf0e10cSrcweir if ( rtl_ustr_compareIgnoreAsciiCase( reinterpret_cast<const sal_Unicode*>(rLogFont.lfFaceName), reinterpret_cast<const sal_Unicode*>(L"MS Sans Serif") ) == 0 ) 2846cdf0e10cSrcweir rFont.SetHeight( 8 ); 2847cdf0e10cSrcweir else if ( rFont.GetHeight() < 6 ) 2848cdf0e10cSrcweir rFont.SetHeight( 6 ); 2849cdf0e10cSrcweir } 2850cdf0e10cSrcweir } 2851cdf0e10cSrcweir 2852cdf0e10cSrcweir // ----------------------------------------------------------------------- 2853cdf0e10cSrcweir 2854cdf0e10cSrcweir static long ImplA2I( const BYTE* pStr ) 2855cdf0e10cSrcweir { 2856cdf0e10cSrcweir long n = 0; 2857cdf0e10cSrcweir int nSign = 1; 2858cdf0e10cSrcweir 2859cdf0e10cSrcweir if ( *pStr == '-' ) 2860cdf0e10cSrcweir { 2861cdf0e10cSrcweir nSign = -1; 2862cdf0e10cSrcweir pStr++; 2863cdf0e10cSrcweir } 2864cdf0e10cSrcweir 2865cdf0e10cSrcweir while( (*pStr >= 48) && (*pStr <= 57) ) 2866cdf0e10cSrcweir { 2867cdf0e10cSrcweir n *= 10; 2868cdf0e10cSrcweir n += ((*pStr) - 48); 2869cdf0e10cSrcweir pStr++; 2870cdf0e10cSrcweir } 2871cdf0e10cSrcweir 2872cdf0e10cSrcweir n *= nSign; 2873cdf0e10cSrcweir 2874cdf0e10cSrcweir return n; 2875cdf0e10cSrcweir } 2876cdf0e10cSrcweir 2877cdf0e10cSrcweir // ----------------------------------------------------------------------- 2878cdf0e10cSrcweir static HRESULT WINAPI backwardCompatibleDwmIsCompositionEnabled( BOOL* pOut ) 2879cdf0e10cSrcweir { 2880cdf0e10cSrcweir *pOut = FALSE; 2881cdf0e10cSrcweir return S_OK; 2882cdf0e10cSrcweir } 2883cdf0e10cSrcweir 2884cdf0e10cSrcweir static BOOL ImplDwmIsCompositionEnabled() 2885cdf0e10cSrcweir { 2886cdf0e10cSrcweir SalData* pSalData = GetSalData(); 2887cdf0e10cSrcweir if( ! pSalData->mpDwmIsCompositionEnabled ) 2888cdf0e10cSrcweir { 2889aa150a94SHerbert Dürr pSalData->maDwmLib = osl_loadAsciiModule( "Dwmapi.dll", SAL_LOADMODULE_DEFAULT ); 2890cdf0e10cSrcweir if( pSalData->maDwmLib ) 2891cdf0e10cSrcweir pSalData->mpDwmIsCompositionEnabled = (DwmIsCompositionEnabled_ptr)osl_getAsciiFunctionSymbol( pSalData->maDwmLib, "DwmIsCompositionEnabled" ); 2892cdf0e10cSrcweir if( ! pSalData->mpDwmIsCompositionEnabled ) // something failed 2893cdf0e10cSrcweir pSalData->mpDwmIsCompositionEnabled = backwardCompatibleDwmIsCompositionEnabled; 2894cdf0e10cSrcweir } 2895cdf0e10cSrcweir BOOL aResult = FALSE; 2896cdf0e10cSrcweir HRESULT nError = pSalData->mpDwmIsCompositionEnabled( &aResult ); 2897cdf0e10cSrcweir return nError == S_OK && aResult; 2898cdf0e10cSrcweir } 2899cdf0e10cSrcweir 2900cdf0e10cSrcweir 2901cdf0e10cSrcweir void WinSalFrame::UpdateSettings( AllSettings& rSettings ) 2902cdf0e10cSrcweir { 2903cdf0e10cSrcweir MouseSettings aMouseSettings = rSettings.GetMouseSettings(); 2904cdf0e10cSrcweir aMouseSettings.SetDoubleClickTime( GetDoubleClickTime() ); 2905cdf0e10cSrcweir aMouseSettings.SetDoubleClickWidth( GetSystemMetrics( SM_CXDOUBLECLK ) ); 2906cdf0e10cSrcweir aMouseSettings.SetDoubleClickHeight( GetSystemMetrics( SM_CYDOUBLECLK ) ); 2907cdf0e10cSrcweir long nDragWidth = GetSystemMetrics( SM_CXDRAG ); 2908cdf0e10cSrcweir long nDragHeight = GetSystemMetrics( SM_CYDRAG ); 2909cdf0e10cSrcweir if ( nDragWidth ) 2910cdf0e10cSrcweir aMouseSettings.SetStartDragWidth( nDragWidth ); 2911cdf0e10cSrcweir if ( nDragHeight ) 2912cdf0e10cSrcweir aMouseSettings.SetStartDragHeight( nDragHeight ); 2913cdf0e10cSrcweir HKEY hRegKey; 2914cdf0e10cSrcweir if ( RegOpenKey( HKEY_CURRENT_USER, 2915cdf0e10cSrcweir "Control Panel\\Desktop", 2916cdf0e10cSrcweir &hRegKey ) == ERROR_SUCCESS ) 2917cdf0e10cSrcweir { 2918cdf0e10cSrcweir BYTE aValueBuf[10]; 2919cdf0e10cSrcweir DWORD nValueSize = sizeof( aValueBuf ); 2920cdf0e10cSrcweir DWORD nType; 2921cdf0e10cSrcweir if ( RegQueryValueEx( hRegKey, "MenuShowDelay", 0, 2922cdf0e10cSrcweir &nType, aValueBuf, &nValueSize ) == ERROR_SUCCESS ) 2923cdf0e10cSrcweir { 2924cdf0e10cSrcweir if ( nType == REG_SZ ) 2925cdf0e10cSrcweir aMouseSettings.SetMenuDelay( (sal_uLong)ImplA2I( aValueBuf ) ); 2926cdf0e10cSrcweir } 2927cdf0e10cSrcweir 2928cdf0e10cSrcweir RegCloseKey( hRegKey ); 2929cdf0e10cSrcweir } 2930cdf0e10cSrcweir 2931cdf0e10cSrcweir StyleSettings aStyleSettings = rSettings.GetStyleSettings(); 2932cdf0e10cSrcweir // TODO: once those options vanish: just set bCompBorder to TRUE 2933cdf0e10cSrcweir // to have the system colors read 2934cdf0e10cSrcweir aStyleSettings.SetScrollBarSize( GetSystemMetrics( SM_CXVSCROLL ) ); 2935cdf0e10cSrcweir aStyleSettings.SetSpinSize( GetSystemMetrics( SM_CXVSCROLL ) ); 2936cdf0e10cSrcweir aStyleSettings.SetCursorBlinkTime( GetCaretBlinkTime() ); 2937cdf0e10cSrcweir aStyleSettings.SetFloatTitleHeight( GetSystemMetrics( SM_CYSMCAPTION ) ); 2938cdf0e10cSrcweir aStyleSettings.SetTitleHeight( GetSystemMetrics( SM_CYCAPTION ) ); 2939cdf0e10cSrcweir aStyleSettings.SetActiveBorderColor( ImplWinColorToSal( GetSysColor( COLOR_ACTIVEBORDER ) ) ); 2940cdf0e10cSrcweir aStyleSettings.SetDeactiveBorderColor( ImplWinColorToSal( GetSysColor( COLOR_INACTIVEBORDER ) ) ); 2941cdf0e10cSrcweir if ( aSalShlData.mnVersion >= 410 ) 2942cdf0e10cSrcweir { 2943cdf0e10cSrcweir aStyleSettings.SetActiveColor2( ImplWinColorToSal( GetSysColor( COLOR_GRADIENTACTIVECAPTION ) ) ); 2944cdf0e10cSrcweir aStyleSettings.SetDeactiveColor( ImplWinColorToSal( GetSysColor( COLOR_GRADIENTINACTIVECAPTION ) ) ); 2945cdf0e10cSrcweir } 2946cdf0e10cSrcweir aStyleSettings.SetFaceColor( ImplWinColorToSal( GetSysColor( COLOR_3DFACE ) ) ); 2947cdf0e10cSrcweir aStyleSettings.SetInactiveTabColor( aStyleSettings.GetFaceColor() ); 2948cdf0e10cSrcweir aStyleSettings.SetLightColor( ImplWinColorToSal( GetSysColor( COLOR_3DHILIGHT ) ) ); 2949cdf0e10cSrcweir aStyleSettings.SetLightBorderColor( ImplWinColorToSal( GetSysColor( COLOR_3DLIGHT ) ) ); 2950cdf0e10cSrcweir aStyleSettings.SetShadowColor( ImplWinColorToSal( GetSysColor( COLOR_3DSHADOW ) ) ); 2951cdf0e10cSrcweir aStyleSettings.SetDarkShadowColor( ImplWinColorToSal( GetSysColor( COLOR_3DDKSHADOW ) ) ); 2952cdf0e10cSrcweir aStyleSettings.SetWorkspaceColor( ImplWinColorToSal( GetSysColor( COLOR_APPWORKSPACE ) ) ); 2953cdf0e10cSrcweir aStyleSettings.SetHelpColor( ImplWinColorToSal( GetSysColor( COLOR_INFOBK ) ) ); 2954cdf0e10cSrcweir aStyleSettings.SetHelpTextColor( ImplWinColorToSal( GetSysColor( COLOR_INFOTEXT ) ) ); 2955cdf0e10cSrcweir aStyleSettings.SetDialogColor( aStyleSettings.GetFaceColor() ); 2956cdf0e10cSrcweir aStyleSettings.SetDialogTextColor( aStyleSettings.GetButtonTextColor() ); 2957cdf0e10cSrcweir aStyleSettings.SetButtonTextColor( ImplWinColorToSal( GetSysColor( COLOR_BTNTEXT ) ) ); 2958cdf0e10cSrcweir aStyleSettings.SetButtonRolloverTextColor( aStyleSettings.GetButtonTextColor() ); 2959cdf0e10cSrcweir aStyleSettings.SetRadioCheckTextColor( ImplWinColorToSal( GetSysColor( COLOR_WINDOWTEXT ) ) ); 2960cdf0e10cSrcweir aStyleSettings.SetGroupTextColor( aStyleSettings.GetRadioCheckTextColor() ); 2961cdf0e10cSrcweir aStyleSettings.SetLabelTextColor( aStyleSettings.GetRadioCheckTextColor() ); 2962cdf0e10cSrcweir aStyleSettings.SetInfoTextColor( aStyleSettings.GetRadioCheckTextColor() ); 2963cdf0e10cSrcweir aStyleSettings.SetWindowColor( ImplWinColorToSal( GetSysColor( COLOR_WINDOW ) ) ); 2964cdf0e10cSrcweir aStyleSettings.SetActiveTabColor( aStyleSettings.GetWindowColor() ); 2965cdf0e10cSrcweir aStyleSettings.SetWindowTextColor( ImplWinColorToSal( GetSysColor( COLOR_WINDOWTEXT ) ) ); 2966cdf0e10cSrcweir aStyleSettings.SetFieldColor( aStyleSettings.GetWindowColor() ); 2967cdf0e10cSrcweir aStyleSettings.SetFieldTextColor( aStyleSettings.GetWindowTextColor() ); 2968cdf0e10cSrcweir aStyleSettings.SetFieldRolloverTextColor( aStyleSettings.GetFieldTextColor() ); 2969cdf0e10cSrcweir aStyleSettings.SetHighlightColor( ImplWinColorToSal( GetSysColor( COLOR_HIGHLIGHT ) ) ); 2970cdf0e10cSrcweir aStyleSettings.SetHighlightTextColor( ImplWinColorToSal( GetSysColor( COLOR_HIGHLIGHTTEXT ) ) ); 2971cdf0e10cSrcweir aStyleSettings.SetMenuHighlightColor( aStyleSettings.GetHighlightColor() ); 2972cdf0e10cSrcweir aStyleSettings.SetMenuHighlightTextColor( aStyleSettings.GetHighlightTextColor() ); 2973cdf0e10cSrcweir 2974cdf0e10cSrcweir ImplSVData* pSVData = ImplGetSVData(); 2975cdf0e10cSrcweir pSVData->maNWFData.mnMenuFormatExtraBorder = 0; 2976cdf0e10cSrcweir pSVData->maNWFData.maMenuBarHighlightTextColor = Color( COL_TRANSPARENT ); 2977cdf0e10cSrcweir GetSalData()->mbThemeMenuSupport = FALSE; 2978cdf0e10cSrcweir aStyleSettings.SetMenuColor( ImplWinColorToSal( GetSysColor( COLOR_MENU ) ) ); 2979cdf0e10cSrcweir aStyleSettings.SetMenuBarColor( aStyleSettings.GetMenuColor() ); 2980cdf0e10cSrcweir aStyleSettings.SetMenuBorderColor( aStyleSettings.GetLightBorderColor() ); // overriden below for flat menus 2981cdf0e10cSrcweir aStyleSettings.SetUseFlatBorders( FALSE ); 2982cdf0e10cSrcweir aStyleSettings.SetUseFlatMenues( FALSE ); 2983cdf0e10cSrcweir aStyleSettings.SetMenuTextColor( ImplWinColorToSal( GetSysColor( COLOR_MENUTEXT ) ) ); 2984cdf0e10cSrcweir aStyleSettings.SetMenuBarTextColor( ImplWinColorToSal( GetSysColor( COLOR_MENUTEXT ) ) ); 2985cdf0e10cSrcweir aStyleSettings.SetActiveColor( ImplWinColorToSal( GetSysColor( COLOR_ACTIVECAPTION ) ) ); 2986cdf0e10cSrcweir aStyleSettings.SetActiveTextColor( ImplWinColorToSal( GetSysColor( COLOR_CAPTIONTEXT ) ) ); 2987cdf0e10cSrcweir aStyleSettings.SetDeactiveColor( ImplWinColorToSal( GetSysColor( COLOR_INACTIVECAPTION ) ) ); 2988cdf0e10cSrcweir aStyleSettings.SetDeactiveTextColor( ImplWinColorToSal( GetSysColor( COLOR_INACTIVECAPTIONTEXT ) ) ); 2989cdf0e10cSrcweir if ( aSalShlData.mbWXP ) 2990cdf0e10cSrcweir { 2991cdf0e10cSrcweir // only xp supports a different menu bar color 2992cdf0e10cSrcweir long bFlatMenues = 0; 2993cdf0e10cSrcweir SystemParametersInfo( SPI_GETFLATMENU, 0, &bFlatMenues, 0); 2994cdf0e10cSrcweir if( bFlatMenues ) 2995cdf0e10cSrcweir { 2996cdf0e10cSrcweir aStyleSettings.SetUseFlatMenues( TRUE ); 2997cdf0e10cSrcweir aStyleSettings.SetMenuBarColor( ImplWinColorToSal( GetSysColor( COLOR_MENUBAR ) ) ); 2998cdf0e10cSrcweir aStyleSettings.SetMenuHighlightColor( ImplWinColorToSal( GetSysColor( COLOR_MENUHILIGHT ) ) ); 2999cdf0e10cSrcweir aStyleSettings.SetMenuBorderColor( ImplWinColorToSal( GetSysColor( COLOR_3DSHADOW ) ) ); 3000cdf0e10cSrcweir 3001cdf0e10cSrcweir // flat borders for our controls etc. as well in this mode (ie, no 3d borders) 3002cdf0e10cSrcweir // this is not active in the classic style appearance 3003cdf0e10cSrcweir aStyleSettings.SetUseFlatBorders( TRUE ); 3004cdf0e10cSrcweir } 3005cdf0e10cSrcweir } 3006cdf0e10cSrcweir // check if vista or newer runs 3007cdf0e10cSrcweir // in Aero theme (and similar ?) the menu text color does not change 3008cdf0e10cSrcweir // for selected items; also on WinXP and earlier menus are not themed 3009cdf0e10cSrcweir if( aSalShlData.maVersionInfo.dwMajorVersion >= 6 && 3010cdf0e10cSrcweir ImplDwmIsCompositionEnabled() 3011cdf0e10cSrcweir ) 3012cdf0e10cSrcweir { 3013cdf0e10cSrcweir // in aero menuitem highlight text is drawn in the same color as normal 3014cdf0e10cSrcweir aStyleSettings.SetMenuHighlightTextColor( aStyleSettings.GetMenuTextColor() ); 3015cdf0e10cSrcweir pSVData->maNWFData.mnMenuFormatExtraBorder = 2; 3016cdf0e10cSrcweir pSVData->maNWFData.maMenuBarHighlightTextColor = aStyleSettings.GetMenuTextColor(); 3017cdf0e10cSrcweir GetSalData()->mbThemeMenuSupport = TRUE; 3018cdf0e10cSrcweir } 3019cdf0e10cSrcweir // Bei hellgrau geben wir die Farbe vor, damit es besser aussieht 3020cdf0e10cSrcweir if ( aStyleSettings.GetFaceColor() == COL_LIGHTGRAY ) 3021cdf0e10cSrcweir aStyleSettings.SetCheckedColor( Color( 0xCC, 0xCC, 0xCC ) ); 3022cdf0e10cSrcweir else 3023cdf0e10cSrcweir { 3024cdf0e10cSrcweir // Checked-Color berechnen 3025cdf0e10cSrcweir Color aColor1 = aStyleSettings.GetFaceColor(); 3026cdf0e10cSrcweir Color aColor2 = aStyleSettings.GetLightColor(); 3027cdf0e10cSrcweir BYTE nRed = (BYTE)(((sal_uInt16)aColor1.GetRed() + (sal_uInt16)aColor2.GetRed())/2); 3028cdf0e10cSrcweir BYTE nGreen = (BYTE)(((sal_uInt16)aColor1.GetGreen() + (sal_uInt16)aColor2.GetGreen())/2); 3029cdf0e10cSrcweir BYTE nBlue = (BYTE)(((sal_uInt16)aColor1.GetBlue() + (sal_uInt16)aColor2.GetBlue())/2); 3030cdf0e10cSrcweir aStyleSettings.SetCheckedColor( Color( nRed, nGreen, nBlue ) ); 3031cdf0e10cSrcweir } 3032cdf0e10cSrcweir 3033cdf0e10cSrcweir // caret width 3034cdf0e10cSrcweir DWORD nCaretWidth = 2; 3035cdf0e10cSrcweir if( SystemParametersInfo( SPI_GETCARETWIDTH, 0, &nCaretWidth, 0 ) ) 3036cdf0e10cSrcweir aStyleSettings.SetCursorSize( nCaretWidth ); 3037cdf0e10cSrcweir 3038cdf0e10cSrcweir // High contrast 3039cdf0e10cSrcweir HIGHCONTRAST hc; 3040cdf0e10cSrcweir hc.cbSize = sizeof( HIGHCONTRAST ); 3041cdf0e10cSrcweir if( SystemParametersInfo( SPI_GETHIGHCONTRAST, hc.cbSize, &hc, 0) && (hc.dwFlags & HCF_HIGHCONTRASTON) ) 3042cdf0e10cSrcweir aStyleSettings.SetHighContrastMode( 1 ); 3043cdf0e10cSrcweir else 3044cdf0e10cSrcweir aStyleSettings.SetHighContrastMode( 0 ); 3045cdf0e10cSrcweir 3046cdf0e10cSrcweir 3047cdf0e10cSrcweir // Query Fonts 3048cdf0e10cSrcweir Font aMenuFont = aStyleSettings.GetMenuFont(); 3049cdf0e10cSrcweir Font aTitleFont = aStyleSettings.GetTitleFont(); 3050cdf0e10cSrcweir Font aFloatTitleFont = aStyleSettings.GetFloatTitleFont(); 3051cdf0e10cSrcweir Font aHelpFont = aStyleSettings.GetHelpFont(); 3052cdf0e10cSrcweir Font aAppFont = aStyleSettings.GetAppFont(); 3053cdf0e10cSrcweir Font aIconFont = aStyleSettings.GetIconFont(); 3054cdf0e10cSrcweir HDC hDC = GetDC( 0 ); 3055cdf0e10cSrcweir if( true/*aSalShlData.mbWNT*/ ) 3056cdf0e10cSrcweir { 3057cdf0e10cSrcweir NONCLIENTMETRICSW aNonClientMetrics; 3058cdf0e10cSrcweir aNonClientMetrics.cbSize = sizeof( aNonClientMetrics ); 3059cdf0e10cSrcweir if ( SystemParametersInfoW( SPI_GETNONCLIENTMETRICS, sizeof( aNonClientMetrics ), &aNonClientMetrics, 0 ) ) 3060cdf0e10cSrcweir { 3061cdf0e10cSrcweir ImplSalUpdateStyleFontW( hDC, aNonClientMetrics.lfMenuFont, aMenuFont ); 3062cdf0e10cSrcweir ImplSalUpdateStyleFontW( hDC, aNonClientMetrics.lfCaptionFont, aTitleFont ); 3063cdf0e10cSrcweir ImplSalUpdateStyleFontW( hDC, aNonClientMetrics.lfSmCaptionFont, aFloatTitleFont ); 3064cdf0e10cSrcweir ImplSalUpdateStyleFontW( hDC, aNonClientMetrics.lfStatusFont, aHelpFont ); 3065cdf0e10cSrcweir ImplSalUpdateStyleFontW( hDC, aNonClientMetrics.lfMessageFont, aAppFont ); 3066cdf0e10cSrcweir 3067cdf0e10cSrcweir LOGFONTW aLogFont; 3068cdf0e10cSrcweir if ( SystemParametersInfoW( SPI_GETICONTITLELOGFONT, 0, &aLogFont, 0 ) ) 3069cdf0e10cSrcweir ImplSalUpdateStyleFontW( hDC, aLogFont, aIconFont ); 3070cdf0e10cSrcweir } 3071cdf0e10cSrcweir } 3072cdf0e10cSrcweir 3073cdf0e10cSrcweir // get screen font resolution to calculate toolbox item size 3074cdf0e10cSrcweir long nDPIY = GetDeviceCaps( hDC, LOGPIXELSY ); 3075cdf0e10cSrcweir 3076cdf0e10cSrcweir ReleaseDC( 0, hDC ); 3077cdf0e10cSrcweir 3078cdf0e10cSrcweir long nHeightPx = aMenuFont.GetHeight() * nDPIY / 72; 3079cdf0e10cSrcweir aStyleSettings.SetToolbarIconSize( (((nHeightPx-1)*2) >= 28) ? STYLE_TOOLBAR_ICONSIZE_LARGE : STYLE_TOOLBAR_ICONSIZE_SMALL ); 3080cdf0e10cSrcweir 3081cdf0e10cSrcweir aStyleSettings.SetMenuFont( aMenuFont ); 3082cdf0e10cSrcweir aStyleSettings.SetTitleFont( aTitleFont ); 3083cdf0e10cSrcweir aStyleSettings.SetFloatTitleFont( aFloatTitleFont ); 3084cdf0e10cSrcweir aStyleSettings.SetHelpFont( aHelpFont ); 3085cdf0e10cSrcweir aStyleSettings.SetIconFont( aIconFont ); 3086cdf0e10cSrcweir // We prefer Arial in the russian version, because MS Sans Serif 3087cdf0e10cSrcweir // is to wide for the dialogs 3088cdf0e10cSrcweir if ( rSettings.GetLanguage() == LANGUAGE_RUSSIAN ) 3089cdf0e10cSrcweir { 3090cdf0e10cSrcweir XubString aFontName = aAppFont.GetName(); 3091cdf0e10cSrcweir XubString aFirstName = aFontName.GetToken( 0, ';' ); 3092cdf0e10cSrcweir if ( aFirstName.EqualsIgnoreCaseAscii( "MS Sans Serif" ) ) 3093cdf0e10cSrcweir { 3094cdf0e10cSrcweir aFontName.InsertAscii( "Arial;", 0 ); 3095cdf0e10cSrcweir aAppFont.SetName( aFontName ); 3096cdf0e10cSrcweir } 3097cdf0e10cSrcweir } 3098cdf0e10cSrcweir aStyleSettings.SetAppFont( aAppFont ); 3099cdf0e10cSrcweir aStyleSettings.SetGroupFont( aAppFont ); 3100cdf0e10cSrcweir aStyleSettings.SetLabelFont( aAppFont ); 3101cdf0e10cSrcweir aStyleSettings.SetRadioCheckFont( aAppFont ); 3102cdf0e10cSrcweir aStyleSettings.SetPushButtonFont( aAppFont ); 3103cdf0e10cSrcweir aStyleSettings.SetFieldFont( aAppFont ); 3104cdf0e10cSrcweir if ( aAppFont.GetWeight() > WEIGHT_NORMAL ) 3105cdf0e10cSrcweir aAppFont.SetWeight( WEIGHT_NORMAL ); 3106cdf0e10cSrcweir aStyleSettings.SetInfoFont( aAppFont ); 3107cdf0e10cSrcweir aStyleSettings.SetToolFont( aAppFont ); 3108cdf0e10cSrcweir 3109cdf0e10cSrcweir BOOL bDragFull; 3110cdf0e10cSrcweir if ( SystemParametersInfo( SPI_GETDRAGFULLWINDOWS, 0, &bDragFull, 0 ) ) 3111cdf0e10cSrcweir { 3112cdf0e10cSrcweir sal_uLong nDragFullOptions = aStyleSettings.GetDragFullOptions(); 3113cdf0e10cSrcweir if ( bDragFull ) 3114cdf0e10cSrcweir nDragFullOptions |= DRAGFULL_OPTION_WINDOWMOVE | DRAGFULL_OPTION_WINDOWSIZE | DRAGFULL_OPTION_DOCKING | DRAGFULL_OPTION_SPLIT; 3115cdf0e10cSrcweir else 3116cdf0e10cSrcweir nDragFullOptions &= ~(DRAGFULL_OPTION_WINDOWMOVE | DRAGFULL_OPTION_WINDOWSIZE | DRAGFULL_OPTION_DOCKING | DRAGFULL_OPTION_SPLIT); 3117cdf0e10cSrcweir aStyleSettings.SetDragFullOptions( nDragFullOptions ); 3118cdf0e10cSrcweir } 3119cdf0e10cSrcweir 3120cdf0e10cSrcweir aStyleSettings.SetIconHorzSpace( GetSystemMetrics( SM_CXICONSPACING ) ); 3121cdf0e10cSrcweir aStyleSettings.SetIconVertSpace( GetSystemMetrics( SM_CYICONSPACING ) ); 3122cdf0e10cSrcweir if ( RegOpenKey( HKEY_CURRENT_USER, 3123cdf0e10cSrcweir "Control Panel\\International\\Calendars\\TwoDigitYearMax", 3124cdf0e10cSrcweir &hRegKey ) == ERROR_SUCCESS ) 3125cdf0e10cSrcweir { 3126cdf0e10cSrcweir BYTE aValueBuf[10]; 3127cdf0e10cSrcweir DWORD nValue; 3128cdf0e10cSrcweir DWORD nValueSize = sizeof( aValueBuf ); 3129cdf0e10cSrcweir DWORD nType; 3130cdf0e10cSrcweir if ( RegQueryValueEx( hRegKey, "1", 0, 3131cdf0e10cSrcweir &nType, aValueBuf, &nValueSize ) == ERROR_SUCCESS ) 3132cdf0e10cSrcweir { 3133cdf0e10cSrcweir if ( nType == REG_SZ ) 3134cdf0e10cSrcweir { 3135cdf0e10cSrcweir nValue = (sal_uLong)ImplA2I( aValueBuf ); 3136cdf0e10cSrcweir if ( (nValue > 1000) && (nValue < 10000) ) 3137cdf0e10cSrcweir { 3138cdf0e10cSrcweir MiscSettings aMiscSettings = rSettings.GetMiscSettings(); 3139cdf0e10cSrcweir utl::MiscCfg().SetYear2000( (sal_Int32)(nValue-99) ); 3140cdf0e10cSrcweir rSettings.SetMiscSettings( aMiscSettings ); 3141cdf0e10cSrcweir } 3142cdf0e10cSrcweir } 3143cdf0e10cSrcweir } 3144cdf0e10cSrcweir 3145cdf0e10cSrcweir RegCloseKey( hRegKey ); 3146cdf0e10cSrcweir } 3147cdf0e10cSrcweir 3148cdf0e10cSrcweir rSettings.SetMouseSettings( aMouseSettings ); 3149cdf0e10cSrcweir rSettings.SetStyleSettings( aStyleSettings ); 3150cdf0e10cSrcweir } 3151cdf0e10cSrcweir 3152cdf0e10cSrcweir // ----------------------------------------------------------------------- 3153cdf0e10cSrcweir 3154cdf0e10cSrcweir SalBitmap* WinSalFrame::SnapShot() 3155cdf0e10cSrcweir { 3156cdf0e10cSrcweir WinSalBitmap* pSalBitmap = NULL; 3157cdf0e10cSrcweir 3158cdf0e10cSrcweir RECT aRect; 3159cdf0e10cSrcweir GetWindowRect( mhWnd, &aRect ); 3160cdf0e10cSrcweir 3161cdf0e10cSrcweir int nDX = aRect.right-aRect.left; 3162cdf0e10cSrcweir int nDY = aRect.bottom-aRect.top; 3163cdf0e10cSrcweir HDC hDC = GetWindowDC( mhWnd ); 3164cdf0e10cSrcweir HBITMAP hBmpBitmap = CreateCompatibleBitmap( hDC, nDX, nDY ); 3165cdf0e10cSrcweir HDC hBmpDC = ImplGetCachedDC( CACHED_HDC_1, hBmpBitmap ); 3166cdf0e10cSrcweir sal_Bool bRet; 3167cdf0e10cSrcweir 3168cdf0e10cSrcweir bRet = BitBlt( hBmpDC, 0, 0, nDX, nDY, hDC, 0, 0, SRCCOPY ) ? TRUE : FALSE; 3169cdf0e10cSrcweir ImplReleaseCachedDC( CACHED_HDC_1 ); 3170cdf0e10cSrcweir 3171cdf0e10cSrcweir if ( bRet ) 3172cdf0e10cSrcweir { 3173cdf0e10cSrcweir pSalBitmap = new WinSalBitmap; 3174cdf0e10cSrcweir 3175cdf0e10cSrcweir if ( !pSalBitmap->Create( hBmpBitmap, FALSE, FALSE ) ) 3176cdf0e10cSrcweir { 3177cdf0e10cSrcweir delete pSalBitmap; 3178cdf0e10cSrcweir pSalBitmap = NULL; 3179cdf0e10cSrcweir } 3180cdf0e10cSrcweir } 3181cdf0e10cSrcweir 3182cdf0e10cSrcweir return pSalBitmap; 3183cdf0e10cSrcweir } 3184cdf0e10cSrcweir 3185cdf0e10cSrcweir // ----------------------------------------------------------------------- 3186cdf0e10cSrcweir 3187cdf0e10cSrcweir const SystemEnvData* WinSalFrame::GetSystemData() const 3188cdf0e10cSrcweir { 3189cdf0e10cSrcweir return &maSysData; 3190cdf0e10cSrcweir } 3191cdf0e10cSrcweir 3192cdf0e10cSrcweir // ----------------------------------------------------------------------- 3193cdf0e10cSrcweir 3194cdf0e10cSrcweir void WinSalFrame::Beep( SoundType eSoundType ) 3195cdf0e10cSrcweir { 3196cdf0e10cSrcweir static UINT aImplSoundTab[5] = 3197cdf0e10cSrcweir { 3198cdf0e10cSrcweir 0, // SOUND_DEFAULT 3199cdf0e10cSrcweir MB_ICONASTERISK, // SOUND_INFO 3200cdf0e10cSrcweir MB_ICONEXCLAMATION, // SOUND_WARNING 3201cdf0e10cSrcweir MB_ICONHAND, // SOUND_ERROR 3202cdf0e10cSrcweir MB_ICONQUESTION // SOUND_QUERY 3203cdf0e10cSrcweir }; 3204cdf0e10cSrcweir 3205cdf0e10cSrcweir if( eSoundType != SOUND_DISABLE ) // don't beep on disable 3206cdf0e10cSrcweir MessageBeep( aImplSoundTab[eSoundType] ); 3207cdf0e10cSrcweir } 3208cdf0e10cSrcweir 3209cdf0e10cSrcweir // ----------------------------------------------------------------------- 3210cdf0e10cSrcweir 3211cdf0e10cSrcweir SalFrame::SalPointerState WinSalFrame::GetPointerState() 3212cdf0e10cSrcweir { 3213cdf0e10cSrcweir SalPointerState aState; 3214cdf0e10cSrcweir aState.mnState = 0; 3215cdf0e10cSrcweir 3216cdf0e10cSrcweir if ( GetKeyState( VK_LBUTTON ) & 0x8000 ) 3217cdf0e10cSrcweir aState.mnState |= MOUSE_LEFT; 3218cdf0e10cSrcweir if ( GetKeyState( VK_MBUTTON ) & 0x8000 ) 3219cdf0e10cSrcweir aState.mnState |= MOUSE_MIDDLE; 3220cdf0e10cSrcweir if ( GetKeyState( VK_RBUTTON ) & 0x8000 ) 3221cdf0e10cSrcweir aState.mnState |= MOUSE_RIGHT; 3222cdf0e10cSrcweir if ( GetKeyState( VK_SHIFT ) & 0x8000 ) 3223cdf0e10cSrcweir aState.mnState |= KEY_SHIFT; 3224cdf0e10cSrcweir if ( GetKeyState( VK_CONTROL ) & 0x8000 ) 3225cdf0e10cSrcweir aState.mnState |= KEY_MOD1; 3226cdf0e10cSrcweir if ( GetKeyState( VK_MENU ) & 0x8000 ) 3227cdf0e10cSrcweir aState.mnState |= KEY_MOD2; 3228cdf0e10cSrcweir 3229cdf0e10cSrcweir POINT pt; 3230cdf0e10cSrcweir GetCursorPos( &pt ); 3231cdf0e10cSrcweir 3232cdf0e10cSrcweir aState.maPos = Point( pt.x - maGeometry.nX, pt.y - maGeometry.nY ); 3233cdf0e10cSrcweir return aState; 3234cdf0e10cSrcweir } 3235cdf0e10cSrcweir 3236cdf0e10cSrcweir // ----------------------------------------------------------------------- 3237cdf0e10cSrcweir 3238cdf0e10cSrcweir void WinSalFrame::SetBackgroundBitmap( SalBitmap* ) 3239cdf0e10cSrcweir { 3240cdf0e10cSrcweir } 3241cdf0e10cSrcweir 3242cdf0e10cSrcweir // ----------------------------------------------------------------------- 3243cdf0e10cSrcweir 3244cdf0e10cSrcweir void WinSalFrame::ResetClipRegion() 3245cdf0e10cSrcweir { 3246cdf0e10cSrcweir SetWindowRgn( mhWnd, 0, TRUE ); 3247cdf0e10cSrcweir } 3248cdf0e10cSrcweir 3249cdf0e10cSrcweir // ----------------------------------------------------------------------- 3250cdf0e10cSrcweir 3251cdf0e10cSrcweir void WinSalFrame::BeginSetClipRegion( sal_uLong nRects ) 3252cdf0e10cSrcweir { 3253cdf0e10cSrcweir if( mpClipRgnData ) 3254cdf0e10cSrcweir delete [] (BYTE*)mpClipRgnData; 3255cdf0e10cSrcweir sal_uLong nRectBufSize = sizeof(RECT)*nRects; 3256cdf0e10cSrcweir mpClipRgnData = (RGNDATA*)new BYTE[sizeof(RGNDATA)-1+nRectBufSize]; 3257cdf0e10cSrcweir mpClipRgnData->rdh.dwSize = sizeof( RGNDATAHEADER ); 3258cdf0e10cSrcweir mpClipRgnData->rdh.iType = RDH_RECTANGLES; 3259cdf0e10cSrcweir mpClipRgnData->rdh.nCount = nRects; 3260cdf0e10cSrcweir mpClipRgnData->rdh.nRgnSize = nRectBufSize; 3261cdf0e10cSrcweir SetRectEmpty( &(mpClipRgnData->rdh.rcBound) ); 3262cdf0e10cSrcweir mpNextClipRect = (RECT*)(&(mpClipRgnData->Buffer)); 3263cdf0e10cSrcweir mbFirstClipRect = TRUE; 3264cdf0e10cSrcweir } 3265cdf0e10cSrcweir 3266cdf0e10cSrcweir // ----------------------------------------------------------------------- 3267cdf0e10cSrcweir 3268cdf0e10cSrcweir void WinSalFrame::UnionClipRegion( long nX, long nY, long nWidth, long nHeight ) 3269cdf0e10cSrcweir { 3270cdf0e10cSrcweir if( ! mpClipRgnData ) 3271cdf0e10cSrcweir return; 3272cdf0e10cSrcweir 3273cdf0e10cSrcweir RECT* pRect = mpNextClipRect; 3274cdf0e10cSrcweir RECT* pBoundRect = &(mpClipRgnData->rdh.rcBound); 3275cdf0e10cSrcweir long nRight = nX + nWidth; 3276cdf0e10cSrcweir long nBottom = nY + nHeight; 3277cdf0e10cSrcweir 3278cdf0e10cSrcweir if ( mbFirstClipRect ) 3279cdf0e10cSrcweir { 3280cdf0e10cSrcweir pBoundRect->left = nX; 3281cdf0e10cSrcweir pBoundRect->top = nY; 3282cdf0e10cSrcweir pBoundRect->right = nRight; 3283cdf0e10cSrcweir pBoundRect->bottom = nBottom; 3284cdf0e10cSrcweir mbFirstClipRect = FALSE; 3285cdf0e10cSrcweir } 3286cdf0e10cSrcweir else 3287cdf0e10cSrcweir { 3288cdf0e10cSrcweir if ( nX < pBoundRect->left ) 3289cdf0e10cSrcweir pBoundRect->left = (int)nX; 3290cdf0e10cSrcweir 3291cdf0e10cSrcweir if ( nY < pBoundRect->top ) 3292cdf0e10cSrcweir pBoundRect->top = (int)nY; 3293cdf0e10cSrcweir 3294cdf0e10cSrcweir if ( nRight > pBoundRect->right ) 3295cdf0e10cSrcweir pBoundRect->right = (int)nRight; 3296cdf0e10cSrcweir 3297cdf0e10cSrcweir if ( nBottom > pBoundRect->bottom ) 3298cdf0e10cSrcweir pBoundRect->bottom = (int)nBottom; 3299cdf0e10cSrcweir } 3300cdf0e10cSrcweir 3301cdf0e10cSrcweir pRect->left = (int)nX; 3302cdf0e10cSrcweir pRect->top = (int)nY; 3303cdf0e10cSrcweir pRect->right = (int)nRight; 3304cdf0e10cSrcweir pRect->bottom = (int)nBottom; 3305cdf0e10cSrcweir if( (mpNextClipRect - (RECT*)(&mpClipRgnData->Buffer)) < (int)mpClipRgnData->rdh.nCount ) 3306cdf0e10cSrcweir mpNextClipRect++; 3307cdf0e10cSrcweir } 3308cdf0e10cSrcweir 3309cdf0e10cSrcweir // ----------------------------------------------------------------------- 3310cdf0e10cSrcweir 3311cdf0e10cSrcweir void WinSalFrame::EndSetClipRegion() 3312cdf0e10cSrcweir { 3313cdf0e10cSrcweir if( ! mpClipRgnData ) 3314cdf0e10cSrcweir return; 3315cdf0e10cSrcweir 3316cdf0e10cSrcweir HRGN hRegion; 3317cdf0e10cSrcweir 3318cdf0e10cSrcweir // create region from accumulated rectangles 3319cdf0e10cSrcweir if ( mpClipRgnData->rdh.nCount == 1 ) 3320cdf0e10cSrcweir { 3321cdf0e10cSrcweir RECT* pRect = &(mpClipRgnData->rdh.rcBound); 3322cdf0e10cSrcweir hRegion = CreateRectRgn( pRect->left, pRect->top, 3323cdf0e10cSrcweir pRect->right, pRect->bottom ); 3324cdf0e10cSrcweir } 3325cdf0e10cSrcweir else 3326cdf0e10cSrcweir { 3327cdf0e10cSrcweir sal_uLong nSize = mpClipRgnData->rdh.nRgnSize+sizeof(RGNDATAHEADER); 3328cdf0e10cSrcweir hRegion = ExtCreateRegion( NULL, nSize, mpClipRgnData ); 3329cdf0e10cSrcweir } 3330cdf0e10cSrcweir delete [] (BYTE*)mpClipRgnData; 3331cdf0e10cSrcweir mpClipRgnData = NULL; 3332cdf0e10cSrcweir 3333cdf0e10cSrcweir DBG_ASSERT( hRegion, "WinSalFrame::EndSetClipRegion() - Can't create ClipRegion" ); 3334cdf0e10cSrcweir if( hRegion ) 3335cdf0e10cSrcweir { 3336cdf0e10cSrcweir RECT aWindowRect; 3337cdf0e10cSrcweir GetWindowRect( mhWnd, &aWindowRect ); 3338cdf0e10cSrcweir POINT aPt; 3339cdf0e10cSrcweir aPt.x=0; 3340cdf0e10cSrcweir aPt.y=0; 3341cdf0e10cSrcweir ClientToScreen( mhWnd, &aPt ); 3342cdf0e10cSrcweir OffsetRgn( hRegion, aPt.x - aWindowRect.left, aPt.y - aWindowRect.top ); 3343cdf0e10cSrcweir 3344cdf0e10cSrcweir if( SetWindowRgn( mhWnd, hRegion, TRUE ) == 0 ) 3345cdf0e10cSrcweir DeleteObject( hRegion ); 3346cdf0e10cSrcweir } 3347cdf0e10cSrcweir } 3348cdf0e10cSrcweir 3349cdf0e10cSrcweir // ----------------------------------------------------------------------- 3350cdf0e10cSrcweir 3351cdf0e10cSrcweir static long ImplHandleMouseMsg( HWND hWnd, UINT nMsg, 3352cdf0e10cSrcweir WPARAM wParam, LPARAM lParam ) 3353cdf0e10cSrcweir { 3354cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 3355cdf0e10cSrcweir if ( !pFrame ) 3356cdf0e10cSrcweir return 0; 3357cdf0e10cSrcweir 3358cdf0e10cSrcweir if( nMsg == WM_LBUTTONDOWN || nMsg == WM_MBUTTONDOWN || nMsg == WM_RBUTTONDOWN ) 3359cdf0e10cSrcweir { 3360cdf0e10cSrcweir // #103168# post again if async focus has not arrived yet 3361cdf0e10cSrcweir // hopefully we will not receive the corresponding button up before this 3362cdf0e10cSrcweir // button down arrives again 3363cdf0e10cSrcweir Window *pWin = pFrame->GetWindow(); 3364cdf0e10cSrcweir if( pWin && pWin->ImplGetWindowImpl()->mpFrameData->mnFocusId ) 3365cdf0e10cSrcweir { 3366cdf0e10cSrcweir ImplPostMessage( hWnd, nMsg, wParam, lParam ); 3367cdf0e10cSrcweir return 1; 3368cdf0e10cSrcweir } 3369cdf0e10cSrcweir } 3370cdf0e10cSrcweir SalMouseEvent aMouseEvt; 3371cdf0e10cSrcweir long nRet; 3372cdf0e10cSrcweir sal_uInt16 nEvent = 0; 3373cdf0e10cSrcweir sal_Bool bCall = TRUE; 3374cdf0e10cSrcweir 3375cdf0e10cSrcweir aMouseEvt.mnX = (short)LOWORD( lParam ); 3376cdf0e10cSrcweir aMouseEvt.mnY = (short)HIWORD( lParam ); 3377cdf0e10cSrcweir aMouseEvt.mnCode = 0; 3378cdf0e10cSrcweir aMouseEvt.mnTime = GetMessageTime(); 3379cdf0e10cSrcweir 3380cdf0e10cSrcweir // Wegen (Logitech-)MouseTreiber ueber GetKeyState() gehen, die auf 3381cdf0e10cSrcweir // mittlerer Maustaste Doppelklick simulieren und den KeyStatus nicht 3382cdf0e10cSrcweir // beruecksichtigen 3383cdf0e10cSrcweir 3384cdf0e10cSrcweir if ( GetKeyState( VK_LBUTTON ) & 0x8000 ) 3385cdf0e10cSrcweir aMouseEvt.mnCode |= MOUSE_LEFT; 3386cdf0e10cSrcweir if ( GetKeyState( VK_MBUTTON ) & 0x8000 ) 3387cdf0e10cSrcweir aMouseEvt.mnCode |= MOUSE_MIDDLE; 3388cdf0e10cSrcweir if ( GetKeyState( VK_RBUTTON ) & 0x8000 ) 3389cdf0e10cSrcweir aMouseEvt.mnCode |= MOUSE_RIGHT; 3390cdf0e10cSrcweir if ( GetKeyState( VK_SHIFT ) & 0x8000 ) 3391cdf0e10cSrcweir aMouseEvt.mnCode |= KEY_SHIFT; 3392cdf0e10cSrcweir if ( GetKeyState( VK_CONTROL ) & 0x8000 ) 3393cdf0e10cSrcweir aMouseEvt.mnCode |= KEY_MOD1; 3394cdf0e10cSrcweir if ( GetKeyState( VK_MENU ) & 0x8000 ) 3395cdf0e10cSrcweir aMouseEvt.mnCode |= KEY_MOD2; 3396cdf0e10cSrcweir 3397cdf0e10cSrcweir switch ( nMsg ) 3398cdf0e10cSrcweir { 3399cdf0e10cSrcweir case WM_MOUSEMOVE: 3400cdf0e10cSrcweir { 3401cdf0e10cSrcweir // Da bei Druecken von Modifier-Tasten die MouseEvents 3402cdf0e10cSrcweir // nicht zusammengefast werden (da diese durch KeyEvents 3403cdf0e10cSrcweir // unterbrochen werden), machen wir dieses hier selber 3404cdf0e10cSrcweir if ( aMouseEvt.mnCode & (KEY_SHIFT | KEY_MOD1 | KEY_MOD2) ) 3405cdf0e10cSrcweir { 3406cdf0e10cSrcweir MSG aTempMsg; 3407cdf0e10cSrcweir if ( ImplPeekMessage( &aTempMsg, hWnd, WM_MOUSEFIRST, WM_MOUSELAST, PM_NOREMOVE | PM_NOYIELD ) ) 3408cdf0e10cSrcweir { 3409cdf0e10cSrcweir if ( (aTempMsg.message == WM_MOUSEMOVE) && 3410cdf0e10cSrcweir (aTempMsg.wParam == wParam) ) 3411cdf0e10cSrcweir return 1; 3412cdf0e10cSrcweir } 3413cdf0e10cSrcweir } 3414cdf0e10cSrcweir 3415cdf0e10cSrcweir SalData* pSalData = GetSalData(); 3416cdf0e10cSrcweir // Test for MouseLeave 3417cdf0e10cSrcweir if ( pSalData->mhWantLeaveMsg && (pSalData->mhWantLeaveMsg != hWnd) ) 3418cdf0e10cSrcweir ImplSendMessage( pSalData->mhWantLeaveMsg, SAL_MSG_MOUSELEAVE, 0, GetMessagePos() ); 3419cdf0e10cSrcweir 3420cdf0e10cSrcweir pSalData->mhWantLeaveMsg = hWnd; 3421cdf0e10cSrcweir // Start MouseLeave-Timer 3422cdf0e10cSrcweir if ( !pSalData->mpMouseLeaveTimer ) 3423cdf0e10cSrcweir { 3424cdf0e10cSrcweir pSalData->mpMouseLeaveTimer = new AutoTimer; 3425cdf0e10cSrcweir pSalData->mpMouseLeaveTimer->SetTimeout( SAL_MOUSELEAVE_TIMEOUT ); 3426cdf0e10cSrcweir pSalData->mpMouseLeaveTimer->Start(); 3427cdf0e10cSrcweir // We dont need to set a timeout handler, because we test 3428cdf0e10cSrcweir // for mouseleave in the timeout callback 3429cdf0e10cSrcweir } 3430cdf0e10cSrcweir aMouseEvt.mnButton = 0; 3431cdf0e10cSrcweir nEvent = SALEVENT_MOUSEMOVE; 3432cdf0e10cSrcweir } 3433cdf0e10cSrcweir break; 3434cdf0e10cSrcweir 3435cdf0e10cSrcweir case WM_NCMOUSEMOVE: 3436cdf0e10cSrcweir case SAL_MSG_MOUSELEAVE: 3437cdf0e10cSrcweir { 3438cdf0e10cSrcweir SalData* pSalData = GetSalData(); 3439cdf0e10cSrcweir if ( pSalData->mhWantLeaveMsg == hWnd ) 3440cdf0e10cSrcweir { 3441cdf0e10cSrcweir pSalData->mhWantLeaveMsg = 0; 3442cdf0e10cSrcweir if ( pSalData->mpMouseLeaveTimer ) 3443cdf0e10cSrcweir { 3444cdf0e10cSrcweir delete pSalData->mpMouseLeaveTimer; 3445cdf0e10cSrcweir pSalData->mpMouseLeaveTimer = NULL; 3446cdf0e10cSrcweir } 3447cdf0e10cSrcweir // Mouse-Coordinaates are relativ to the screen 3448cdf0e10cSrcweir POINT aPt; 3449cdf0e10cSrcweir aPt.x = (short)LOWORD( lParam ); 3450cdf0e10cSrcweir aPt.y = (short)HIWORD( lParam ); 3451cdf0e10cSrcweir ScreenToClient( hWnd, &aPt ); 3452cdf0e10cSrcweir aMouseEvt.mnX = aPt.x; 3453cdf0e10cSrcweir aMouseEvt.mnY = aPt.y; 3454cdf0e10cSrcweir aMouseEvt.mnButton = 0; 3455cdf0e10cSrcweir nEvent = SALEVENT_MOUSELEAVE; 3456cdf0e10cSrcweir } 3457cdf0e10cSrcweir else 3458cdf0e10cSrcweir bCall = FALSE; 3459cdf0e10cSrcweir } 3460cdf0e10cSrcweir break; 3461cdf0e10cSrcweir 3462cdf0e10cSrcweir case WM_LBUTTONDOWN: 3463cdf0e10cSrcweir aMouseEvt.mnButton = MOUSE_LEFT; 3464cdf0e10cSrcweir nEvent = SALEVENT_MOUSEBUTTONDOWN; 3465cdf0e10cSrcweir break; 3466cdf0e10cSrcweir 3467cdf0e10cSrcweir case WM_MBUTTONDOWN: 3468cdf0e10cSrcweir aMouseEvt.mnButton = MOUSE_MIDDLE; 3469cdf0e10cSrcweir nEvent = SALEVENT_MOUSEBUTTONDOWN; 3470cdf0e10cSrcweir break; 3471cdf0e10cSrcweir 3472cdf0e10cSrcweir case WM_RBUTTONDOWN: 3473cdf0e10cSrcweir aMouseEvt.mnButton = MOUSE_RIGHT; 3474cdf0e10cSrcweir nEvent = SALEVENT_MOUSEBUTTONDOWN; 3475cdf0e10cSrcweir break; 3476cdf0e10cSrcweir 3477cdf0e10cSrcweir case WM_LBUTTONUP: 3478cdf0e10cSrcweir aMouseEvt.mnButton = MOUSE_LEFT; 3479cdf0e10cSrcweir nEvent = SALEVENT_MOUSEBUTTONUP; 3480cdf0e10cSrcweir break; 3481cdf0e10cSrcweir 3482cdf0e10cSrcweir case WM_MBUTTONUP: 3483cdf0e10cSrcweir aMouseEvt.mnButton = MOUSE_MIDDLE; 3484cdf0e10cSrcweir nEvent = SALEVENT_MOUSEBUTTONUP; 3485cdf0e10cSrcweir break; 3486cdf0e10cSrcweir 3487cdf0e10cSrcweir case WM_RBUTTONUP: 3488cdf0e10cSrcweir aMouseEvt.mnButton = MOUSE_RIGHT; 3489cdf0e10cSrcweir nEvent = SALEVENT_MOUSEBUTTONUP; 3490cdf0e10cSrcweir break; 3491cdf0e10cSrcweir } 3492cdf0e10cSrcweir 3493cdf0e10cSrcweir // check if this window was destroyed - this might happen if we are the help window 3494cdf0e10cSrcweir // and sent a mouse leave message to the application which killed the help window, ie ourself 3495cdf0e10cSrcweir if( !IsWindow( hWnd ) ) 3496cdf0e10cSrcweir return 0; 3497cdf0e10cSrcweir 3498cdf0e10cSrcweir if ( bCall ) 3499cdf0e10cSrcweir { 3500cdf0e10cSrcweir if ( nEvent == SALEVENT_MOUSEBUTTONDOWN ) 3501cdf0e10cSrcweir UpdateWindow( hWnd ); 3502cdf0e10cSrcweir 3503cdf0e10cSrcweir // --- RTL --- (mirror mouse pos) 3504cdf0e10cSrcweir if( Application::GetSettings().GetLayoutRTL() ) 3505cdf0e10cSrcweir aMouseEvt.mnX = pFrame->maGeometry.nWidth-1-aMouseEvt.mnX; 3506cdf0e10cSrcweir 3507cdf0e10cSrcweir nRet = pFrame->CallCallback( nEvent, &aMouseEvt ); 3508cdf0e10cSrcweir if ( nMsg == WM_MOUSEMOVE ) 3509cdf0e10cSrcweir SetCursor( pFrame->mhCursor ); 3510cdf0e10cSrcweir } 3511cdf0e10cSrcweir else 3512cdf0e10cSrcweir nRet = 0; 3513cdf0e10cSrcweir 3514cdf0e10cSrcweir return nRet; 3515cdf0e10cSrcweir } 3516cdf0e10cSrcweir 3517cdf0e10cSrcweir // ----------------------------------------------------------------------- 3518cdf0e10cSrcweir 3519cdf0e10cSrcweir static long ImplHandleMouseActivateMsg( HWND hWnd ) 3520cdf0e10cSrcweir { 3521cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 3522cdf0e10cSrcweir if ( !pFrame ) 3523cdf0e10cSrcweir return 0; 3524cdf0e10cSrcweir 3525cdf0e10cSrcweir if ( pFrame->mbFloatWin ) 3526cdf0e10cSrcweir return TRUE; 3527cdf0e10cSrcweir 3528cdf0e10cSrcweir SalMouseActivateEvent aMouseActivateEvt; 3529cdf0e10cSrcweir POINT aPt; 3530cdf0e10cSrcweir GetCursorPos( &aPt ); 3531cdf0e10cSrcweir ScreenToClient( hWnd, &aPt ); 3532cdf0e10cSrcweir aMouseActivateEvt.mnX = aPt.x; 3533cdf0e10cSrcweir aMouseActivateEvt.mnY = aPt.y; 3534cdf0e10cSrcweir return pFrame->CallCallback( SALEVENT_MOUSEACTIVATE, &aMouseActivateEvt ); 3535cdf0e10cSrcweir } 3536cdf0e10cSrcweir 3537cdf0e10cSrcweir // ----------------------------------------------------------------------- 3538cdf0e10cSrcweir 3539cdf0e10cSrcweir static long ImplHandleWheelMsg( HWND hWnd, UINT nMsg, WPARAM wParam, LPARAM lParam ) 3540cdf0e10cSrcweir { 3541cdf0e10cSrcweir DBG_ASSERT( nMsg == WM_MOUSEWHEEL || 3542cdf0e10cSrcweir nMsg == WM_MOUSEHWHEEL, 3543cdf0e10cSrcweir "ImplHandleWheelMsg() called with no wheel mouse event" ); 3544cdf0e10cSrcweir 3545cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 3546cdf0e10cSrcweir 3547cdf0e10cSrcweir long nRet = 0; 3548cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 3549cdf0e10cSrcweir if ( pFrame ) 3550cdf0e10cSrcweir { 3551cdf0e10cSrcweir WORD nWinModCode = LOWORD( wParam ); 3552cdf0e10cSrcweir POINT aWinPt; 3553cdf0e10cSrcweir aWinPt.x = (short)LOWORD( lParam ); 3554cdf0e10cSrcweir aWinPt.y = (short)HIWORD( lParam ); 3555cdf0e10cSrcweir ScreenToClient( hWnd, &aWinPt ); 3556cdf0e10cSrcweir 3557cdf0e10cSrcweir SalWheelMouseEvent aWheelEvt; 3558cdf0e10cSrcweir aWheelEvt.mnTime = GetMessageTime(); 3559cdf0e10cSrcweir aWheelEvt.mnX = aWinPt.x; 3560cdf0e10cSrcweir aWheelEvt.mnY = aWinPt.y; 3561cdf0e10cSrcweir aWheelEvt.mnCode = 0; 3562cdf0e10cSrcweir aWheelEvt.mnDelta = (short)HIWORD( wParam ); 3563cdf0e10cSrcweir aWheelEvt.mnNotchDelta = aWheelEvt.mnDelta/WHEEL_DELTA; 3564cdf0e10cSrcweir if( aWheelEvt.mnNotchDelta == 0 ) 3565cdf0e10cSrcweir { 3566cdf0e10cSrcweir if( aWheelEvt.mnDelta > 0 ) 3567cdf0e10cSrcweir aWheelEvt.mnNotchDelta = 1; 3568cdf0e10cSrcweir else if( aWheelEvt.mnDelta < 0 ) 3569cdf0e10cSrcweir aWheelEvt.mnNotchDelta = -1; 3570cdf0e10cSrcweir } 3571cdf0e10cSrcweir 3572cdf0e10cSrcweir if( nMsg == WM_MOUSEWHEEL ) 3573cdf0e10cSrcweir { 3574cdf0e10cSrcweir if ( aSalShlData.mnWheelScrollLines == WHEEL_PAGESCROLL ) 3575cdf0e10cSrcweir aWheelEvt.mnScrollLines = SAL_WHEELMOUSE_EVENT_PAGESCROLL; 3576cdf0e10cSrcweir else 3577cdf0e10cSrcweir aWheelEvt.mnScrollLines = aSalShlData.mnWheelScrollLines; 3578cdf0e10cSrcweir aWheelEvt.mbHorz = FALSE; 3579cdf0e10cSrcweir } 3580cdf0e10cSrcweir else 3581cdf0e10cSrcweir { 3582cdf0e10cSrcweir aWheelEvt.mnScrollLines = aSalShlData.mnWheelScrollChars; 3583cdf0e10cSrcweir aWheelEvt.mbHorz = TRUE; 3584cdf0e10cSrcweir } 3585cdf0e10cSrcweir 3586cdf0e10cSrcweir if ( nWinModCode & MK_SHIFT ) 3587cdf0e10cSrcweir aWheelEvt.mnCode |= KEY_SHIFT; 3588cdf0e10cSrcweir if ( nWinModCode & MK_CONTROL ) 3589cdf0e10cSrcweir aWheelEvt.mnCode |= KEY_MOD1; 3590cdf0e10cSrcweir if ( GetKeyState( VK_MENU ) & 0x8000 ) 3591cdf0e10cSrcweir aWheelEvt.mnCode |= KEY_MOD2; 3592cdf0e10cSrcweir 3593cdf0e10cSrcweir // --- RTL --- (mirror mouse pos) 3594cdf0e10cSrcweir if( Application::GetSettings().GetLayoutRTL() ) 3595cdf0e10cSrcweir aWheelEvt.mnX = pFrame->maGeometry.nWidth-1-aWheelEvt.mnX; 3596cdf0e10cSrcweir 3597cdf0e10cSrcweir nRet = pFrame->CallCallback( SALEVENT_WHEELMOUSE, &aWheelEvt ); 3598cdf0e10cSrcweir } 3599cdf0e10cSrcweir 3600cdf0e10cSrcweir ImplSalYieldMutexRelease(); 3601cdf0e10cSrcweir 3602cdf0e10cSrcweir return nRet; 3603cdf0e10cSrcweir } 3604cdf0e10cSrcweir 3605cdf0e10cSrcweir // ----------------------------------------------------------------------- 3606cdf0e10cSrcweir 3607cdf0e10cSrcweir static sal_uInt16 ImplSalGetKeyCode( WPARAM wParam ) 3608cdf0e10cSrcweir { 3609cdf0e10cSrcweir sal_uInt16 nKeyCode; 3610cdf0e10cSrcweir 3611cdf0e10cSrcweir // convert KeyCode 3612cdf0e10cSrcweir if ( wParam < KEY_TAB_SIZE ) 3613cdf0e10cSrcweir nKeyCode = aImplTranslateKeyTab[wParam]; 3614cdf0e10cSrcweir else 3615cdf0e10cSrcweir { 3616cdf0e10cSrcweir SalData* pSalData = GetSalData(); 3617cdf0e10cSrcweir std::map< UINT, sal_uInt16 >::const_iterator it = pSalData->maVKMap.find( (UINT)wParam ); 3618cdf0e10cSrcweir if( it != pSalData->maVKMap.end() ) 3619cdf0e10cSrcweir nKeyCode = it->second; 3620cdf0e10cSrcweir else 3621cdf0e10cSrcweir nKeyCode = 0; 3622cdf0e10cSrcweir } 3623cdf0e10cSrcweir 3624cdf0e10cSrcweir return nKeyCode; 3625cdf0e10cSrcweir } 3626cdf0e10cSrcweir 3627cdf0e10cSrcweir // ----------------------------------------------------------------------- 3628cdf0e10cSrcweir 3629cdf0e10cSrcweir static UINT ImplStrToNum( const sal_Char* pStr ) 3630cdf0e10cSrcweir { 3631cdf0e10cSrcweir sal_uInt16 n = 0; 3632cdf0e10cSrcweir 3633cdf0e10cSrcweir // Solange es sich um eine Ziffer handelt, String umwandeln 3634cdf0e10cSrcweir while( (*pStr >= 48) && (*pStr <= 57) ) 3635cdf0e10cSrcweir { 3636cdf0e10cSrcweir n *= 10; 3637cdf0e10cSrcweir n += ((*pStr) - 48); 3638cdf0e10cSrcweir pStr++; 3639cdf0e10cSrcweir } 3640cdf0e10cSrcweir 3641cdf0e10cSrcweir return n; 3642cdf0e10cSrcweir } 3643cdf0e10cSrcweir 3644cdf0e10cSrcweir // ----------------------------------------------------------------------- 3645cdf0e10cSrcweir 3646cdf0e10cSrcweir static void ImplUpdateInputLang( WinSalFrame* pFrame ) 3647cdf0e10cSrcweir { 3648cdf0e10cSrcweir sal_Bool bLanguageChange = FALSE; 3649cdf0e10cSrcweir UINT nLang = LOWORD( GetKeyboardLayout( 0 ) ); 3650cdf0e10cSrcweir if ( nLang && nLang != pFrame->mnInputLang ) 3651cdf0e10cSrcweir { 3652cdf0e10cSrcweir // keep input lang up-to-date 3653cdf0e10cSrcweir pFrame->mnInputLang = nLang; 3654cdf0e10cSrcweir bLanguageChange = TRUE; 3655cdf0e10cSrcweir } 3656cdf0e10cSrcweir 3657cdf0e10cSrcweir // If we are on Windows NT we use Unicode FrameProcs and so we 3658cdf0e10cSrcweir // get Unicode charcodes directly from Windows 3659cdf0e10cSrcweir // no need to set up a code page 3660cdf0e10cSrcweir return; 3661cdf0e10cSrcweir } 3662cdf0e10cSrcweir 3663cdf0e10cSrcweir 3664cdf0e10cSrcweir static sal_Unicode ImplGetCharCode( WinSalFrame* pFrame, WPARAM nCharCode ) 3665cdf0e10cSrcweir { 3666cdf0e10cSrcweir ImplUpdateInputLang( pFrame ); 3667cdf0e10cSrcweir 3668cdf0e10cSrcweir // If we are on Windows NT we use Unicode FrameProcs and so we 3669cdf0e10cSrcweir // get Unicode charcodes directly from Windows 3670cdf0e10cSrcweir return (sal_Unicode)nCharCode; 3671cdf0e10cSrcweir } 3672cdf0e10cSrcweir 3673cdf0e10cSrcweir // ----------------------------------------------------------------------- 3674cdf0e10cSrcweir 3675cdf0e10cSrcweir LanguageType WinSalFrame::GetInputLanguage() 3676cdf0e10cSrcweir { 3677cdf0e10cSrcweir if( !mnInputLang ) 3678cdf0e10cSrcweir ImplUpdateInputLang( this ); 3679cdf0e10cSrcweir 3680cdf0e10cSrcweir if( !mnInputLang ) 3681cdf0e10cSrcweir return LANGUAGE_DONTKNOW; 3682cdf0e10cSrcweir else 3683cdf0e10cSrcweir return (LanguageType) mnInputLang; 3684cdf0e10cSrcweir } 3685cdf0e10cSrcweir 3686cdf0e10cSrcweir // ----------------------------------------------------------------------- 3687cdf0e10cSrcweir 3688cdf0e10cSrcweir sal_Bool WinSalFrame::MapUnicodeToKeyCode( sal_Unicode aUnicode, LanguageType aLangType, KeyCode& rKeyCode ) 3689cdf0e10cSrcweir { 3690cdf0e10cSrcweir sal_Bool bRet = FALSE; 3691cdf0e10cSrcweir HKL hkl = 0; 3692cdf0e10cSrcweir 3693cdf0e10cSrcweir // just use the passed language identifier, do not try to load additional keyboard support 3694cdf0e10cSrcweir hkl = (HKL) aLangType; 3695cdf0e10cSrcweir 3696cdf0e10cSrcweir if( hkl ) 3697cdf0e10cSrcweir { 3698cdf0e10cSrcweir SHORT scan = VkKeyScanExW( aUnicode, hkl ); 3699cdf0e10cSrcweir if( LOWORD(scan) == 0xFFFF ) 3700cdf0e10cSrcweir // keyboard not loaded or key cannot be mapped 3701cdf0e10cSrcweir bRet = FALSE; 3702cdf0e10cSrcweir else 3703cdf0e10cSrcweir { 3704cdf0e10cSrcweir BYTE vkeycode = LOBYTE(scan); 3705cdf0e10cSrcweir BYTE shiftstate = HIBYTE(scan); 3706cdf0e10cSrcweir 3707cdf0e10cSrcweir // Last argument is set to FALSE, because there's no decission made 3708cdf0e10cSrcweir // yet which key should be assigned to MOD3 modifier on Windows. 3709cdf0e10cSrcweir // Windows key - user's can be confused, because it should display 3710cdf0e10cSrcweir // Windows menu (applies to both left/right key) 3711cdf0e10cSrcweir // Menu key - this key is used to display context menu 3712cdf0e10cSrcweir // AltGr key - probably it has no sense 3713cdf0e10cSrcweir rKeyCode = KeyCode( ImplSalGetKeyCode( vkeycode ), 3714cdf0e10cSrcweir (shiftstate & 0x01) ? TRUE : FALSE, // shift 3715cdf0e10cSrcweir (shiftstate & 0x02) ? TRUE : FALSE, // ctrl 3716cdf0e10cSrcweir (shiftstate & 0x04) ? TRUE : FALSE, // alt 3717cdf0e10cSrcweir FALSE ); 3718cdf0e10cSrcweir bRet = TRUE; 3719cdf0e10cSrcweir } 3720cdf0e10cSrcweir } 3721cdf0e10cSrcweir 3722cdf0e10cSrcweir return bRet; 3723cdf0e10cSrcweir } 3724cdf0e10cSrcweir 3725cdf0e10cSrcweir // ----------------------------------------------------------------------- 3726cdf0e10cSrcweir 3727cdf0e10cSrcweir static long ImplHandleKeyMsg( HWND hWnd, UINT nMsg, 3728cdf0e10cSrcweir WPARAM wParam, LPARAM lParam, LRESULT& rResult ) 3729cdf0e10cSrcweir { 3730cdf0e10cSrcweir static sal_Bool bIgnoreCharMsg = FALSE; 3731cdf0e10cSrcweir static WPARAM nDeadChar = 0; 3732cdf0e10cSrcweir static WPARAM nLastVKChar = 0; 3733cdf0e10cSrcweir static sal_uInt16 nLastChar = 0; 3734cdf0e10cSrcweir static sal_uInt16 nLastModKeyCode = 0; 3735cdf0e10cSrcweir static bool bWaitForModKeyRelease = false; 3736cdf0e10cSrcweir sal_uInt16 nRepeat = LOWORD( lParam )-1; 3737cdf0e10cSrcweir sal_uInt16 nModCode = 0; 3738cdf0e10cSrcweir 3739cdf0e10cSrcweir // Key wurde evtl. durch SysChild an uns weitergeleitet und 3740cdf0e10cSrcweir // darf somit dann nicht doppelt verarbeitet werden 3741cdf0e10cSrcweir GetSalData()->mnSalObjWantKeyEvt = 0; 3742cdf0e10cSrcweir 3743cdf0e10cSrcweir if ( nMsg == WM_DEADCHAR ) 3744cdf0e10cSrcweir { 3745cdf0e10cSrcweir nDeadChar = wParam; 3746cdf0e10cSrcweir return 0; 3747cdf0e10cSrcweir } 3748cdf0e10cSrcweir 3749cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 3750cdf0e10cSrcweir if ( !pFrame ) 3751cdf0e10cSrcweir return 0; 3752cdf0e10cSrcweir 3753cdf0e10cSrcweir // Wir restaurieren den Background-Modus bei jeder Texteingabe, 3754cdf0e10cSrcweir // da einige Tools wie RichWin uns diesen hin- und wieder umsetzen 3755cdf0e10cSrcweir if ( pFrame->mpGraphics && 37565f27b83cSArmin Le Grand pFrame->mpGraphics->getHDC() ) 37575f27b83cSArmin Le Grand SetBkMode( pFrame->mpGraphics->getHDC(), TRANSPARENT ); 3758cdf0e10cSrcweir 3759cdf0e10cSrcweir // determine modifiers 3760cdf0e10cSrcweir if ( GetKeyState( VK_SHIFT ) & 0x8000 ) 3761cdf0e10cSrcweir nModCode |= KEY_SHIFT; 3762cdf0e10cSrcweir if ( GetKeyState( VK_CONTROL ) & 0x8000 ) 3763cdf0e10cSrcweir nModCode |= KEY_MOD1; 3764cdf0e10cSrcweir if ( GetKeyState( VK_MENU ) & 0x8000 ) 3765cdf0e10cSrcweir nModCode |= KEY_MOD2; 3766cdf0e10cSrcweir 3767cdf0e10cSrcweir if ( (nMsg == WM_CHAR) || (nMsg == WM_SYSCHAR) ) 3768cdf0e10cSrcweir { 3769cdf0e10cSrcweir nDeadChar = 0; 3770cdf0e10cSrcweir 3771cdf0e10cSrcweir if ( bIgnoreCharMsg ) 3772cdf0e10cSrcweir { 3773cdf0e10cSrcweir bIgnoreCharMsg = FALSE; 3774cdf0e10cSrcweir // #101635# if zero is returned here for WM_SYSCHAR (ALT+<key>) Windows will beep 3775cdf0e10cSrcweir // becaus this 'hotkey' was not processed -> better return 1 3776cdf0e10cSrcweir // except for Alt-SPACE which should always open the sysmenu (#104616#) 3777cdf0e10cSrcweir 3778cdf0e10cSrcweir // also return zero if a system menubar is available that might process this hotkey 3779cdf0e10cSrcweir // this also applies to the OLE inplace embedding where we are a child window 3780cdf0e10cSrcweir if( (GetWindowStyle( hWnd ) & WS_CHILD) || GetMenu( hWnd ) || (wParam == 0x20) ) 3781cdf0e10cSrcweir return 0; 3782cdf0e10cSrcweir else 3783cdf0e10cSrcweir return 1; 3784cdf0e10cSrcweir } 3785cdf0e10cSrcweir 3786cdf0e10cSrcweir // Backspace ignorieren wir als eigenstaendige Taste, 3787cdf0e10cSrcweir // damit wir keine Probleme in Kombination mit einem 3788cdf0e10cSrcweir // DeadKey bekommen 3789cdf0e10cSrcweir if ( wParam == 0x08 ) // BACKSPACE 3790cdf0e10cSrcweir return 0; 3791cdf0e10cSrcweir 3792cdf0e10cSrcweir // Hier kommen nur "freifliegende" WM_CHAR Message an, die durch 3793cdf0e10cSrcweir // eintippen einer ALT-NUMPAD Kombination erzeugt wurden 3794cdf0e10cSrcweir SalKeyEvent aKeyEvt; 3795cdf0e10cSrcweir 3796cdf0e10cSrcweir if ( (wParam >= '0') && (wParam <= '9') ) 3797cdf0e10cSrcweir aKeyEvt.mnCode = sal::static_int_cast<sal_uInt16>(KEYGROUP_NUM + wParam - '0'); 3798cdf0e10cSrcweir else if ( (wParam >= 'A') && (wParam <= 'Z') ) 3799cdf0e10cSrcweir aKeyEvt.mnCode = sal::static_int_cast<sal_uInt16>(KEYGROUP_ALPHA + wParam - 'A'); 3800cdf0e10cSrcweir else if ( (wParam >= 'a') && (wParam <= 'z') ) 3801cdf0e10cSrcweir aKeyEvt.mnCode = sal::static_int_cast<sal_uInt16>(KEYGROUP_ALPHA + wParam - 'a'); 3802cdf0e10cSrcweir else if ( wParam == 0x0D ) // RETURN 3803cdf0e10cSrcweir aKeyEvt.mnCode = KEY_RETURN; 3804cdf0e10cSrcweir else if ( wParam == 0x1B ) // ESCAPE 3805cdf0e10cSrcweir aKeyEvt.mnCode = KEY_ESCAPE; 3806cdf0e10cSrcweir else if ( wParam == 0x09 ) // TAB 3807cdf0e10cSrcweir aKeyEvt.mnCode = KEY_TAB; 3808cdf0e10cSrcweir else if ( wParam == 0x20 ) // SPACE 3809cdf0e10cSrcweir aKeyEvt.mnCode = KEY_SPACE; 3810cdf0e10cSrcweir else 3811cdf0e10cSrcweir aKeyEvt.mnCode = 0; 3812cdf0e10cSrcweir 3813cdf0e10cSrcweir aKeyEvt.mnTime = GetMessageTime(); 3814cdf0e10cSrcweir aKeyEvt.mnCode |= nModCode; 3815cdf0e10cSrcweir aKeyEvt.mnCharCode = ImplGetCharCode( pFrame, wParam ); 3816cdf0e10cSrcweir aKeyEvt.mnRepeat = nRepeat; 3817cdf0e10cSrcweir nLastChar = 0; 3818cdf0e10cSrcweir nLastVKChar = 0; 3819cdf0e10cSrcweir long nRet = pFrame->CallCallback( SALEVENT_KEYINPUT, &aKeyEvt ); 3820cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_KEYUP, &aKeyEvt ); 3821cdf0e10cSrcweir return nRet; 3822cdf0e10cSrcweir } 3823cdf0e10cSrcweir // #i11583#, MCD, 2003-01-13, Support for WM_UNICHAR & Keyman 6.0; addition begins 3824cdf0e10cSrcweir else if( nMsg == WM_UNICHAR ) 3825cdf0e10cSrcweir { 3826cdf0e10cSrcweir // If Windows is asking if we accept WM_UNICHAR, return TRUE 3827cdf0e10cSrcweir if(wParam == UNICODE_NOCHAR) 3828cdf0e10cSrcweir { 3829cdf0e10cSrcweir rResult = TRUE; // ssa: this will actually return TRUE to windows 3830cdf0e10cSrcweir return 1; // ...but this will only avoid calling the defwindowproc 3831cdf0e10cSrcweir } 3832cdf0e10cSrcweir 3833cdf0e10cSrcweir SalKeyEvent aKeyEvt; 3834cdf0e10cSrcweir aKeyEvt.mnCode = nModCode; // Or should it be 0? - as this is always a character returned 3835cdf0e10cSrcweir aKeyEvt.mnTime = GetMessageTime(); 3836cdf0e10cSrcweir aKeyEvt.mnRepeat = 0; 3837cdf0e10cSrcweir 3838cdf0e10cSrcweir if( wParam >= Uni_SupplementaryPlanesStart ) 3839cdf0e10cSrcweir { 3840cdf0e10cSrcweir // character is supplementary char in UTF-32 format - must be converted to UTF-16 supplementary pair 3841cdf0e10cSrcweir // sal_Unicode ch = (sal_Unicode) Uni_UTF32ToSurrogate1(wParam); 3842cdf0e10cSrcweir nLastChar = 0; 3843cdf0e10cSrcweir nLastVKChar = 0; 3844cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_KEYINPUT, &aKeyEvt ); 3845cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_KEYUP, &aKeyEvt ); 3846cdf0e10cSrcweir wParam = (sal_Unicode) Uni_UTF32ToSurrogate2( wParam ); 3847cdf0e10cSrcweir } 3848cdf0e10cSrcweir 3849cdf0e10cSrcweir aKeyEvt.mnCharCode = (sal_Unicode) wParam; 3850cdf0e10cSrcweir 3851cdf0e10cSrcweir nLastChar = 0; 3852cdf0e10cSrcweir nLastVKChar = 0; 3853cdf0e10cSrcweir long nRet = pFrame->CallCallback( SALEVENT_KEYINPUT, &aKeyEvt ); 3854cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_KEYUP, &aKeyEvt ); 3855cdf0e10cSrcweir 3856cdf0e10cSrcweir return nRet; 3857cdf0e10cSrcweir } 3858cdf0e10cSrcweir // MCD, 2003-01-13, Support for WM_UNICHAR & Keyman 6.0; addition ends 3859cdf0e10cSrcweir else 3860cdf0e10cSrcweir { 3861cdf0e10cSrcweir // Bei Shift, Control und Menu schicken wir einen KeyModChange-Event 3862cdf0e10cSrcweir if ( (wParam == VK_SHIFT) || (wParam == VK_CONTROL) || (wParam == VK_MENU) ) 3863cdf0e10cSrcweir { 3864cdf0e10cSrcweir SalKeyModEvent aModEvt; 3865cdf0e10cSrcweir aModEvt.mnTime = GetMessageTime(); 3866cdf0e10cSrcweir aModEvt.mnCode = nModCode; 3867cdf0e10cSrcweir aModEvt.mnModKeyCode = 0; // no command events will be sent if this member is 0 3868cdf0e10cSrcweir 3869cdf0e10cSrcweir sal_uInt16 tmpCode = 0; 3870cdf0e10cSrcweir if( GetKeyState( VK_LSHIFT ) & 0x8000 ) 3871cdf0e10cSrcweir tmpCode |= MODKEY_LSHIFT; 3872cdf0e10cSrcweir if( GetKeyState( VK_RSHIFT ) & 0x8000 ) 3873cdf0e10cSrcweir tmpCode |= MODKEY_RSHIFT; 3874cdf0e10cSrcweir if( GetKeyState( VK_LCONTROL ) & 0x8000 ) 3875cdf0e10cSrcweir tmpCode |= MODKEY_LMOD1; 3876cdf0e10cSrcweir if( GetKeyState( VK_RCONTROL ) & 0x8000 ) 3877cdf0e10cSrcweir tmpCode |= MODKEY_RMOD1; 3878cdf0e10cSrcweir if( GetKeyState( VK_LMENU ) & 0x8000 ) 3879cdf0e10cSrcweir tmpCode |= MODKEY_LMOD2; 3880cdf0e10cSrcweir if( GetKeyState( VK_RMENU ) & 0x8000 ) 3881cdf0e10cSrcweir tmpCode |= MODKEY_RMOD2; 3882cdf0e10cSrcweir 3883cdf0e10cSrcweir if( tmpCode < nLastModKeyCode ) 3884cdf0e10cSrcweir { 3885cdf0e10cSrcweir aModEvt.mnModKeyCode = nLastModKeyCode; 3886cdf0e10cSrcweir nLastModKeyCode = 0; 3887cdf0e10cSrcweir bWaitForModKeyRelease = true; 3888cdf0e10cSrcweir } 3889cdf0e10cSrcweir else 3890cdf0e10cSrcweir { 3891cdf0e10cSrcweir if( !bWaitForModKeyRelease ) 3892cdf0e10cSrcweir nLastModKeyCode = tmpCode; 3893cdf0e10cSrcweir } 3894cdf0e10cSrcweir 3895cdf0e10cSrcweir if( !tmpCode ) 3896cdf0e10cSrcweir bWaitForModKeyRelease = false; 3897cdf0e10cSrcweir 3898cdf0e10cSrcweir return pFrame->CallCallback( SALEVENT_KEYMODCHANGE, &aModEvt ); 3899cdf0e10cSrcweir } 3900cdf0e10cSrcweir else 3901cdf0e10cSrcweir { 3902cdf0e10cSrcweir SalKeyEvent aKeyEvt; 3903cdf0e10cSrcweir sal_uInt16 nEvent; 3904cdf0e10cSrcweir MSG aCharMsg; 3905cdf0e10cSrcweir BOOL bCharPeek = FALSE; 3906cdf0e10cSrcweir UINT nCharMsg = WM_CHAR; 3907cdf0e10cSrcweir sal_Bool bKeyUp = (nMsg == WM_KEYUP) || (nMsg == WM_SYSKEYUP); 3908cdf0e10cSrcweir 3909cdf0e10cSrcweir nLastModKeyCode = 0; // make sure no modkey messages are sent if they belong to a hotkey (see above) 3910cdf0e10cSrcweir aKeyEvt.mnCharCode = 0; 3911cdf0e10cSrcweir aKeyEvt.mnCode = 0; 3912cdf0e10cSrcweir 3913cdf0e10cSrcweir aKeyEvt.mnCode = ImplSalGetKeyCode( wParam ); 3914cdf0e10cSrcweir if ( !bKeyUp ) 3915cdf0e10cSrcweir { 3916cdf0e10cSrcweir // check for charcode 3917cdf0e10cSrcweir // Mit Hilfe von PeekMessage holen wir uns jetzt die 3918cdf0e10cSrcweir // zugehoerige WM_CHAR Message, wenn vorhanden. 3919cdf0e10cSrcweir // Diese WM_CHAR Message steht immer am Anfang der 3920cdf0e10cSrcweir // Messagequeue. Ausserdem ist sichergestellt, dass immer 3921cdf0e10cSrcweir // nur eine WM_CHAR Message in der Queue steht. 3922cdf0e10cSrcweir bCharPeek = ImplPeekMessage( &aCharMsg, hWnd, 3923cdf0e10cSrcweir WM_CHAR, WM_CHAR, PM_NOREMOVE | PM_NOYIELD ); 3924cdf0e10cSrcweir if ( bCharPeek && (nDeadChar == aCharMsg.wParam) ) 3925cdf0e10cSrcweir { 3926cdf0e10cSrcweir bCharPeek = FALSE; 3927cdf0e10cSrcweir nDeadChar = 0; 3928cdf0e10cSrcweir 3929cdf0e10cSrcweir if ( wParam == VK_BACK ) 3930cdf0e10cSrcweir { 3931cdf0e10cSrcweir ImplPeekMessage( &aCharMsg, hWnd, 3932cdf0e10cSrcweir nCharMsg, nCharMsg, PM_REMOVE | PM_NOYIELD ); 3933cdf0e10cSrcweir return 0; 3934cdf0e10cSrcweir } 3935cdf0e10cSrcweir } 3936cdf0e10cSrcweir else 3937cdf0e10cSrcweir { 3938cdf0e10cSrcweir if ( !bCharPeek ) 3939cdf0e10cSrcweir { 3940cdf0e10cSrcweir bCharPeek = ImplPeekMessage( &aCharMsg, hWnd, 3941cdf0e10cSrcweir WM_SYSCHAR, WM_SYSCHAR, PM_NOREMOVE | PM_NOYIELD ); 3942cdf0e10cSrcweir nCharMsg = WM_SYSCHAR; 3943cdf0e10cSrcweir } 3944cdf0e10cSrcweir } 3945cdf0e10cSrcweir if ( bCharPeek ) 3946cdf0e10cSrcweir aKeyEvt.mnCharCode = ImplGetCharCode( pFrame, aCharMsg.wParam ); 3947cdf0e10cSrcweir else 3948cdf0e10cSrcweir aKeyEvt.mnCharCode = 0; 3949cdf0e10cSrcweir 3950cdf0e10cSrcweir nLastChar = aKeyEvt.mnCharCode; 3951cdf0e10cSrcweir nLastVKChar = wParam; 3952cdf0e10cSrcweir } 3953cdf0e10cSrcweir else 3954cdf0e10cSrcweir { 3955cdf0e10cSrcweir if ( wParam == nLastVKChar ) 3956cdf0e10cSrcweir { 3957cdf0e10cSrcweir aKeyEvt.mnCharCode = nLastChar; 3958cdf0e10cSrcweir nLastChar = 0; 3959cdf0e10cSrcweir nLastVKChar = 0; 3960cdf0e10cSrcweir } 3961cdf0e10cSrcweir } 3962cdf0e10cSrcweir 3963cdf0e10cSrcweir if ( aKeyEvt.mnCode || aKeyEvt.mnCharCode ) 3964cdf0e10cSrcweir { 3965cdf0e10cSrcweir if ( bKeyUp ) 3966cdf0e10cSrcweir nEvent = SALEVENT_KEYUP; 3967cdf0e10cSrcweir else 3968cdf0e10cSrcweir nEvent = SALEVENT_KEYINPUT; 3969cdf0e10cSrcweir 3970cdf0e10cSrcweir aKeyEvt.mnTime = GetMessageTime(); 3971cdf0e10cSrcweir aKeyEvt.mnCode |= nModCode; 3972cdf0e10cSrcweir aKeyEvt.mnRepeat = nRepeat; 3973cdf0e10cSrcweir 3974cdf0e10cSrcweir if( (nModCode & (KEY_MOD1|KEY_MOD2)) == (KEY_MOD1|KEY_MOD2) && 3975cdf0e10cSrcweir aKeyEvt.mnCharCode ) 3976cdf0e10cSrcweir { 3977cdf0e10cSrcweir // this is actually AltGr and should not be handled as Alt 3978cdf0e10cSrcweir aKeyEvt.mnCode &= ~(KEY_MOD1|KEY_MOD2); 3979cdf0e10cSrcweir } 3980cdf0e10cSrcweir 3981cdf0e10cSrcweir bIgnoreCharMsg = bCharPeek ? TRUE : FALSE; 3982cdf0e10cSrcweir long nRet = pFrame->CallCallback( nEvent, &aKeyEvt ); 3983cdf0e10cSrcweir // independent part only reacts on keyup but Windows does not send 3984cdf0e10cSrcweir // keyup for VK_HANJA 3985cdf0e10cSrcweir if( aKeyEvt.mnCode == KEY_HANGUL_HANJA ) 3986cdf0e10cSrcweir nRet = pFrame->CallCallback( SALEVENT_KEYUP, &aKeyEvt ); 3987cdf0e10cSrcweir 3988cdf0e10cSrcweir bIgnoreCharMsg = FALSE; 3989cdf0e10cSrcweir 3990cdf0e10cSrcweir // char-message, than remove or ignore 3991cdf0e10cSrcweir if ( bCharPeek ) 3992cdf0e10cSrcweir { 3993cdf0e10cSrcweir nDeadChar = 0; 3994cdf0e10cSrcweir if ( nRet ) 3995cdf0e10cSrcweir { 3996cdf0e10cSrcweir ImplPeekMessage( &aCharMsg, hWnd, 3997cdf0e10cSrcweir nCharMsg, nCharMsg, PM_REMOVE | PM_NOYIELD ); 3998cdf0e10cSrcweir } 3999cdf0e10cSrcweir else 4000cdf0e10cSrcweir bIgnoreCharMsg = TRUE; 4001cdf0e10cSrcweir } 4002cdf0e10cSrcweir 4003cdf0e10cSrcweir return nRet; 4004cdf0e10cSrcweir } 4005cdf0e10cSrcweir else 4006cdf0e10cSrcweir return 0; 4007cdf0e10cSrcweir } 4008cdf0e10cSrcweir } 4009cdf0e10cSrcweir } 4010cdf0e10cSrcweir 4011cdf0e10cSrcweir // ----------------------------------------------------------------------- 4012cdf0e10cSrcweir 4013cdf0e10cSrcweir long ImplHandleSalObjKeyMsg( HWND hWnd, UINT nMsg, 4014cdf0e10cSrcweir WPARAM wParam, LPARAM lParam ) 4015cdf0e10cSrcweir { 4016cdf0e10cSrcweir if ( (nMsg == WM_KEYDOWN) || (nMsg == WM_KEYUP) ) 4017cdf0e10cSrcweir { 4018cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4019cdf0e10cSrcweir if ( !pFrame ) 4020cdf0e10cSrcweir return 0; 4021cdf0e10cSrcweir 4022cdf0e10cSrcweir sal_uInt16 nRepeat = LOWORD( lParam )-1; 4023cdf0e10cSrcweir sal_uInt16 nModCode = 0; 4024cdf0e10cSrcweir 4025cdf0e10cSrcweir // determine modifiers 4026cdf0e10cSrcweir if ( GetKeyState( VK_SHIFT ) & 0x8000 ) 4027cdf0e10cSrcweir nModCode |= KEY_SHIFT; 4028cdf0e10cSrcweir if ( GetKeyState( VK_CONTROL ) & 0x8000 ) 4029cdf0e10cSrcweir nModCode |= KEY_MOD1; 4030cdf0e10cSrcweir if ( GetKeyState( VK_MENU ) & 0x8000 ) 4031cdf0e10cSrcweir nModCode |= KEY_MOD2; 4032cdf0e10cSrcweir 4033cdf0e10cSrcweir if ( (wParam != VK_SHIFT) && (wParam != VK_CONTROL) && (wParam != VK_MENU) ) 4034cdf0e10cSrcweir { 4035cdf0e10cSrcweir SalKeyEvent aKeyEvt; 4036cdf0e10cSrcweir sal_uInt16 nEvent; 4037cdf0e10cSrcweir sal_Bool bKeyUp = (nMsg == WM_KEYUP) || (nMsg == WM_SYSKEYUP); 4038cdf0e10cSrcweir 4039cdf0e10cSrcweir // convert KeyCode 4040cdf0e10cSrcweir aKeyEvt.mnCode = ImplSalGetKeyCode( wParam ); 4041cdf0e10cSrcweir aKeyEvt.mnCharCode = 0; 4042cdf0e10cSrcweir 4043cdf0e10cSrcweir if ( aKeyEvt.mnCode ) 4044cdf0e10cSrcweir { 4045cdf0e10cSrcweir if ( bKeyUp ) 4046cdf0e10cSrcweir nEvent = SALEVENT_KEYUP; 4047cdf0e10cSrcweir else 4048cdf0e10cSrcweir nEvent = SALEVENT_KEYINPUT; 4049cdf0e10cSrcweir 4050cdf0e10cSrcweir aKeyEvt.mnTime = GetMessageTime(); 4051cdf0e10cSrcweir aKeyEvt.mnCode |= nModCode; 4052cdf0e10cSrcweir aKeyEvt.mnRepeat = nRepeat; 4053cdf0e10cSrcweir long nRet = pFrame->CallCallback( nEvent, &aKeyEvt ); 4054cdf0e10cSrcweir return nRet; 4055cdf0e10cSrcweir } 4056cdf0e10cSrcweir else 4057cdf0e10cSrcweir return 0; 4058cdf0e10cSrcweir } 4059cdf0e10cSrcweir } 4060cdf0e10cSrcweir 4061cdf0e10cSrcweir return 0; 4062cdf0e10cSrcweir } 4063cdf0e10cSrcweir 4064cdf0e10cSrcweir // ----------------------------------------------------------------------- 4065cdf0e10cSrcweir 4066cdf0e10cSrcweir long ImplHandleSalObjSysCharMsg( HWND hWnd, WPARAM wParam, LPARAM lParam ) 4067cdf0e10cSrcweir { 4068cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4069cdf0e10cSrcweir if ( !pFrame ) 4070cdf0e10cSrcweir return 0; 4071cdf0e10cSrcweir 4072cdf0e10cSrcweir sal_uInt16 nRepeat = LOWORD( lParam )-1; 4073cdf0e10cSrcweir sal_uInt16 nModCode = 0; 4074cdf0e10cSrcweir sal_uInt16 cKeyCode = (sal_uInt16)wParam; 4075cdf0e10cSrcweir 4076cdf0e10cSrcweir // determine modifiers 4077cdf0e10cSrcweir if ( GetKeyState( VK_SHIFT ) & 0x8000 ) 4078cdf0e10cSrcweir nModCode |= KEY_SHIFT; 4079cdf0e10cSrcweir if ( GetKeyState( VK_CONTROL ) & 0x8000 ) 4080cdf0e10cSrcweir nModCode |= KEY_MOD1; 4081cdf0e10cSrcweir nModCode |= KEY_MOD2; 4082cdf0e10cSrcweir 4083cdf0e10cSrcweir // KeyEvent zusammenbauen 4084cdf0e10cSrcweir SalKeyEvent aKeyEvt; 4085cdf0e10cSrcweir aKeyEvt.mnTime = GetMessageTime(); 4086cdf0e10cSrcweir if ( (cKeyCode >= 48) && (cKeyCode <= 57) ) 4087cdf0e10cSrcweir aKeyEvt.mnCode = KEY_0+(cKeyCode-48); 4088cdf0e10cSrcweir else if ( (cKeyCode >= 65) && (cKeyCode <= 90) ) 4089cdf0e10cSrcweir aKeyEvt.mnCode = KEY_A+(cKeyCode-65); 4090cdf0e10cSrcweir else if ( (cKeyCode >= 97) && (cKeyCode <= 122) ) 4091cdf0e10cSrcweir aKeyEvt.mnCode = KEY_A+(cKeyCode-97); 4092cdf0e10cSrcweir else 4093cdf0e10cSrcweir aKeyEvt.mnCode = 0; 4094cdf0e10cSrcweir aKeyEvt.mnCode |= nModCode; 4095cdf0e10cSrcweir aKeyEvt.mnCharCode = ImplGetCharCode( pFrame, cKeyCode ); 4096cdf0e10cSrcweir aKeyEvt.mnRepeat = nRepeat; 4097cdf0e10cSrcweir long nRet = pFrame->CallCallback( SALEVENT_KEYINPUT, &aKeyEvt ); 4098cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_KEYUP, &aKeyEvt ); 4099cdf0e10cSrcweir return nRet; 4100cdf0e10cSrcweir } 4101cdf0e10cSrcweir 4102cdf0e10cSrcweir // ----------------------------------------------------------------------- 4103cdf0e10cSrcweir 4104cdf0e10cSrcweir static bool ImplHandlePaintMsg( HWND hWnd ) 4105cdf0e10cSrcweir { 4106cdf0e10cSrcweir sal_Bool bMutex = FALSE; 4107cdf0e10cSrcweir if ( ImplSalYieldMutexTryToAcquire() ) 4108cdf0e10cSrcweir bMutex = TRUE; 4109cdf0e10cSrcweir 4110cdf0e10cSrcweir // if we don't get the mutex, we can also change the clip region, 4111cdf0e10cSrcweir // because other threads doesn't use the mutex from the main 4112cdf0e10cSrcweir // thread --> see GetGraphics() 4113cdf0e10cSrcweir 4114cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4115cdf0e10cSrcweir if ( pFrame ) 4116cdf0e10cSrcweir { 4117cdf0e10cSrcweir // Clip-Region muss zurueckgesetzt werden, da wir sonst kein 4118cdf0e10cSrcweir // ordentliches Bounding-Rectangle bekommen 4119cdf0e10cSrcweir if ( pFrame->mpGraphics && pFrame->mpGraphics->mhRegion ) 41205f27b83cSArmin Le Grand SelectClipRgn( pFrame->mpGraphics->getHDC(), 0 ); 4121cdf0e10cSrcweir 4122cdf0e10cSrcweir // Laut Window-Doku soll man erst abfragen, ob ueberhaupt eine 4123cdf0e10cSrcweir // Paint-Region anliegt 4124cdf0e10cSrcweir if ( GetUpdateRect( hWnd, NULL, FALSE ) ) 4125cdf0e10cSrcweir { 4126cdf0e10cSrcweir // Call BeginPaint/EndPaint to query the rect and send 4127cdf0e10cSrcweir // this Notofication to rect 4128cdf0e10cSrcweir RECT aUpdateRect; 4129cdf0e10cSrcweir PAINTSTRUCT aPs; 4130cdf0e10cSrcweir BeginPaint( hWnd, &aPs ); 4131cdf0e10cSrcweir CopyRect( &aUpdateRect, &aPs.rcPaint ); 4132cdf0e10cSrcweir 4133cdf0e10cSrcweir // Paint 4134cdf0e10cSrcweir // ClipRegion wieder herstellen 4135cdf0e10cSrcweir if ( pFrame->mpGraphics && pFrame->mpGraphics->mhRegion ) 4136cdf0e10cSrcweir { 41375f27b83cSArmin Le Grand SelectClipRgn( pFrame->mpGraphics->getHDC(), 4138cdf0e10cSrcweir pFrame->mpGraphics->mhRegion ); 4139cdf0e10cSrcweir } 4140cdf0e10cSrcweir 4141cdf0e10cSrcweir if ( bMutex ) 4142cdf0e10cSrcweir { 4143cdf0e10cSrcweir SalPaintEvent aPEvt( aUpdateRect.left, aUpdateRect.top, aUpdateRect.right-aUpdateRect.left, aUpdateRect.bottom-aUpdateRect.top, pFrame->mbPresentation ); 4144cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_PAINT, &aPEvt ); 4145cdf0e10cSrcweir } 4146cdf0e10cSrcweir else 4147cdf0e10cSrcweir { 4148cdf0e10cSrcweir RECT* pRect = new RECT; 4149cdf0e10cSrcweir CopyRect( pRect, &aUpdateRect ); 4150cdf0e10cSrcweir ImplPostMessage( hWnd, SAL_MSG_POSTPAINT, (WPARAM)pRect, 0 ); 4151cdf0e10cSrcweir } 4152cdf0e10cSrcweir EndPaint( hWnd, &aPs ); 4153cdf0e10cSrcweir } 4154cdf0e10cSrcweir else 4155cdf0e10cSrcweir { 4156cdf0e10cSrcweir // ClipRegion wieder herstellen 4157cdf0e10cSrcweir if ( pFrame->mpGraphics && pFrame->mpGraphics->mhRegion ) 4158cdf0e10cSrcweir { 41595f27b83cSArmin Le Grand SelectClipRgn( pFrame->mpGraphics->getHDC(), 4160cdf0e10cSrcweir pFrame->mpGraphics->mhRegion ); 4161cdf0e10cSrcweir } 4162cdf0e10cSrcweir } 4163cdf0e10cSrcweir } 4164cdf0e10cSrcweir 4165cdf0e10cSrcweir if ( bMutex ) 4166cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4167cdf0e10cSrcweir 4168cdf0e10cSrcweir return bMutex ? true : false; 4169cdf0e10cSrcweir } 4170cdf0e10cSrcweir 4171cdf0e10cSrcweir // ----------------------------------------------------------------------- 4172cdf0e10cSrcweir 4173cdf0e10cSrcweir static void ImplHandlePaintMsg2( HWND hWnd, RECT* pRect ) 4174cdf0e10cSrcweir { 4175cdf0e10cSrcweir // Paint 4176cdf0e10cSrcweir if ( ImplSalYieldMutexTryToAcquire() ) 4177cdf0e10cSrcweir { 4178cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4179cdf0e10cSrcweir if ( pFrame ) 4180cdf0e10cSrcweir { 4181cdf0e10cSrcweir SalPaintEvent aPEvt( pRect->left, pRect->top, pRect->right-pRect->left, pRect->bottom-pRect->top ); 4182cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_PAINT, &aPEvt ); 4183cdf0e10cSrcweir } 4184cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4185cdf0e10cSrcweir delete pRect; 4186cdf0e10cSrcweir } 4187cdf0e10cSrcweir else 4188cdf0e10cSrcweir ImplPostMessage( hWnd, SAL_MSG_POSTPAINT, (WPARAM)pRect, 0 ); 4189cdf0e10cSrcweir } 4190cdf0e10cSrcweir 4191cdf0e10cSrcweir // ----------------------------------------------------------------------- 4192cdf0e10cSrcweir 4193cdf0e10cSrcweir static void SetMaximizedFrameGeometry( HWND hWnd, WinSalFrame* pFrame, RECT* pParentRect ) 4194cdf0e10cSrcweir { 4195cdf0e10cSrcweir // calculate and set frame geometry of a maximized window - useful if the window is still hidden 4196cdf0e10cSrcweir 4197cdf0e10cSrcweir // dualmonitor support: 4198cdf0e10cSrcweir // Get screensize of the monitor whith the mouse pointer 4199cdf0e10cSrcweir 4200cdf0e10cSrcweir RECT aRectMouse; 4201cdf0e10cSrcweir if( ! pParentRect ) 4202cdf0e10cSrcweir { 4203cdf0e10cSrcweir POINT pt; 4204cdf0e10cSrcweir GetCursorPos( &pt ); 4205cdf0e10cSrcweir aRectMouse.left = pt.x; 4206cdf0e10cSrcweir aRectMouse.top = pt.y; 4207cdf0e10cSrcweir aRectMouse.right = pt.x+2; 4208cdf0e10cSrcweir aRectMouse.bottom = pt.y+2; 4209cdf0e10cSrcweir pParentRect = &aRectMouse; 4210cdf0e10cSrcweir } 4211cdf0e10cSrcweir 4212cdf0e10cSrcweir RECT aRect; 4213cdf0e10cSrcweir ImplSalGetWorkArea( hWnd, &aRect, pParentRect ); 4214cdf0e10cSrcweir 4215cdf0e10cSrcweir // a maximized window has no other borders than the caption 4216cdf0e10cSrcweir pFrame->maGeometry.nLeftDecoration = pFrame->maGeometry.nRightDecoration = pFrame->maGeometry.nBottomDecoration = 0; 4217cdf0e10cSrcweir pFrame->maGeometry.nTopDecoration = pFrame->mbCaption ? GetSystemMetrics( SM_CYCAPTION ) : 0; 4218cdf0e10cSrcweir 4219cdf0e10cSrcweir aRect.top += pFrame->maGeometry.nTopDecoration; 4220cdf0e10cSrcweir pFrame->maGeometry.nX = aRect.left; 4221cdf0e10cSrcweir pFrame->maGeometry.nY = aRect.top; 4222cdf0e10cSrcweir pFrame->maGeometry.nWidth = aRect.right - aRect.left; 4223cdf0e10cSrcweir pFrame->maGeometry.nHeight = aRect.bottom - aRect.top; 4224cdf0e10cSrcweir } 4225cdf0e10cSrcweir 4226cdf0e10cSrcweir static void UpdateFrameGeometry( HWND hWnd, WinSalFrame* pFrame ) 4227cdf0e10cSrcweir { 4228cdf0e10cSrcweir if( !pFrame ) 4229cdf0e10cSrcweir return; 4230cdf0e10cSrcweir 4231cdf0e10cSrcweir RECT aRect; 4232cdf0e10cSrcweir GetWindowRect( hWnd, &aRect ); 4233cdf0e10cSrcweir memset(&pFrame->maGeometry, 0, sizeof(SalFrameGeometry) ); 4234cdf0e10cSrcweir 4235cdf0e10cSrcweir if ( IsIconic( hWnd ) ) 4236cdf0e10cSrcweir return; 4237cdf0e10cSrcweir 4238cdf0e10cSrcweir POINT aPt; 4239cdf0e10cSrcweir aPt.x=0; 4240cdf0e10cSrcweir aPt.y=0; 4241cdf0e10cSrcweir ClientToScreen(hWnd, &aPt); 4242cdf0e10cSrcweir int cx = aPt.x - aRect.left; 4243cdf0e10cSrcweir pFrame->maGeometry.nTopDecoration = aPt.y - aRect.top; 4244cdf0e10cSrcweir 4245cdf0e10cSrcweir pFrame->maGeometry.nLeftDecoration = cx; 4246cdf0e10cSrcweir pFrame->maGeometry.nRightDecoration = cx; 4247cdf0e10cSrcweir 4248cdf0e10cSrcweir pFrame->maGeometry.nX = aPt.x; 4249cdf0e10cSrcweir pFrame->maGeometry.nY = aPt.y; 4250cdf0e10cSrcweir 4251cdf0e10cSrcweir RECT aInnerRect; 4252cdf0e10cSrcweir GetClientRect( hWnd, &aInnerRect ); 4253cdf0e10cSrcweir if( aInnerRect.right ) 4254cdf0e10cSrcweir { 4255cdf0e10cSrcweir // improve right decoration 4256cdf0e10cSrcweir aPt.x=aInnerRect.right; 4257cdf0e10cSrcweir aPt.y=aInnerRect.top; 4258cdf0e10cSrcweir ClientToScreen(hWnd, &aPt); 4259cdf0e10cSrcweir pFrame->maGeometry.nRightDecoration = aRect.right - aPt.x; 4260cdf0e10cSrcweir } 4261cdf0e10cSrcweir if( aInnerRect.bottom ) // may be zero if window was not shown yet 4262cdf0e10cSrcweir pFrame->maGeometry.nBottomDecoration += aRect.bottom - aPt.y - aInnerRect.bottom; 4263cdf0e10cSrcweir else 4264cdf0e10cSrcweir // bottom border is typically the same as left/right 4265cdf0e10cSrcweir pFrame->maGeometry.nBottomDecoration = pFrame->maGeometry.nLeftDecoration; 4266cdf0e10cSrcweir 4267cdf0e10cSrcweir int nWidth = aRect.right - aRect.left 4268cdf0e10cSrcweir - pFrame->maGeometry.nRightDecoration - pFrame->maGeometry.nLeftDecoration; 4269cdf0e10cSrcweir int nHeight = aRect.bottom - aRect.top 4270cdf0e10cSrcweir - pFrame->maGeometry.nBottomDecoration - pFrame->maGeometry.nTopDecoration; 4271cdf0e10cSrcweir // clamp to zero 4272cdf0e10cSrcweir pFrame->maGeometry.nHeight = nHeight < 0 ? 0 : nHeight; 4273cdf0e10cSrcweir pFrame->maGeometry.nWidth = nWidth < 0 ? 0 : nWidth; 4274cdf0e10cSrcweir pFrame->updateScreenNumber(); 4275cdf0e10cSrcweir } 4276cdf0e10cSrcweir 4277cdf0e10cSrcweir // ----------------------------------------------------------------------- 4278cdf0e10cSrcweir 4279cdf0e10cSrcweir static void ImplCallMoveHdl( HWND hWnd ) 4280cdf0e10cSrcweir { 4281cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4282cdf0e10cSrcweir if ( pFrame ) 4283cdf0e10cSrcweir { 4284cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_MOVE, 0 ); 4285cdf0e10cSrcweir // Um doppelte Paints von VCL und SAL zu vermeiden 4286cdf0e10cSrcweir //if ( IsWindowVisible( hWnd ) && !pFrame->mbInShow ) 4287cdf0e10cSrcweir // UpdateWindow( hWnd ); 4288cdf0e10cSrcweir } 4289cdf0e10cSrcweir } 4290cdf0e10cSrcweir 4291cdf0e10cSrcweir // ----------------------------------------------------------------------- 4292cdf0e10cSrcweir 4293cdf0e10cSrcweir static void ImplCallClosePopupsHdl( HWND hWnd ) 4294cdf0e10cSrcweir { 4295cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4296cdf0e10cSrcweir if ( pFrame ) 4297cdf0e10cSrcweir { 4298cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_CLOSEPOPUPS, 0 ); 4299cdf0e10cSrcweir } 4300cdf0e10cSrcweir } 4301cdf0e10cSrcweir 4302cdf0e10cSrcweir // ----------------------------------------------------------------------- 4303cdf0e10cSrcweir 4304cdf0e10cSrcweir static void ImplHandleMoveMsg( HWND hWnd ) 4305cdf0e10cSrcweir { 4306cdf0e10cSrcweir if ( ImplSalYieldMutexTryToAcquire() ) 4307cdf0e10cSrcweir { 4308cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4309cdf0e10cSrcweir if ( pFrame ) 4310cdf0e10cSrcweir { 4311cdf0e10cSrcweir UpdateFrameGeometry( hWnd, pFrame ); 4312cdf0e10cSrcweir 4313cdf0e10cSrcweir if ( GetWindowStyle( hWnd ) & WS_VISIBLE ) 4314cdf0e10cSrcweir pFrame->mbDefPos = FALSE; 4315cdf0e10cSrcweir 4316cdf0e10cSrcweir // Gegen moegliche Rekursionen sichern 4317cdf0e10cSrcweir if ( !pFrame->mbInMoveMsg ) 4318cdf0e10cSrcweir { 4319cdf0e10cSrcweir // Fenster im FullScreenModus wieder einpassen 4320cdf0e10cSrcweir pFrame->mbInMoveMsg = TRUE; 4321cdf0e10cSrcweir if ( pFrame->mbFullScreen ) 4322cdf0e10cSrcweir ImplSalFrameFullScreenPos( pFrame ); 4323cdf0e10cSrcweir pFrame->mbInMoveMsg = FALSE; 4324cdf0e10cSrcweir } 4325cdf0e10cSrcweir 4326cdf0e10cSrcweir // Status merken 4327cdf0e10cSrcweir ImplSaveFrameState( pFrame ); 4328cdf0e10cSrcweir 4329cdf0e10cSrcweir // Call Hdl 4330cdf0e10cSrcweir //#93851 if we call this handler, VCL floating windows are not updated correctly 4331cdf0e10cSrcweir ImplCallMoveHdl( hWnd ); 4332cdf0e10cSrcweir 4333cdf0e10cSrcweir } 4334cdf0e10cSrcweir 4335cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4336cdf0e10cSrcweir } 4337cdf0e10cSrcweir else 4338cdf0e10cSrcweir ImplPostMessage( hWnd, SAL_MSG_POSTMOVE, 0, 0 ); 4339cdf0e10cSrcweir } 4340cdf0e10cSrcweir 4341cdf0e10cSrcweir // ----------------------------------------------------------------------- 4342cdf0e10cSrcweir 4343cdf0e10cSrcweir static void ImplCallSizeHdl( HWND hWnd ) 4344cdf0e10cSrcweir { 4345cdf0e10cSrcweir // Da Windows diese Messages auch senden kann, muss hier auch die 4346cdf0e10cSrcweir // Solar-Semaphore beruecksichtigt werden 4347cdf0e10cSrcweir if ( ImplSalYieldMutexTryToAcquire() ) 4348cdf0e10cSrcweir { 4349cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4350cdf0e10cSrcweir if ( pFrame ) 4351cdf0e10cSrcweir { 4352cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_RESIZE, 0 ); 4353cdf0e10cSrcweir // Um doppelte Paints von VCL und SAL zu vermeiden 4354cdf0e10cSrcweir if ( IsWindowVisible( hWnd ) && !pFrame->mbInShow ) 4355cdf0e10cSrcweir UpdateWindow( hWnd ); 4356cdf0e10cSrcweir } 4357cdf0e10cSrcweir 4358cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4359cdf0e10cSrcweir } 4360cdf0e10cSrcweir else 4361cdf0e10cSrcweir ImplPostMessage( hWnd, SAL_MSG_POSTCALLSIZE, 0, 0 ); 4362cdf0e10cSrcweir } 4363cdf0e10cSrcweir 4364cdf0e10cSrcweir // ----------------------------------------------------------------------- 4365cdf0e10cSrcweir 4366cdf0e10cSrcweir static void ImplHandleSizeMsg( HWND hWnd, WPARAM wParam, LPARAM lParam ) 4367cdf0e10cSrcweir { 4368cdf0e10cSrcweir if ( (wParam != SIZE_MAXSHOW) && (wParam != SIZE_MAXHIDE) ) 4369cdf0e10cSrcweir { 4370cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4371cdf0e10cSrcweir if ( pFrame ) 4372cdf0e10cSrcweir { 4373cdf0e10cSrcweir UpdateFrameGeometry( hWnd, pFrame ); 4374cdf0e10cSrcweir 4375cdf0e10cSrcweir pFrame->mnWidth = (int)LOWORD(lParam); 4376cdf0e10cSrcweir pFrame->mnHeight = (int)HIWORD(lParam); 4377cdf0e10cSrcweir // Status merken 4378cdf0e10cSrcweir ImplSaveFrameState( pFrame ); 4379cdf0e10cSrcweir // Call Hdl 4380cdf0e10cSrcweir ImplCallSizeHdl( hWnd ); 4381cdf0e10cSrcweir } 4382cdf0e10cSrcweir } 4383cdf0e10cSrcweir } 4384cdf0e10cSrcweir 4385cdf0e10cSrcweir // ----------------------------------------------------------------------- 4386cdf0e10cSrcweir 4387cdf0e10cSrcweir static void ImplHandleFocusMsg( HWND hWnd ) 4388cdf0e10cSrcweir { 4389cdf0e10cSrcweir if ( ImplSalYieldMutexTryToAcquire() ) 4390cdf0e10cSrcweir { 4391cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4392cdf0e10cSrcweir if ( pFrame && !WinSalFrame::mbInReparent ) 4393cdf0e10cSrcweir { 4394cdf0e10cSrcweir // Query the actual status 4395cdf0e10cSrcweir if ( ::GetFocus() == hWnd ) 4396cdf0e10cSrcweir { 4397cdf0e10cSrcweir if ( IsWindowVisible( hWnd ) && !pFrame->mbInShow ) 4398cdf0e10cSrcweir UpdateWindow( hWnd ); 4399cdf0e10cSrcweir 4400cdf0e10cSrcweir // Feststellen, ob wir IME unterstuetzen 4401cdf0e10cSrcweir if ( pFrame->mbIME && pFrame->mhDefIMEContext ) 4402cdf0e10cSrcweir { 4403cdf0e10cSrcweir UINT nImeProps = ImmGetProperty( GetKeyboardLayout( 0 ), IGP_PROPERTY ); 4404cdf0e10cSrcweir 4405cdf0e10cSrcweir pFrame->mbSpezIME = (nImeProps & IME_PROP_SPECIAL_UI) != 0; 4406cdf0e10cSrcweir pFrame->mbAtCursorIME = (nImeProps & IME_PROP_AT_CARET) != 0; 4407cdf0e10cSrcweir pFrame->mbHandleIME = !pFrame->mbSpezIME; 4408cdf0e10cSrcweir } 4409cdf0e10cSrcweir 4410cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_GETFOCUS, 0 ); 4411cdf0e10cSrcweir } 4412cdf0e10cSrcweir else 4413cdf0e10cSrcweir { 4414cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_LOSEFOCUS, 0 ); 4415cdf0e10cSrcweir } 4416cdf0e10cSrcweir } 4417cdf0e10cSrcweir 4418cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4419cdf0e10cSrcweir } 4420cdf0e10cSrcweir else 4421cdf0e10cSrcweir ImplPostMessage( hWnd, SAL_MSG_POSTFOCUS, 0, 0 ); 4422cdf0e10cSrcweir } 4423cdf0e10cSrcweir 4424cdf0e10cSrcweir // ----------------------------------------------------------------------- 4425cdf0e10cSrcweir 4426cdf0e10cSrcweir static void ImplHandleCloseMsg( HWND hWnd ) 4427cdf0e10cSrcweir { 4428cdf0e10cSrcweir if ( ImplSalYieldMutexTryToAcquire() ) 4429cdf0e10cSrcweir { 4430cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4431cdf0e10cSrcweir if ( pFrame ) 4432cdf0e10cSrcweir { 4433cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_CLOSE, 0 ); 4434cdf0e10cSrcweir } 4435cdf0e10cSrcweir 4436cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4437cdf0e10cSrcweir } 4438cdf0e10cSrcweir else 4439cdf0e10cSrcweir ImplPostMessage( hWnd, WM_CLOSE, 0, 0 ); 4440cdf0e10cSrcweir } 4441cdf0e10cSrcweir 4442cdf0e10cSrcweir // ----------------------------------------------------------------------- 4443cdf0e10cSrcweir 4444cdf0e10cSrcweir static long ImplHandleShutDownMsg( HWND hWnd ) 4445cdf0e10cSrcweir { 4446cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 4447cdf0e10cSrcweir long nRet = 0; 4448cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4449cdf0e10cSrcweir if ( pFrame ) 4450cdf0e10cSrcweir { 4451cdf0e10cSrcweir nRet = pFrame->CallCallback( SALEVENT_SHUTDOWN, 0 ); 4452cdf0e10cSrcweir } 4453cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4454cdf0e10cSrcweir return nRet; 4455cdf0e10cSrcweir } 4456cdf0e10cSrcweir 4457cdf0e10cSrcweir // ----------------------------------------------------------------------- 4458cdf0e10cSrcweir 4459cdf0e10cSrcweir static void ImplHandleSettingsChangeMsg( HWND hWnd, UINT nMsg, 4460cdf0e10cSrcweir WPARAM wParam, LPARAM lParam ) 4461cdf0e10cSrcweir { 4462cdf0e10cSrcweir sal_uInt16 nSalEvent = SALEVENT_SETTINGSCHANGED; 4463cdf0e10cSrcweir 4464cdf0e10cSrcweir if ( nMsg == WM_DEVMODECHANGE ) 4465cdf0e10cSrcweir nSalEvent = SALEVENT_PRINTERCHANGED; 4466cdf0e10cSrcweir else if ( nMsg == WM_DISPLAYCHANGE ) 4467cdf0e10cSrcweir nSalEvent = SALEVENT_DISPLAYCHANGED; 4468cdf0e10cSrcweir else if ( nMsg == WM_FONTCHANGE ) 4469cdf0e10cSrcweir nSalEvent = SALEVENT_FONTCHANGED; 4470cdf0e10cSrcweir else if ( nMsg == WM_TIMECHANGE ) 4471cdf0e10cSrcweir nSalEvent = SALEVENT_DATETIMECHANGED; 4472cdf0e10cSrcweir else if ( nMsg == WM_WININICHANGE ) 4473cdf0e10cSrcweir { 4474cdf0e10cSrcweir if ( lParam ) 4475cdf0e10cSrcweir { 4476cdf0e10cSrcweir if ( ImplSalWICompareAscii( (const wchar_t*)lParam, "devices" ) == 0 ) 4477cdf0e10cSrcweir nSalEvent = SALEVENT_PRINTERCHANGED; 4478cdf0e10cSrcweir } 4479cdf0e10cSrcweir } 4480cdf0e10cSrcweir 4481cdf0e10cSrcweir if ( nMsg == WM_SETTINGCHANGE ) 4482cdf0e10cSrcweir { 4483cdf0e10cSrcweir if ( wParam == SPI_SETWHEELSCROLLLINES ) 4484cdf0e10cSrcweir aSalShlData.mnWheelScrollLines = ImplSalGetWheelScrollLines(); 4485cdf0e10cSrcweir else if( wParam == SPI_SETWHEELSCROLLCHARS ) 4486cdf0e10cSrcweir aSalShlData.mnWheelScrollChars = ImplSalGetWheelScrollChars(); 4487cdf0e10cSrcweir } 4488cdf0e10cSrcweir 4489cdf0e10cSrcweir if ( WM_SYSCOLORCHANGE == nMsg && GetSalData()->mhDitherPal ) 4490cdf0e10cSrcweir ImplUpdateSysColorEntries(); 4491cdf0e10cSrcweir 4492cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 4493cdf0e10cSrcweir 4494cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4495cdf0e10cSrcweir if ( pFrame ) 4496cdf0e10cSrcweir { 4497cdf0e10cSrcweir if ( (nMsg == WM_DISPLAYCHANGE) || (nMsg == WM_WININICHANGE) ) 4498cdf0e10cSrcweir { 4499cdf0e10cSrcweir if ( pFrame->mbFullScreen ) 4500cdf0e10cSrcweir ImplSalFrameFullScreenPos( pFrame ); 4501cdf0e10cSrcweir } 4502cdf0e10cSrcweir 4503cdf0e10cSrcweir pFrame->CallCallback( nSalEvent, 0 ); 4504cdf0e10cSrcweir } 4505cdf0e10cSrcweir 4506cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4507cdf0e10cSrcweir } 4508cdf0e10cSrcweir 4509cdf0e10cSrcweir // ----------------------------------------------------------------------- 4510cdf0e10cSrcweir 4511cdf0e10cSrcweir static void ImplHandleUserEvent( HWND hWnd, LPARAM lParam ) 4512cdf0e10cSrcweir { 4513cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 4514cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4515cdf0e10cSrcweir if ( pFrame ) 4516cdf0e10cSrcweir { 4517cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_USEREVENT, (void*)lParam ); 4518cdf0e10cSrcweir } 4519cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4520cdf0e10cSrcweir } 4521cdf0e10cSrcweir 4522cdf0e10cSrcweir // ----------------------------------------------------------------------- 4523cdf0e10cSrcweir 4524cdf0e10cSrcweir static void ImplHandleForcePalette( HWND hWnd ) 4525cdf0e10cSrcweir { 4526cdf0e10cSrcweir SalData* pSalData = GetSalData(); 4527cdf0e10cSrcweir HPALETTE hPal = pSalData->mhDitherPal; 4528cdf0e10cSrcweir if ( hPal ) 4529cdf0e10cSrcweir { 4530cdf0e10cSrcweir if ( !ImplSalYieldMutexTryToAcquire() ) 4531cdf0e10cSrcweir { 4532cdf0e10cSrcweir ImplPostMessage( hWnd, SAL_MSG_FORCEPALETTE, 0, 0 ); 4533cdf0e10cSrcweir return; 4534cdf0e10cSrcweir } 4535cdf0e10cSrcweir 4536cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4537cdf0e10cSrcweir if ( pFrame && pFrame->mpGraphics ) 4538cdf0e10cSrcweir { 4539cdf0e10cSrcweir WinSalGraphics* pGraphics = pFrame->mpGraphics; 4540cdf0e10cSrcweir if ( pGraphics && pGraphics->mhDefPal ) 4541cdf0e10cSrcweir { 45425f27b83cSArmin Le Grand SelectPalette( pGraphics->getHDC(), hPal, FALSE ); 45435f27b83cSArmin Le Grand if ( RealizePalette( pGraphics->getHDC() ) ) 4544cdf0e10cSrcweir { 4545cdf0e10cSrcweir InvalidateRect( hWnd, NULL, FALSE ); 4546cdf0e10cSrcweir UpdateWindow( hWnd ); 4547cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_DISPLAYCHANGED, 0 ); 4548cdf0e10cSrcweir } 4549cdf0e10cSrcweir } 4550cdf0e10cSrcweir } 4551cdf0e10cSrcweir 4552cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4553cdf0e10cSrcweir } 4554cdf0e10cSrcweir } 4555cdf0e10cSrcweir 4556cdf0e10cSrcweir // ----------------------------------------------------------------------- 4557cdf0e10cSrcweir 4558cdf0e10cSrcweir static LRESULT ImplHandlePalette( sal_Bool bFrame, HWND hWnd, UINT nMsg, 4559cdf0e10cSrcweir WPARAM wParam, LPARAM lParam, int& rDef ) 4560cdf0e10cSrcweir { 4561cdf0e10cSrcweir SalData* pSalData = GetSalData(); 4562cdf0e10cSrcweir HPALETTE hPal = pSalData->mhDitherPal; 4563cdf0e10cSrcweir if ( !hPal ) 4564cdf0e10cSrcweir return 0; 4565cdf0e10cSrcweir 4566cdf0e10cSrcweir rDef = FALSE; 4567cdf0e10cSrcweir if ( pSalData->mbInPalChange ) 4568cdf0e10cSrcweir return 0; 4569cdf0e10cSrcweir 4570cdf0e10cSrcweir if ( (nMsg == WM_PALETTECHANGED) || (nMsg == SAL_MSG_POSTPALCHANGED) ) 4571cdf0e10cSrcweir { 4572cdf0e10cSrcweir if ( (HWND)wParam == hWnd ) 4573cdf0e10cSrcweir return 0; 4574cdf0e10cSrcweir } 4575cdf0e10cSrcweir 4576cdf0e10cSrcweir sal_Bool bReleaseMutex = FALSE; 4577cdf0e10cSrcweir if ( (nMsg == WM_QUERYNEWPALETTE) || (nMsg == WM_PALETTECHANGED) ) 4578cdf0e10cSrcweir { 4579cdf0e10cSrcweir // Da Windows diese Messages auch sendet, muss hier auch die 4580cdf0e10cSrcweir // Solar-Semaphore beruecksichtigt werden 4581cdf0e10cSrcweir if ( ImplSalYieldMutexTryToAcquire() ) 4582cdf0e10cSrcweir bReleaseMutex = TRUE; 4583cdf0e10cSrcweir else if ( nMsg == WM_QUERYNEWPALETTE ) 4584cdf0e10cSrcweir ImplPostMessage( hWnd, SAL_MSG_POSTQUERYNEWPAL, wParam, lParam ); 4585cdf0e10cSrcweir else /* ( nMsg == WM_PALETTECHANGED ) */ 4586cdf0e10cSrcweir ImplPostMessage( hWnd, SAL_MSG_POSTPALCHANGED, wParam, lParam ); 4587cdf0e10cSrcweir } 4588cdf0e10cSrcweir 4589cdf0e10cSrcweir WinSalVirtualDevice*pTempVD; 4590cdf0e10cSrcweir WinSalFrame* pTempFrame; 4591cdf0e10cSrcweir WinSalGraphics* pGraphics; 4592cdf0e10cSrcweir HDC hDC; 4593cdf0e10cSrcweir HPALETTE hOldPal; 4594cdf0e10cSrcweir UINT nCols; 4595cdf0e10cSrcweir sal_Bool bStdDC; 4596cdf0e10cSrcweir sal_Bool bUpdate; 4597cdf0e10cSrcweir 4598cdf0e10cSrcweir pSalData->mbInPalChange = TRUE; 4599cdf0e10cSrcweir 4600cdf0e10cSrcweir // Alle Paletten in VirDevs und Frames zuruecksetzen 4601cdf0e10cSrcweir pTempVD = pSalData->mpFirstVD; 4602cdf0e10cSrcweir while ( pTempVD ) 4603cdf0e10cSrcweir { 4604cdf0e10cSrcweir pGraphics = pTempVD->mpGraphics; 4605cdf0e10cSrcweir if ( pGraphics->mhDefPal ) 4606cdf0e10cSrcweir { 46075f27b83cSArmin Le Grand SelectPalette( pGraphics->getHDC(), 4608cdf0e10cSrcweir pGraphics->mhDefPal, 4609cdf0e10cSrcweir TRUE ); 4610cdf0e10cSrcweir } 4611cdf0e10cSrcweir pTempVD = pTempVD->mpNext; 4612cdf0e10cSrcweir } 4613cdf0e10cSrcweir pTempFrame = pSalData->mpFirstFrame; 4614cdf0e10cSrcweir while ( pTempFrame ) 4615cdf0e10cSrcweir { 4616cdf0e10cSrcweir pGraphics = pTempFrame->mpGraphics; 4617cdf0e10cSrcweir if ( pGraphics && pGraphics->mhDefPal ) 4618cdf0e10cSrcweir { 46195f27b83cSArmin Le Grand SelectPalette( pGraphics->getHDC(), 4620cdf0e10cSrcweir pGraphics->mhDefPal, 4621cdf0e10cSrcweir TRUE ); 4622cdf0e10cSrcweir } 4623cdf0e10cSrcweir pTempFrame = pTempFrame->mpNextFrame; 4624cdf0e10cSrcweir } 4625cdf0e10cSrcweir 4626cdf0e10cSrcweir // Palette neu realizen 4627cdf0e10cSrcweir WinSalFrame* pFrame = NULL; 4628cdf0e10cSrcweir if ( bFrame ) 4629cdf0e10cSrcweir pFrame = GetWindowPtr( hWnd ); 4630cdf0e10cSrcweir if ( pFrame && pFrame->mpGraphics ) 4631cdf0e10cSrcweir { 46325f27b83cSArmin Le Grand hDC = pFrame->mpGraphics->getHDC(); 4633cdf0e10cSrcweir bStdDC = TRUE; 4634cdf0e10cSrcweir } 4635cdf0e10cSrcweir else 4636cdf0e10cSrcweir { 4637cdf0e10cSrcweir hDC = GetDC( hWnd ); 4638cdf0e10cSrcweir bStdDC = FALSE; 4639cdf0e10cSrcweir } 4640cdf0e10cSrcweir UnrealizeObject( hPal ); 4641cdf0e10cSrcweir hOldPal = SelectPalette( hDC, hPal, TRUE ); 4642cdf0e10cSrcweir nCols = RealizePalette( hDC ); 4643cdf0e10cSrcweir bUpdate = nCols != 0; 4644cdf0e10cSrcweir if ( !bStdDC ) 4645cdf0e10cSrcweir { 4646cdf0e10cSrcweir SelectPalette( hDC, hOldPal, TRUE ); 4647cdf0e10cSrcweir ReleaseDC( hWnd, hDC ); 4648cdf0e10cSrcweir } 4649cdf0e10cSrcweir 4650cdf0e10cSrcweir // Alle Paletten in VirDevs und Frames neu setzen 4651cdf0e10cSrcweir pTempVD = pSalData->mpFirstVD; 4652cdf0e10cSrcweir while ( pTempVD ) 4653cdf0e10cSrcweir { 4654cdf0e10cSrcweir pGraphics = pTempVD->mpGraphics; 4655cdf0e10cSrcweir if ( pGraphics->mhDefPal ) 4656cdf0e10cSrcweir { 46575f27b83cSArmin Le Grand SelectPalette( pGraphics->getHDC(), hPal, TRUE ); 46585f27b83cSArmin Le Grand RealizePalette( pGraphics->getHDC() ); 4659cdf0e10cSrcweir } 4660cdf0e10cSrcweir pTempVD = pTempVD->mpNext; 4661cdf0e10cSrcweir } 4662cdf0e10cSrcweir pTempFrame = pSalData->mpFirstFrame; 4663cdf0e10cSrcweir while ( pTempFrame ) 4664cdf0e10cSrcweir { 4665cdf0e10cSrcweir if ( pTempFrame != pFrame ) 4666cdf0e10cSrcweir { 4667cdf0e10cSrcweir pGraphics = pTempFrame->mpGraphics; 4668cdf0e10cSrcweir if ( pGraphics && pGraphics->mhDefPal ) 4669cdf0e10cSrcweir { 46705f27b83cSArmin Le Grand SelectPalette( pGraphics->getHDC(), hPal, TRUE ); 46715f27b83cSArmin Le Grand if ( RealizePalette( pGraphics->getHDC() ) ) 4672cdf0e10cSrcweir bUpdate = TRUE; 4673cdf0e10cSrcweir } 4674cdf0e10cSrcweir } 4675cdf0e10cSrcweir pTempFrame = pTempFrame->mpNextFrame; 4676cdf0e10cSrcweir } 4677cdf0e10cSrcweir 4678cdf0e10cSrcweir // Wenn sich Farben geaendert haben, dann die Fenster updaten 4679cdf0e10cSrcweir if ( bUpdate ) 4680cdf0e10cSrcweir { 4681cdf0e10cSrcweir pTempFrame = pSalData->mpFirstFrame; 4682cdf0e10cSrcweir while ( pTempFrame ) 4683cdf0e10cSrcweir { 4684cdf0e10cSrcweir pGraphics = pTempFrame->mpGraphics; 4685cdf0e10cSrcweir if ( pGraphics && pGraphics->mhDefPal ) 4686cdf0e10cSrcweir { 4687cdf0e10cSrcweir InvalidateRect( pTempFrame->mhWnd, NULL, FALSE ); 4688cdf0e10cSrcweir UpdateWindow( pTempFrame->mhWnd ); 4689cdf0e10cSrcweir pTempFrame->CallCallback( SALEVENT_DISPLAYCHANGED, 0 ); 4690cdf0e10cSrcweir } 4691cdf0e10cSrcweir pTempFrame = pTempFrame->mpNextFrame; 4692cdf0e10cSrcweir } 4693cdf0e10cSrcweir } 4694cdf0e10cSrcweir 4695cdf0e10cSrcweir pSalData->mbInPalChange = FALSE; 4696cdf0e10cSrcweir 4697cdf0e10cSrcweir if ( bReleaseMutex ) 4698cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4699cdf0e10cSrcweir 4700cdf0e10cSrcweir if ( nMsg == WM_PALETTECHANGED ) 4701cdf0e10cSrcweir return 0; 4702cdf0e10cSrcweir else 4703cdf0e10cSrcweir return nCols; 4704cdf0e10cSrcweir } 4705cdf0e10cSrcweir 4706cdf0e10cSrcweir // ----------------------------------------------------------------------- 4707cdf0e10cSrcweir 4708cdf0e10cSrcweir static int ImplHandleMinMax( HWND hWnd, LPARAM lParam ) 4709cdf0e10cSrcweir { 4710cdf0e10cSrcweir int bRet = FALSE; 4711cdf0e10cSrcweir 4712cdf0e10cSrcweir if ( ImplSalYieldMutexTryToAcquire() ) 4713cdf0e10cSrcweir { 4714cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 4715cdf0e10cSrcweir if ( pFrame ) 4716cdf0e10cSrcweir { 4717cdf0e10cSrcweir MINMAXINFO* pMinMax = (MINMAXINFO*)lParam; 4718cdf0e10cSrcweir 4719cdf0e10cSrcweir if ( pFrame->mbFullScreen ) 4720cdf0e10cSrcweir { 4721cdf0e10cSrcweir int nX; 4722cdf0e10cSrcweir int nY; 4723cdf0e10cSrcweir int nDX; 4724cdf0e10cSrcweir int nDY; 4725cdf0e10cSrcweir ImplSalCalcFullScreenSize( pFrame, nX, nY, nDX, nDY ); 4726cdf0e10cSrcweir 4727cdf0e10cSrcweir if ( pMinMax->ptMaxPosition.x > nX ) 4728cdf0e10cSrcweir pMinMax->ptMaxPosition.x = nX; 4729cdf0e10cSrcweir if ( pMinMax->ptMaxPosition.y > nY ) 4730cdf0e10cSrcweir pMinMax->ptMaxPosition.y = nY; 4731cdf0e10cSrcweir 4732cdf0e10cSrcweir if ( pMinMax->ptMaxSize.x < nDX ) 4733cdf0e10cSrcweir pMinMax->ptMaxSize.x = nDX; 4734cdf0e10cSrcweir if ( pMinMax->ptMaxSize.y < nDY ) 4735cdf0e10cSrcweir pMinMax->ptMaxSize.y = nDY; 4736cdf0e10cSrcweir if ( pMinMax->ptMaxTrackSize.x < nDX ) 4737cdf0e10cSrcweir pMinMax->ptMaxTrackSize.x = nDX; 4738cdf0e10cSrcweir if ( pMinMax->ptMaxTrackSize.y < nDY ) 4739cdf0e10cSrcweir pMinMax->ptMaxTrackSize.y = nDY; 4740cdf0e10cSrcweir 4741cdf0e10cSrcweir pMinMax->ptMinTrackSize.x = nDX; 4742cdf0e10cSrcweir pMinMax->ptMinTrackSize.y = nDY; 4743cdf0e10cSrcweir 4744cdf0e10cSrcweir bRet = TRUE; 4745cdf0e10cSrcweir } 4746cdf0e10cSrcweir 4747cdf0e10cSrcweir if ( pFrame->mnMinWidth || pFrame->mnMinHeight ) 4748cdf0e10cSrcweir { 4749cdf0e10cSrcweir int nWidth = pFrame->mnMinWidth; 4750cdf0e10cSrcweir int nHeight = pFrame->mnMinHeight; 4751cdf0e10cSrcweir 4752cdf0e10cSrcweir ImplSalAddBorder( pFrame, nWidth, nHeight ); 4753cdf0e10cSrcweir 4754cdf0e10cSrcweir if ( pMinMax->ptMinTrackSize.x < nWidth ) 4755cdf0e10cSrcweir pMinMax->ptMinTrackSize.x = nWidth; 4756cdf0e10cSrcweir if ( pMinMax->ptMinTrackSize.y < nHeight ) 4757cdf0e10cSrcweir pMinMax->ptMinTrackSize.y = nHeight; 4758cdf0e10cSrcweir } 4759cdf0e10cSrcweir 4760cdf0e10cSrcweir if ( pFrame->mnMaxWidth || pFrame->mnMaxHeight ) 4761cdf0e10cSrcweir { 4762cdf0e10cSrcweir int nWidth = pFrame->mnMaxWidth; 4763cdf0e10cSrcweir int nHeight = pFrame->mnMaxHeight; 4764cdf0e10cSrcweir 4765cdf0e10cSrcweir ImplSalAddBorder( pFrame, nWidth, nHeight ); 4766cdf0e10cSrcweir 4767cdf0e10cSrcweir if( nWidth > 0 && nHeight > 0 ) // protect against int overflow due to INT_MAX initialisation 4768cdf0e10cSrcweir { 4769cdf0e10cSrcweir if ( pMinMax->ptMaxTrackSize.x > nWidth ) 4770cdf0e10cSrcweir pMinMax->ptMaxTrackSize.x = nWidth; 4771cdf0e10cSrcweir if ( pMinMax->ptMaxTrackSize.y > nHeight ) 4772cdf0e10cSrcweir pMinMax->ptMaxTrackSize.y = nHeight; 4773cdf0e10cSrcweir } 4774cdf0e10cSrcweir } 4775cdf0e10cSrcweir } 4776cdf0e10cSrcweir 4777cdf0e10cSrcweir ImplSalYieldMutexRelease(); 4778cdf0e10cSrcweir } 4779cdf0e10cSrcweir 4780cdf0e10cSrcweir return bRet; 4781cdf0e10cSrcweir } 4782cdf0e10cSrcweir 4783cdf0e10cSrcweir // ----------------------------------------------------------------------- 4784cdf0e10cSrcweir 4785cdf0e10cSrcweir // retrieves the SalMenuItem pointer from a hMenu 4786cdf0e10cSrcweir // the pointer is stored in every item, so if no position 4787cdf0e10cSrcweir // is specified we just use the first item (ie, pos=0) 4788cdf0e10cSrcweir // if bByPosition is FALSE then nPos denotes a menu id instead of a position 4789cdf0e10cSrcweir static WinSalMenuItem* ImplGetSalMenuItem( HMENU hMenu, UINT nPos, sal_Bool bByPosition=TRUE ) 4790cdf0e10cSrcweir { 4791cdf0e10cSrcweir DWORD err=0; 4792cdf0e10cSrcweir 4793cdf0e10cSrcweir MENUITEMINFOW mi; 4794cdf0e10cSrcweir memset(&mi, 0, sizeof(mi)); 4795cdf0e10cSrcweir mi.cbSize = sizeof( mi ); 4796cdf0e10cSrcweir mi.fMask = MIIM_DATA; 4797cdf0e10cSrcweir if( !GetMenuItemInfoW( hMenu, nPos, bByPosition, &mi) ) 4798cdf0e10cSrcweir err = GetLastError(); 4799cdf0e10cSrcweir 4800cdf0e10cSrcweir return (WinSalMenuItem *) mi.dwItemData; 4801cdf0e10cSrcweir } 4802cdf0e10cSrcweir 4803cdf0e10cSrcweir // returns the index of the currently selected item if any or -1 4804cdf0e10cSrcweir static int ImplGetSelectedIndex( HMENU hMenu ) 4805cdf0e10cSrcweir { 4806cdf0e10cSrcweir DWORD err=0; 4807cdf0e10cSrcweir 4808cdf0e10cSrcweir MENUITEMINFOW mi; 4809cdf0e10cSrcweir memset(&mi, 0, sizeof(mi)); 4810cdf0e10cSrcweir mi.cbSize = sizeof( mi ); 4811cdf0e10cSrcweir mi.fMask = MIIM_STATE; 4812cdf0e10cSrcweir int n = GetMenuItemCount( hMenu ); 4813cdf0e10cSrcweir if( n != -1 ) 4814cdf0e10cSrcweir { 4815cdf0e10cSrcweir for(int i=0; i<n; i++ ) 4816cdf0e10cSrcweir { 4817cdf0e10cSrcweir if( !GetMenuItemInfoW( hMenu, i, TRUE, &mi) ) 4818cdf0e10cSrcweir err = GetLastError(); 4819cdf0e10cSrcweir else 4820cdf0e10cSrcweir { 4821cdf0e10cSrcweir if( mi.fState & MFS_HILITE ) 4822cdf0e10cSrcweir return i; 4823cdf0e10cSrcweir } 4824cdf0e10cSrcweir } 4825cdf0e10cSrcweir } 4826cdf0e10cSrcweir return -1; 4827cdf0e10cSrcweir } 4828cdf0e10cSrcweir 4829cdf0e10cSrcweir static int ImplMenuChar( HWND, WPARAM wParam, LPARAM lParam ) 4830cdf0e10cSrcweir { 4831cdf0e10cSrcweir int nRet = MNC_IGNORE; 4832cdf0e10cSrcweir HMENU hMenu = (HMENU) lParam; 4833cdf0e10cSrcweir String aMnemonic; 4834cdf0e10cSrcweir aMnemonic.AssignAscii("&"); 4835cdf0e10cSrcweir aMnemonic.Append( (sal_Unicode) LOWORD(wParam) ); 4836cdf0e10cSrcweir aMnemonic.ToLowerAscii(); // we only have ascii mnemonics 4837cdf0e10cSrcweir 4838cdf0e10cSrcweir // search the mnemonic in the current menu 4839cdf0e10cSrcweir int nItemCount = GetMenuItemCount( hMenu ); 4840cdf0e10cSrcweir int nFound = 0; 4841cdf0e10cSrcweir int idxFound = -1; 4842cdf0e10cSrcweir int idxSelected = ImplGetSelectedIndex( hMenu ); 4843cdf0e10cSrcweir int idx = idxSelected != -1 ? idxSelected+1 : 0; // if duplicate mnemonics cycle through menu 4844cdf0e10cSrcweir for( int i=0; i< nItemCount; i++, idx++ ) 4845cdf0e10cSrcweir { 4846cdf0e10cSrcweir WinSalMenuItem* pSalMenuItem = ImplGetSalMenuItem( hMenu, idx % nItemCount ); 4847cdf0e10cSrcweir if( !pSalMenuItem ) 4848cdf0e10cSrcweir continue; 4849cdf0e10cSrcweir String aStr = pSalMenuItem->mText; 4850cdf0e10cSrcweir aStr.ToLowerAscii(); 4851cdf0e10cSrcweir if( aStr.Search( aMnemonic ) != STRING_NOTFOUND) 4852cdf0e10cSrcweir { 4853cdf0e10cSrcweir if( idxFound == -1 ) 4854cdf0e10cSrcweir idxFound = idx % nItemCount; 4855cdf0e10cSrcweir if( nFound++ ) 4856cdf0e10cSrcweir break; // duplicate found 4857cdf0e10cSrcweir } 4858cdf0e10cSrcweir } 4859cdf0e10cSrcweir if( nFound == 1 ) 4860cdf0e10cSrcweir nRet = MAKELRESULT( idxFound, MNC_EXECUTE ); 4861cdf0e10cSrcweir else 4862cdf0e10cSrcweir // duplicate mnemonics, just select the next occurence 4863cdf0e10cSrcweir nRet = MAKELRESULT( idxFound, MNC_SELECT ); 4864cdf0e10cSrcweir 4865cdf0e10cSrcweir return nRet; 4866cdf0e10cSrcweir } 4867cdf0e10cSrcweir 4868cdf0e10cSrcweir static int ImplMeasureItem( HWND hWnd, WPARAM wParam, LPARAM lParam ) 4869cdf0e10cSrcweir { 4870cdf0e10cSrcweir int nRet = 0; 4871cdf0e10cSrcweir if( !wParam ) 4872cdf0e10cSrcweir { 4873cdf0e10cSrcweir // request was sent by a menu 4874cdf0e10cSrcweir nRet = 1; 4875cdf0e10cSrcweir MEASUREITEMSTRUCT *pMI = (LPMEASUREITEMSTRUCT) lParam; 4876cdf0e10cSrcweir if( pMI->CtlType != ODT_MENU ) 4877cdf0e10cSrcweir return 0; 4878cdf0e10cSrcweir 4879cdf0e10cSrcweir WinSalMenuItem *pSalMenuItem = (WinSalMenuItem *) pMI->itemData; 4880cdf0e10cSrcweir if( !pSalMenuItem ) 4881cdf0e10cSrcweir return 0; 4882cdf0e10cSrcweir 4883cdf0e10cSrcweir HDC hdc = GetDC( hWnd ); 4884cdf0e10cSrcweir SIZE strSize; 4885cdf0e10cSrcweir 4886cdf0e10cSrcweir NONCLIENTMETRICS ncm; 4887cdf0e10cSrcweir memset( &ncm, 0, sizeof(ncm) ); 4888cdf0e10cSrcweir ncm.cbSize = sizeof( ncm ); 4889cdf0e10cSrcweir SystemParametersInfo( SPI_GETNONCLIENTMETRICS, 0, (PVOID) &ncm, 0 ); 4890cdf0e10cSrcweir 4891cdf0e10cSrcweir // Assume every menu item can be default and printed bold 4892cdf0e10cSrcweir //ncm.lfMenuFont.lfWeight = FW_BOLD; 4893cdf0e10cSrcweir 4894cdf0e10cSrcweir HFONT hfntOld = (HFONT) SelectObject(hdc, (HFONT) CreateFontIndirect( &ncm.lfMenuFont )); 4895cdf0e10cSrcweir 4896cdf0e10cSrcweir // menu text and accelerator 4897cdf0e10cSrcweir String aStr(pSalMenuItem->mText.GetBuffer() ); 4898cdf0e10cSrcweir if( pSalMenuItem->mAccelText.Len() ) 4899cdf0e10cSrcweir { 4900cdf0e10cSrcweir aStr.AppendAscii(" "); 4901cdf0e10cSrcweir aStr.Append( pSalMenuItem->mAccelText ); 4902cdf0e10cSrcweir } 4903cdf0e10cSrcweir GetTextExtentPoint32W( hdc, (LPWSTR) aStr.GetBuffer(), 4904cdf0e10cSrcweir aStr.Len(), &strSize ); 4905cdf0e10cSrcweir 4906cdf0e10cSrcweir // image 4907cdf0e10cSrcweir Size bmpSize( 16, 16 ); 4908cdf0e10cSrcweir //if( !!pSalMenuItem->maBitmap ) 4909cdf0e10cSrcweir // bmpSize = pSalMenuItem->maBitmap.GetSizePixel(); 4910cdf0e10cSrcweir 4911cdf0e10cSrcweir // checkmark 4912cdf0e10cSrcweir Size checkSize( GetSystemMetrics( SM_CXMENUCHECK ), GetSystemMetrics( SM_CYMENUCHECK ) ); 4913cdf0e10cSrcweir 4914cdf0e10cSrcweir pMI->itemWidth = checkSize.Width() + 3 + bmpSize.Width() + 3 + strSize.cx; 4915cdf0e10cSrcweir pMI->itemHeight = Max( Max( checkSize.Height(), bmpSize.Height() ), strSize.cy ); 4916cdf0e10cSrcweir pMI->itemHeight += 4; 4917cdf0e10cSrcweir 4918cdf0e10cSrcweir DeleteObject( SelectObject(hdc, hfntOld) ); 4919cdf0e10cSrcweir ReleaseDC( hWnd, hdc ); 4920cdf0e10cSrcweir } 4921cdf0e10cSrcweir 4922cdf0e10cSrcweir return nRet; 4923cdf0e10cSrcweir } 4924cdf0e10cSrcweir 4925cdf0e10cSrcweir static int ImplDrawItem(HWND, WPARAM wParam, LPARAM lParam ) 4926cdf0e10cSrcweir { 4927cdf0e10cSrcweir int nRet = 0; 4928cdf0e10cSrcweir DWORD err = 0; 4929cdf0e10cSrcweir if( !wParam ) 4930cdf0e10cSrcweir { 4931cdf0e10cSrcweir // request was sent by a menu 4932cdf0e10cSrcweir nRet = 1; 4933cdf0e10cSrcweir DRAWITEMSTRUCT *pDI = (LPDRAWITEMSTRUCT) lParam; 4934cdf0e10cSrcweir if( pDI->CtlType != ODT_MENU ) 4935cdf0e10cSrcweir return 0; 4936cdf0e10cSrcweir 4937cdf0e10cSrcweir WinSalMenuItem *pSalMenuItem = (WinSalMenuItem *) pDI->itemData; 4938cdf0e10cSrcweir if( !pSalMenuItem ) 4939cdf0e10cSrcweir return 0; 4940cdf0e10cSrcweir 4941cdf0e10cSrcweir COLORREF clrPrevText, clrPrevBkgnd; 4942cdf0e10cSrcweir HFONT hfntOld; 4943cdf0e10cSrcweir HBRUSH hbrOld; 4944cdf0e10cSrcweir sal_Bool fChecked = (pDI->itemState & ODS_CHECKED) ? TRUE : FALSE; 4945cdf0e10cSrcweir sal_Bool fSelected = (pDI->itemState & ODS_SELECTED) ? TRUE : FALSE; 4946cdf0e10cSrcweir sal_Bool fDisabled = (pDI->itemState & (ODS_DISABLED | ODS_GRAYED)) ? TRUE : FALSE; 4947cdf0e10cSrcweir 4948cdf0e10cSrcweir // Set the appropriate foreground and background colors. 4949cdf0e10cSrcweir RECT aRect = pDI->rcItem; 4950cdf0e10cSrcweir 4951cdf0e10cSrcweir clrPrevBkgnd = SetBkColor( pDI->hDC, GetSysColor( COLOR_MENU ) ); 4952cdf0e10cSrcweir 4953cdf0e10cSrcweir if ( fDisabled ) 4954cdf0e10cSrcweir clrPrevText = SetTextColor( pDI->hDC, GetSysColor( COLOR_GRAYTEXT ) ); 4955cdf0e10cSrcweir else 4956cdf0e10cSrcweir clrPrevText = SetTextColor( pDI->hDC, GetSysColor( fSelected ? COLOR_HIGHLIGHTTEXT : COLOR_MENUTEXT ) ); 4957cdf0e10cSrcweir 4958cdf0e10cSrcweir DWORD colBackground = GetSysColor( fSelected ? COLOR_HIGHLIGHT : COLOR_MENU ); 4959cdf0e10cSrcweir if ( fSelected ) 4960cdf0e10cSrcweir clrPrevBkgnd = SetBkColor( pDI->hDC, colBackground ); 4961cdf0e10cSrcweir else 4962cdf0e10cSrcweir clrPrevBkgnd = SetBkColor( pDI->hDC, colBackground ); 4963cdf0e10cSrcweir 4964cdf0e10cSrcweir hbrOld = (HBRUSH)SelectObject( pDI->hDC, CreateSolidBrush( GetBkColor( pDI->hDC ) ) ); 4965cdf0e10cSrcweir 4966cdf0e10cSrcweir // Fill background 4967cdf0e10cSrcweir if(!PatBlt( pDI->hDC, aRect.left, aRect.top, aRect.right-aRect.left, aRect.bottom-aRect.top, PATCOPY )) 4968cdf0e10cSrcweir err = GetLastError(); 4969cdf0e10cSrcweir 4970cdf0e10cSrcweir int lineHeight = aRect.bottom-aRect.top; 4971cdf0e10cSrcweir 4972cdf0e10cSrcweir int x = aRect.left; 4973cdf0e10cSrcweir int y = aRect.top; 4974cdf0e10cSrcweir 4975cdf0e10cSrcweir int checkWidth = GetSystemMetrics( SM_CXMENUCHECK ); 4976cdf0e10cSrcweir int checkHeight = GetSystemMetrics( SM_CYMENUCHECK ); 4977cdf0e10cSrcweir if( fChecked ) 4978cdf0e10cSrcweir { 4979cdf0e10cSrcweir RECT r; 4980cdf0e10cSrcweir r.left = 0; 4981cdf0e10cSrcweir r.top = 0; 4982cdf0e10cSrcweir r.right = checkWidth; 4983cdf0e10cSrcweir r.bottom = checkWidth; 4984cdf0e10cSrcweir HDC memDC = CreateCompatibleDC( pDI->hDC ); 4985cdf0e10cSrcweir HBITMAP memBmp = CreateCompatibleBitmap( pDI->hDC, checkWidth, checkHeight ); 4986cdf0e10cSrcweir HBITMAP hOldBmp = (HBITMAP) SelectObject( memDC, memBmp ); 4987cdf0e10cSrcweir DrawFrameControl( memDC, &r, DFC_MENU, DFCS_MENUCHECK ); 4988cdf0e10cSrcweir BitBlt( pDI->hDC, x, y+(lineHeight-checkHeight)/2, checkWidth, checkHeight, memDC, 0, 0, SRCAND ); 4989cdf0e10cSrcweir DeleteObject( SelectObject( memDC, hOldBmp ) ); 4990cdf0e10cSrcweir DeleteDC( memDC ); 4991cdf0e10cSrcweir } 4992cdf0e10cSrcweir x += checkWidth+3; 4993cdf0e10cSrcweir 4994cdf0e10cSrcweir //Size bmpSize = aBitmap.GetSizePixel(); 4995cdf0e10cSrcweir Size bmpSize(16, 16); 4996cdf0e10cSrcweir if( !!pSalMenuItem->maBitmap ) 4997cdf0e10cSrcweir { 4998cdf0e10cSrcweir Bitmap aBitmap( pSalMenuItem->maBitmap ); 4999cdf0e10cSrcweir 5000cdf0e10cSrcweir // set transparent pixels to background color 5001cdf0e10cSrcweir if( fDisabled ) 5002cdf0e10cSrcweir colBackground = RGB(255,255,255); 5003cdf0e10cSrcweir aBitmap.Replace( Color( COL_LIGHTMAGENTA ), 5004cdf0e10cSrcweir Color( GetRValue(colBackground),GetGValue(colBackground),GetBValue(colBackground) ), 0); 5005cdf0e10cSrcweir 5006cdf0e10cSrcweir WinSalBitmap* pSalBmp = static_cast<WinSalBitmap*>(aBitmap.ImplGetImpBitmap()->ImplGetSalBitmap()); 5007cdf0e10cSrcweir HGLOBAL hDrawDIB = pSalBmp->ImplGethDIB(); 5008cdf0e10cSrcweir 5009cdf0e10cSrcweir if( hDrawDIB ) 5010cdf0e10cSrcweir { 5011cdf0e10cSrcweir PBITMAPINFO pBI = (PBITMAPINFO) GlobalLock( hDrawDIB ); 5012cdf0e10cSrcweir PBITMAPINFOHEADER pBIH = (PBITMAPINFOHEADER) pBI; 5013cdf0e10cSrcweir PBYTE pBits = (PBYTE) pBI + *(DWORD*) pBI + 5014cdf0e10cSrcweir pSalBmp->ImplGetDIBColorCount( hDrawDIB ) * sizeof( RGBQUAD ); 5015cdf0e10cSrcweir 5016cdf0e10cSrcweir HBITMAP hBmp = CreateDIBitmap( pDI->hDC, pBIH, CBM_INIT, pBits, pBI, DIB_RGB_COLORS ); 5017cdf0e10cSrcweir GlobalUnlock( hDrawDIB ); 5018cdf0e10cSrcweir 5019cdf0e10cSrcweir HBRUSH hbrIcon = CreateSolidBrush( GetSysColor( COLOR_GRAYTEXT ) ); 5020cdf0e10cSrcweir DrawStateW( pDI->hDC, (HBRUSH)hbrIcon, (DRAWSTATEPROC)NULL, (LPARAM)hBmp, (WPARAM)0, 5021cdf0e10cSrcweir x, y+(lineHeight-bmpSize.Height())/2, bmpSize.Width(), bmpSize.Height(), 5022cdf0e10cSrcweir DST_BITMAP | (fDisabled ? (fSelected ? DSS_MONO : DSS_DISABLED) : DSS_NORMAL) ); 5023cdf0e10cSrcweir 5024cdf0e10cSrcweir DeleteObject( hbrIcon ); 5025cdf0e10cSrcweir DeleteObject( hBmp ); 5026cdf0e10cSrcweir } 5027cdf0e10cSrcweir 5028cdf0e10cSrcweir } 5029cdf0e10cSrcweir x += bmpSize.Width() + 3; 5030cdf0e10cSrcweir aRect.left = x; 5031cdf0e10cSrcweir 5032cdf0e10cSrcweir NONCLIENTMETRICS ncm; 5033cdf0e10cSrcweir memset( &ncm, 0, sizeof(ncm) ); 5034cdf0e10cSrcweir ncm.cbSize = sizeof( ncm ); 5035cdf0e10cSrcweir SystemParametersInfo( SPI_GETNONCLIENTMETRICS, 0, (PVOID) &ncm, 0 ); 5036cdf0e10cSrcweir 5037cdf0e10cSrcweir // Print default menu entry with bold font 5038cdf0e10cSrcweir //if ( pDI->itemState & ODS_DEFAULT ) 5039cdf0e10cSrcweir // ncm.lfMenuFont.lfWeight = FW_BOLD; 5040cdf0e10cSrcweir 5041cdf0e10cSrcweir hfntOld = (HFONT) SelectObject(pDI->hDC, (HFONT) CreateFontIndirect( &ncm.lfMenuFont )); 5042cdf0e10cSrcweir 5043cdf0e10cSrcweir SIZE strSize; 5044cdf0e10cSrcweir String aStr( pSalMenuItem->mText.GetBuffer() ); 5045cdf0e10cSrcweir GetTextExtentPoint32W( pDI->hDC, (LPWSTR) aStr.GetBuffer(), 5046cdf0e10cSrcweir aStr.Len(), &strSize ); 5047cdf0e10cSrcweir 5048cdf0e10cSrcweir if(!DrawStateW( pDI->hDC, (HBRUSH)NULL, (DRAWSTATEPROC)NULL, 5049cdf0e10cSrcweir (LPARAM)(LPWSTR) aStr.GetBuffer(), 5050cdf0e10cSrcweir (WPARAM)0, aRect.left, aRect.top + (lineHeight - strSize.cy)/2, 0, 0, 5051cdf0e10cSrcweir DST_PREFIXTEXT | (fDisabled && !fSelected ? DSS_DISABLED : DSS_NORMAL) ) ) 5052cdf0e10cSrcweir err = GetLastError(); 5053cdf0e10cSrcweir 5054cdf0e10cSrcweir if( pSalMenuItem->mAccelText.Len() ) 5055cdf0e10cSrcweir { 5056cdf0e10cSrcweir SIZE strSizeA; 5057cdf0e10cSrcweir aStr = pSalMenuItem->mAccelText; 5058cdf0e10cSrcweir GetTextExtentPoint32W( pDI->hDC, (LPWSTR) aStr.GetBuffer(), 5059cdf0e10cSrcweir aStr.Len(), &strSizeA ); 5060cdf0e10cSrcweir TEXTMETRIC tm; 5061cdf0e10cSrcweir GetTextMetrics( pDI->hDC, &tm ); 5062cdf0e10cSrcweir 5063cdf0e10cSrcweir // position the accelerator string to the right but leave space for the 5064cdf0e10cSrcweir // (potential) submenu arrow (tm.tmMaxCharWidth) 5065cdf0e10cSrcweir if(!DrawStateW( pDI->hDC, (HBRUSH)NULL, (DRAWSTATEPROC)NULL, 5066cdf0e10cSrcweir (LPARAM)(LPWSTR) aStr.GetBuffer(), 5067cdf0e10cSrcweir (WPARAM)0, aRect.right-strSizeA.cx-tm.tmMaxCharWidth, aRect.top + (lineHeight - strSizeA.cy)/2, 0, 0, 5068cdf0e10cSrcweir DST_TEXT | (fDisabled && !fSelected ? DSS_DISABLED : DSS_NORMAL) ) ) 5069cdf0e10cSrcweir err = GetLastError(); 5070cdf0e10cSrcweir } 5071cdf0e10cSrcweir 5072cdf0e10cSrcweir // Restore the original font and colors. 5073cdf0e10cSrcweir DeleteObject( SelectObject( pDI->hDC, hbrOld ) ); 5074cdf0e10cSrcweir DeleteObject( SelectObject( pDI->hDC, hfntOld) ); 5075cdf0e10cSrcweir SetTextColor(pDI->hDC, clrPrevText); 5076cdf0e10cSrcweir SetBkColor(pDI->hDC, clrPrevBkgnd); 5077cdf0e10cSrcweir } 5078cdf0e10cSrcweir return nRet; 5079cdf0e10cSrcweir } 5080cdf0e10cSrcweir 5081cdf0e10cSrcweir static int ImplHandleMenuActivate( HWND hWnd, WPARAM wParam, LPARAM ) 5082cdf0e10cSrcweir { 5083cdf0e10cSrcweir // Menu activation 5084cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5085cdf0e10cSrcweir if ( !pFrame ) 5086cdf0e10cSrcweir return 0; 5087cdf0e10cSrcweir 5088cdf0e10cSrcweir HMENU hMenu = (HMENU) wParam; 5089cdf0e10cSrcweir // WORD nPos = LOWORD (lParam); 5090cdf0e10cSrcweir // sal_Bool bWindowMenu = (sal_Bool) HIWORD(lParam); 5091cdf0e10cSrcweir 5092cdf0e10cSrcweir // Send activate and deactivate together, so we have not keep track of opened menues 5093cdf0e10cSrcweir // this will be enough to have the menues updated correctly 5094cdf0e10cSrcweir SalMenuEvent aMenuEvt; 5095cdf0e10cSrcweir WinSalMenuItem *pSalMenuItem = ImplGetSalMenuItem( hMenu, 0 ); 5096cdf0e10cSrcweir if( pSalMenuItem ) 5097cdf0e10cSrcweir aMenuEvt.mpMenu = pSalMenuItem->mpMenu; 5098cdf0e10cSrcweir else 5099cdf0e10cSrcweir aMenuEvt.mpMenu = NULL; 5100cdf0e10cSrcweir 5101cdf0e10cSrcweir long nRet = pFrame->CallCallback( SALEVENT_MENUACTIVATE, &aMenuEvt ); 5102cdf0e10cSrcweir if( nRet ) 5103cdf0e10cSrcweir nRet = pFrame->CallCallback( SALEVENT_MENUDEACTIVATE, &aMenuEvt ); 5104cdf0e10cSrcweir if( nRet ) 5105cdf0e10cSrcweir pFrame->mLastActivatedhMenu = hMenu; 5106cdf0e10cSrcweir 5107cdf0e10cSrcweir return (nRet!=0); 5108cdf0e10cSrcweir } 5109cdf0e10cSrcweir 5110cdf0e10cSrcweir static int ImplHandleMenuSelect( HWND hWnd, WPARAM wParam, LPARAM lParam ) 5111cdf0e10cSrcweir { 5112cdf0e10cSrcweir // Menu selection 5113cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5114cdf0e10cSrcweir if ( !pFrame ) 5115cdf0e10cSrcweir return 0; 5116cdf0e10cSrcweir 5117cdf0e10cSrcweir WORD nId = LOWORD(wParam); // menu item or submenu index 5118cdf0e10cSrcweir WORD nFlags = HIWORD(wParam); 5119cdf0e10cSrcweir HMENU hMenu = (HMENU) lParam; 5120cdf0e10cSrcweir 5121cdf0e10cSrcweir // check if we have to process the message 5122cdf0e10cSrcweir if( !GetSalData()->IsKnownMenuHandle( hMenu ) ) 5123cdf0e10cSrcweir return 0; 5124cdf0e10cSrcweir 5125cdf0e10cSrcweir sal_Bool bByPosition = FALSE; 5126cdf0e10cSrcweir if( nFlags & MF_POPUP ) 5127cdf0e10cSrcweir bByPosition = TRUE; 5128cdf0e10cSrcweir 5129cdf0e10cSrcweir long nRet = 0; 5130cdf0e10cSrcweir if ( hMenu && !pFrame->mLastActivatedhMenu ) 5131cdf0e10cSrcweir { 5132cdf0e10cSrcweir // we never activated a menu (ie, no WM_INITMENUPOPUP has occured yet) 5133cdf0e10cSrcweir // which means this must be the menubar -> send activation/deactivation 5134cdf0e10cSrcweir SalMenuEvent aMenuEvt; 5135cdf0e10cSrcweir WinSalMenuItem *pSalMenuItem = ImplGetSalMenuItem( hMenu, nId, bByPosition ); 5136cdf0e10cSrcweir if( pSalMenuItem ) 5137cdf0e10cSrcweir aMenuEvt.mpMenu = pSalMenuItem->mpMenu; 5138cdf0e10cSrcweir else 5139cdf0e10cSrcweir aMenuEvt.mpMenu = NULL; 5140cdf0e10cSrcweir 5141cdf0e10cSrcweir nRet = pFrame->CallCallback( SALEVENT_MENUACTIVATE, &aMenuEvt ); 5142cdf0e10cSrcweir if( nRet ) 5143cdf0e10cSrcweir nRet = pFrame->CallCallback( SALEVENT_MENUDEACTIVATE, &aMenuEvt ); 5144cdf0e10cSrcweir if( nRet ) 5145cdf0e10cSrcweir pFrame->mLastActivatedhMenu = hMenu; 5146cdf0e10cSrcweir } 5147cdf0e10cSrcweir 5148cdf0e10cSrcweir if( !hMenu && nFlags == 0xFFFF ) 5149cdf0e10cSrcweir { 5150cdf0e10cSrcweir // all menus are closed, reset activation logic 5151cdf0e10cSrcweir pFrame->mLastActivatedhMenu = NULL; 5152cdf0e10cSrcweir } 5153cdf0e10cSrcweir 5154cdf0e10cSrcweir if( hMenu ) 5155cdf0e10cSrcweir { 5156cdf0e10cSrcweir // hMenu must be saved, as it is not passed in WM_COMMAND which always occurs after a selection 5157cdf0e10cSrcweir // if a menu is closed due to a command selection then hMenu is NULL, but WM_COMMAND comes later 5158cdf0e10cSrcweir // so we must not overwrite it in this case 5159cdf0e10cSrcweir pFrame->mSelectedhMenu = hMenu; 5160cdf0e10cSrcweir 5161cdf0e10cSrcweir // send highlight event 5162cdf0e10cSrcweir if( nFlags & MF_POPUP ) 5163cdf0e10cSrcweir { 5164cdf0e10cSrcweir // submenu selected 5165cdf0e10cSrcweir // wParam now carries an index instead of an id -> retrieve id 5166cdf0e10cSrcweir MENUITEMINFOW mi; 5167cdf0e10cSrcweir memset(&mi, 0, sizeof(mi)); 5168cdf0e10cSrcweir mi.cbSize = sizeof( mi ); 5169cdf0e10cSrcweir mi.fMask = MIIM_ID; 5170cdf0e10cSrcweir if( GetMenuItemInfoW( hMenu, LOWORD(wParam), TRUE, &mi) ) 5171cdf0e10cSrcweir nId = sal::static_int_cast<WORD>(mi.wID); 5172cdf0e10cSrcweir } 5173cdf0e10cSrcweir 5174cdf0e10cSrcweir SalMenuEvent aMenuEvt; 5175cdf0e10cSrcweir aMenuEvt.mnId = nId; 5176cdf0e10cSrcweir WinSalMenuItem *pSalMenuItem = ImplGetSalMenuItem( hMenu, nId, FALSE ); 5177cdf0e10cSrcweir if( pSalMenuItem ) 5178cdf0e10cSrcweir aMenuEvt.mpMenu = pSalMenuItem->mpMenu; 5179cdf0e10cSrcweir else 5180cdf0e10cSrcweir aMenuEvt.mpMenu = NULL; 5181cdf0e10cSrcweir 5182cdf0e10cSrcweir nRet = pFrame->CallCallback( SALEVENT_MENUHIGHLIGHT, &aMenuEvt ); 5183cdf0e10cSrcweir } 5184cdf0e10cSrcweir 5185cdf0e10cSrcweir return (nRet != 0); 5186cdf0e10cSrcweir } 5187cdf0e10cSrcweir 5188cdf0e10cSrcweir static int ImplHandleCommand( HWND hWnd, WPARAM wParam, LPARAM ) 5189cdf0e10cSrcweir { 5190cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5191cdf0e10cSrcweir if ( !pFrame ) 5192cdf0e10cSrcweir return 0; 5193cdf0e10cSrcweir 5194cdf0e10cSrcweir long nRet = 0; 5195cdf0e10cSrcweir if( !HIWORD(wParam) ) 5196cdf0e10cSrcweir { 5197cdf0e10cSrcweir // Menu command 5198cdf0e10cSrcweir WORD nId = LOWORD(wParam); 5199cdf0e10cSrcweir if( nId ) // zero for separators 5200cdf0e10cSrcweir { 5201cdf0e10cSrcweir SalMenuEvent aMenuEvt; 5202cdf0e10cSrcweir aMenuEvt.mnId = nId; 5203cdf0e10cSrcweir WinSalMenuItem *pSalMenuItem = ImplGetSalMenuItem( pFrame->mSelectedhMenu, nId, FALSE ); 5204cdf0e10cSrcweir if( pSalMenuItem ) 5205cdf0e10cSrcweir aMenuEvt.mpMenu = pSalMenuItem->mpMenu; 5206cdf0e10cSrcweir else 5207cdf0e10cSrcweir aMenuEvt.mpMenu = NULL; 5208cdf0e10cSrcweir 5209cdf0e10cSrcweir nRet = pFrame->CallCallback( SALEVENT_MENUCOMMAND, &aMenuEvt ); 5210cdf0e10cSrcweir } 5211cdf0e10cSrcweir } 5212cdf0e10cSrcweir return (nRet != 0); 5213cdf0e10cSrcweir } 5214cdf0e10cSrcweir 5215cdf0e10cSrcweir static int ImplHandleSysCommand( HWND hWnd, WPARAM wParam, LPARAM lParam ) 5216cdf0e10cSrcweir { 5217cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5218cdf0e10cSrcweir if ( !pFrame ) 5219cdf0e10cSrcweir return 0; 5220cdf0e10cSrcweir 5221cdf0e10cSrcweir WPARAM nCommand = wParam & 0xFFF0; 5222cdf0e10cSrcweir 5223cdf0e10cSrcweir if ( pFrame->mbFullScreen ) 5224cdf0e10cSrcweir { 5225cdf0e10cSrcweir BOOL bMaximize = IsZoomed( pFrame->mhWnd ); 5226cdf0e10cSrcweir BOOL bMinimize = IsIconic( pFrame->mhWnd ); 5227cdf0e10cSrcweir if ( (nCommand == SC_SIZE) || 5228cdf0e10cSrcweir (!bMinimize && (nCommand == SC_MOVE)) || 5229cdf0e10cSrcweir (!bMaximize && (nCommand == SC_MAXIMIZE)) || 5230cdf0e10cSrcweir (bMaximize && (nCommand == SC_RESTORE)) ) 5231cdf0e10cSrcweir { 5232cdf0e10cSrcweir MessageBeep( 0 ); 5233cdf0e10cSrcweir return TRUE; 5234cdf0e10cSrcweir } 5235cdf0e10cSrcweir } 5236cdf0e10cSrcweir 5237cdf0e10cSrcweir if ( nCommand == SC_KEYMENU ) 5238cdf0e10cSrcweir { 5239cdf0e10cSrcweir // do not process SC_KEYMENU if we have a native menu 5240cdf0e10cSrcweir // Windows should handle this 5241cdf0e10cSrcweir if( GetMenu( hWnd ) ) 5242cdf0e10cSrcweir return FALSE; 5243cdf0e10cSrcweir 5244cdf0e10cSrcweir // Hier verarbeiten wir nur KeyMenu-Events fuer Alt um 5245cdf0e10cSrcweir // den MenuBar zu aktivieren, oder wenn ein SysChild-Fenster 5246cdf0e10cSrcweir // den Focus hat, da diese Alt+Tasten-Kombinationen nur 5247cdf0e10cSrcweir // ueber diesen Event verarbeitet werden 5248cdf0e10cSrcweir if ( !LOWORD( lParam ) ) 5249cdf0e10cSrcweir { 5250cdf0e10cSrcweir // Nur ausloesen, wenn keine weitere Taste gedrueckt ist. Im 5251cdf0e10cSrcweir // Gegensatz zur Doku wird in der X-Koordinaate der CharCode 5252cdf0e10cSrcweir // geliefert, der zusaetzlich gedrueckt ist 5253cdf0e10cSrcweir // Also 32 fuer Space, 99 fuer c, 100 fuer d, ... 5254cdf0e10cSrcweir // Da dies nicht dokumentiert ist, fragen wir vorsichtshalber 5255cdf0e10cSrcweir // auch den Status der Space-Taste ab 5256cdf0e10cSrcweir if ( GetKeyState( VK_SPACE ) & 0x8000 ) 5257cdf0e10cSrcweir return 0; 5258cdf0e10cSrcweir 5259cdf0e10cSrcweir // Damit nicht bei Alt+Maustaste auch der MenuBar aktiviert wird 5260cdf0e10cSrcweir if ( (GetKeyState( VK_LBUTTON ) & 0x8000) || 5261cdf0e10cSrcweir (GetKeyState( VK_RBUTTON ) & 0x8000) || 5262cdf0e10cSrcweir (GetKeyState( VK_MBUTTON ) & 0x8000) || 5263cdf0e10cSrcweir (GetKeyState( VK_SHIFT ) & 0x8000) ) 5264cdf0e10cSrcweir return 1; 5265cdf0e10cSrcweir 5266cdf0e10cSrcweir SalKeyEvent aKeyEvt; 5267cdf0e10cSrcweir aKeyEvt.mnTime = GetMessageTime(); 5268cdf0e10cSrcweir aKeyEvt.mnCode = KEY_MENU; 5269cdf0e10cSrcweir aKeyEvt.mnCharCode = 0; 5270cdf0e10cSrcweir aKeyEvt.mnRepeat = 0; 5271cdf0e10cSrcweir long nRet = pFrame->CallCallback( SALEVENT_KEYINPUT, &aKeyEvt ); 5272cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_KEYUP, &aKeyEvt ); 5273cdf0e10cSrcweir return (nRet != 0); 5274cdf0e10cSrcweir } 5275cdf0e10cSrcweir else 5276cdf0e10cSrcweir { 5277cdf0e10cSrcweir // Testen, ob ein SysChild den Focus hat 5278cdf0e10cSrcweir HWND hFocusWnd = ::GetFocus(); 5279cdf0e10cSrcweir if ( hFocusWnd && ImplFindSalObject( hFocusWnd ) ) 5280cdf0e10cSrcweir { 5281cdf0e10cSrcweir char cKeyCode = (char)(unsigned char)LOWORD( lParam ); 5282cdf0e10cSrcweir // LowerCase 5283cdf0e10cSrcweir if ( (cKeyCode >= 65) && (cKeyCode <= 90) ) 5284cdf0e10cSrcweir cKeyCode += 32; 5285cdf0e10cSrcweir // Wir nehmen nur 0-9 und A-Z, alle anderen Tasten muessen durch 5286cdf0e10cSrcweir // den Hook vom SalObj verarbeitet werden 5287cdf0e10cSrcweir if ( ((cKeyCode >= 48) && (cKeyCode <= 57)) || 5288cdf0e10cSrcweir ((cKeyCode >= 97) && (cKeyCode <= 122)) ) 5289cdf0e10cSrcweir { 5290cdf0e10cSrcweir sal_uInt16 nModCode = 0; 5291cdf0e10cSrcweir if ( GetKeyState( VK_SHIFT ) & 0x8000 ) 5292cdf0e10cSrcweir nModCode |= KEY_SHIFT; 5293cdf0e10cSrcweir if ( GetKeyState( VK_CONTROL ) & 0x8000 ) 5294cdf0e10cSrcweir nModCode |= KEY_MOD1; 5295cdf0e10cSrcweir nModCode |= KEY_MOD2; 5296cdf0e10cSrcweir 5297cdf0e10cSrcweir SalKeyEvent aKeyEvt; 5298cdf0e10cSrcweir aKeyEvt.mnTime = GetMessageTime(); 5299cdf0e10cSrcweir if ( (cKeyCode >= 48) && (cKeyCode <= 57) ) 5300cdf0e10cSrcweir aKeyEvt.mnCode = KEY_0+(cKeyCode-48); 5301cdf0e10cSrcweir else 5302cdf0e10cSrcweir aKeyEvt.mnCode = KEY_A+(cKeyCode-97); 5303cdf0e10cSrcweir aKeyEvt.mnCode |= nModCode; 5304cdf0e10cSrcweir aKeyEvt.mnCharCode = cKeyCode; 5305cdf0e10cSrcweir aKeyEvt.mnRepeat = 0; 5306cdf0e10cSrcweir long nRet = pFrame->CallCallback( SALEVENT_KEYINPUT, &aKeyEvt ); 5307cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_KEYUP, &aKeyEvt ); 5308cdf0e10cSrcweir return (nRet != 0); 5309cdf0e10cSrcweir } 5310cdf0e10cSrcweir } 5311cdf0e10cSrcweir } 5312cdf0e10cSrcweir } 5313cdf0e10cSrcweir 5314cdf0e10cSrcweir return FALSE; 5315cdf0e10cSrcweir } 5316cdf0e10cSrcweir 5317cdf0e10cSrcweir // ----------------------------------------------------------------------- 5318cdf0e10cSrcweir 5319cdf0e10cSrcweir static void ImplHandleInputLangChange( HWND hWnd, WPARAM, LPARAM lParam ) 5320cdf0e10cSrcweir { 5321cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5322cdf0e10cSrcweir 5323cdf0e10cSrcweir // Feststellen, ob wir IME unterstuetzen 5324cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5325cdf0e10cSrcweir if ( pFrame && pFrame->mbIME && pFrame->mhDefIMEContext ) 5326cdf0e10cSrcweir { 5327cdf0e10cSrcweir HKL hKL = (HKL)lParam; 5328cdf0e10cSrcweir UINT nImeProps = ImmGetProperty( hKL, IGP_PROPERTY ); 5329cdf0e10cSrcweir 5330cdf0e10cSrcweir pFrame->mbSpezIME = (nImeProps & IME_PROP_SPECIAL_UI) != 0; 5331cdf0e10cSrcweir pFrame->mbAtCursorIME = (nImeProps & IME_PROP_AT_CARET) != 0; 5332cdf0e10cSrcweir pFrame->mbHandleIME = !pFrame->mbSpezIME; 5333cdf0e10cSrcweir } 5334cdf0e10cSrcweir 5335cdf0e10cSrcweir // trigger input language and codepage update 5336cdf0e10cSrcweir UINT nLang = pFrame->mnInputLang; 5337cdf0e10cSrcweir ImplUpdateInputLang( pFrame ); 5338cdf0e10cSrcweir 5339cdf0e10cSrcweir // notify change 5340cdf0e10cSrcweir if( nLang != pFrame->mnInputLang ) 5341cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_INPUTLANGUAGECHANGE, 0 ); 5342cdf0e10cSrcweir 5343cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5344cdf0e10cSrcweir } 5345cdf0e10cSrcweir 5346cdf0e10cSrcweir // ----------------------------------------------------------------------- 5347cdf0e10cSrcweir 5348cdf0e10cSrcweir static void ImplUpdateIMECursorPos( WinSalFrame* pFrame, HIMC hIMC ) 5349cdf0e10cSrcweir { 5350cdf0e10cSrcweir COMPOSITIONFORM aForm; 5351cdf0e10cSrcweir memset( &aForm, 0, sizeof( aForm ) ); 5352cdf0e10cSrcweir 5353cdf0e10cSrcweir // Cursor-Position ermitteln und aus der die Default-Position fuer 5354cdf0e10cSrcweir // das Composition-Fenster berechnen 5355cdf0e10cSrcweir SalExtTextInputPosEvent aPosEvt; 5356cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_EXTTEXTINPUTPOS, (void*)&aPosEvt ); 5357cdf0e10cSrcweir if ( (aPosEvt.mnX == -1) && (aPosEvt.mnY == -1) ) 5358cdf0e10cSrcweir aForm.dwStyle |= CFS_DEFAULT; 5359cdf0e10cSrcweir else 5360cdf0e10cSrcweir { 5361cdf0e10cSrcweir aForm.dwStyle |= CFS_POINT; 5362cdf0e10cSrcweir aForm.ptCurrentPos.x = aPosEvt.mnX; 5363cdf0e10cSrcweir aForm.ptCurrentPos.y = aPosEvt.mnY; 5364cdf0e10cSrcweir } 5365cdf0e10cSrcweir ImmSetCompositionWindow( hIMC, &aForm ); 5366cdf0e10cSrcweir 5367cdf0e10cSrcweir // Because not all IME's use this values, we create 5368cdf0e10cSrcweir // a Windows caret to force the Position from the IME 5369cdf0e10cSrcweir if ( GetFocus() == pFrame->mhWnd ) 5370cdf0e10cSrcweir { 5371cdf0e10cSrcweir CreateCaret( pFrame->mhWnd, 0, 5372cdf0e10cSrcweir aPosEvt.mnWidth, aPosEvt.mnHeight ); 5373cdf0e10cSrcweir SetCaretPos( aPosEvt.mnX, aPosEvt.mnY ); 5374cdf0e10cSrcweir } 5375cdf0e10cSrcweir } 5376cdf0e10cSrcweir 5377cdf0e10cSrcweir // ----------------------------------------------------------------------- 5378cdf0e10cSrcweir 5379cdf0e10cSrcweir static sal_Bool ImplHandleIMEStartComposition( HWND hWnd ) 5380cdf0e10cSrcweir { 5381cdf0e10cSrcweir sal_Bool bDef = TRUE; 5382cdf0e10cSrcweir 5383cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5384cdf0e10cSrcweir 5385cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5386cdf0e10cSrcweir if ( pFrame ) 5387cdf0e10cSrcweir { 5388cdf0e10cSrcweir HIMC hIMC = ImmGetContext( hWnd ); 5389cdf0e10cSrcweir if ( hIMC ) 5390cdf0e10cSrcweir { 5391cdf0e10cSrcweir ImplUpdateIMECursorPos( pFrame, hIMC ); 5392cdf0e10cSrcweir ImmReleaseContext( hWnd, hIMC ); 5393cdf0e10cSrcweir } 5394cdf0e10cSrcweir 5395cdf0e10cSrcweir if ( pFrame->mbHandleIME ) 5396cdf0e10cSrcweir { 5397cdf0e10cSrcweir if ( pFrame->mbAtCursorIME ) 5398cdf0e10cSrcweir bDef = FALSE; 5399cdf0e10cSrcweir } 5400cdf0e10cSrcweir } 5401cdf0e10cSrcweir 5402cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5403cdf0e10cSrcweir 5404cdf0e10cSrcweir return bDef; 5405cdf0e10cSrcweir } 5406cdf0e10cSrcweir 5407cdf0e10cSrcweir // ----------------------------------------------------------------------- 5408cdf0e10cSrcweir 5409cdf0e10cSrcweir static sal_Bool ImplHandleIMECompositionInput( WinSalFrame* pFrame, 5410cdf0e10cSrcweir HIMC hIMC, LPARAM lParam ) 5411cdf0e10cSrcweir { 5412cdf0e10cSrcweir sal_Bool bDef = TRUE; 5413cdf0e10cSrcweir 5414cdf0e10cSrcweir // Init Event 5415cdf0e10cSrcweir SalExtTextInputEvent aEvt; 5416cdf0e10cSrcweir aEvt.mnTime = GetMessageTime(); 5417cdf0e10cSrcweir aEvt.mpTextAttr = NULL; 5418cdf0e10cSrcweir aEvt.mnCursorPos = 0; 5419cdf0e10cSrcweir aEvt.mnDeltaStart = 0; 5420cdf0e10cSrcweir aEvt.mbOnlyCursor = FALSE; 5421cdf0e10cSrcweir aEvt.mnCursorFlags = 0; 5422cdf0e10cSrcweir 5423cdf0e10cSrcweir // If we get a result string, then we handle this input 5424cdf0e10cSrcweir if ( lParam & GCS_RESULTSTR ) 5425cdf0e10cSrcweir { 5426cdf0e10cSrcweir bDef = FALSE; 5427cdf0e10cSrcweir 5428cdf0e10cSrcweir LONG nTextLen = ImmGetCompositionStringW( hIMC, GCS_RESULTSTR, 0, 0 ) / sizeof( WCHAR ); 5429cdf0e10cSrcweir if ( nTextLen >= 0 ) 5430cdf0e10cSrcweir { 5431cdf0e10cSrcweir WCHAR* pTextBuf = new WCHAR[nTextLen]; 5432cdf0e10cSrcweir ImmGetCompositionStringW( hIMC, GCS_RESULTSTR, pTextBuf, nTextLen*sizeof( WCHAR ) ); 5433cdf0e10cSrcweir aEvt.maText = XubString( reinterpret_cast<const xub_Unicode*>(pTextBuf), (xub_StrLen)nTextLen ); 5434cdf0e10cSrcweir delete [] pTextBuf; 5435cdf0e10cSrcweir } 5436cdf0e10cSrcweir 5437cdf0e10cSrcweir aEvt.mnCursorPos = aEvt.maText.Len(); 5438cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_EXTTEXTINPUT, (void*)&aEvt ); 5439cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_ENDEXTTEXTINPUT, (void*)NULL ); 5440cdf0e10cSrcweir ImplUpdateIMECursorPos( pFrame, hIMC ); 5441cdf0e10cSrcweir } 5442cdf0e10cSrcweir 5443cdf0e10cSrcweir // If the IME doesn't support OnSpot input, then there is nothing to do 5444cdf0e10cSrcweir if ( !pFrame->mbAtCursorIME ) 5445cdf0e10cSrcweir return !bDef; 5446cdf0e10cSrcweir 5447cdf0e10cSrcweir // If we get new Composition data, then we handle this new input 5448cdf0e10cSrcweir if ( (lParam & (GCS_COMPSTR | GCS_COMPATTR)) || 5449cdf0e10cSrcweir ((lParam & GCS_CURSORPOS) && !(lParam & GCS_RESULTSTR)) ) 5450cdf0e10cSrcweir { 5451cdf0e10cSrcweir bDef = FALSE; 5452cdf0e10cSrcweir 5453cdf0e10cSrcweir sal_uInt16* pSalAttrAry = NULL; 5454cdf0e10cSrcweir LONG nTextLen = ImmGetCompositionStringW( hIMC, GCS_COMPSTR, 0, 0 ) / sizeof( WCHAR ); 5455cdf0e10cSrcweir if ( nTextLen > 0 ) 5456cdf0e10cSrcweir { 5457cdf0e10cSrcweir WCHAR* pTextBuf = new WCHAR[nTextLen]; 5458cdf0e10cSrcweir ImmGetCompositionStringW( hIMC, GCS_COMPSTR, pTextBuf, nTextLen*sizeof( WCHAR ) ); 5459cdf0e10cSrcweir aEvt.maText = XubString( reinterpret_cast<const xub_Unicode*>(pTextBuf), (xub_StrLen)nTextLen ); 5460cdf0e10cSrcweir delete [] pTextBuf; 5461cdf0e10cSrcweir 5462cdf0e10cSrcweir BYTE* pAttrBuf = NULL; 5463cdf0e10cSrcweir LONG nAttrLen = ImmGetCompositionStringW( hIMC, GCS_COMPATTR, 0, 0 ); 5464cdf0e10cSrcweir if ( nAttrLen > 0 ) 5465cdf0e10cSrcweir { 5466cdf0e10cSrcweir pAttrBuf = new BYTE[nAttrLen]; 5467cdf0e10cSrcweir ImmGetCompositionStringW( hIMC, GCS_COMPATTR, pAttrBuf, nAttrLen ); 5468cdf0e10cSrcweir } 5469cdf0e10cSrcweir 5470cdf0e10cSrcweir if ( pAttrBuf ) 5471cdf0e10cSrcweir { 5472cdf0e10cSrcweir xub_StrLen nTextLen = aEvt.maText.Len(); 5473cdf0e10cSrcweir pSalAttrAry = new sal_uInt16[nTextLen]; 5474cdf0e10cSrcweir memset( pSalAttrAry, 0, nTextLen*sizeof( sal_uInt16 ) ); 5475cdf0e10cSrcweir for ( xub_StrLen i = 0; (i < nTextLen) && (i < nAttrLen); i++ ) 5476cdf0e10cSrcweir { 5477cdf0e10cSrcweir BYTE nWinAttr = pAttrBuf[i]; 5478cdf0e10cSrcweir sal_uInt16 nSalAttr; 5479cdf0e10cSrcweir if ( nWinAttr == ATTR_TARGET_CONVERTED ) 5480cdf0e10cSrcweir { 5481cdf0e10cSrcweir nSalAttr = SAL_EXTTEXTINPUT_ATTR_BOLDUNDERLINE; 5482cdf0e10cSrcweir aEvt.mnCursorFlags |= SAL_EXTTEXTINPUT_CURSOR_INVISIBLE; 5483cdf0e10cSrcweir } 5484cdf0e10cSrcweir else if ( nWinAttr == ATTR_CONVERTED ) 5485cdf0e10cSrcweir nSalAttr = SAL_EXTTEXTINPUT_ATTR_DASHDOTUNDERLINE; 5486cdf0e10cSrcweir else if ( nWinAttr == ATTR_TARGET_NOTCONVERTED ) 5487cdf0e10cSrcweir nSalAttr = SAL_EXTTEXTINPUT_ATTR_HIGHLIGHT; 5488cdf0e10cSrcweir else if ( nWinAttr == ATTR_INPUT_ERROR ) 5489cdf0e10cSrcweir nSalAttr = SAL_EXTTEXTINPUT_ATTR_REDTEXT | SAL_EXTTEXTINPUT_ATTR_DOTTEDUNDERLINE; 5490cdf0e10cSrcweir else /* ( nWinAttr == ATTR_INPUT ) */ 5491cdf0e10cSrcweir nSalAttr = SAL_EXTTEXTINPUT_ATTR_DOTTEDUNDERLINE; 5492cdf0e10cSrcweir pSalAttrAry[i] = nSalAttr; 5493cdf0e10cSrcweir } 5494cdf0e10cSrcweir 5495cdf0e10cSrcweir aEvt.mpTextAttr = pSalAttrAry; 5496cdf0e10cSrcweir delete [] pAttrBuf; 5497cdf0e10cSrcweir } 5498cdf0e10cSrcweir } 5499cdf0e10cSrcweir 5500cdf0e10cSrcweir // Only when we get new composition data, we must send this event 5501cdf0e10cSrcweir if ( (nTextLen > 0) || !(lParam & GCS_RESULTSTR) ) 5502cdf0e10cSrcweir { 5503cdf0e10cSrcweir // End the mode, if the last character is deleted 5504cdf0e10cSrcweir if ( !nTextLen && !pFrame->mbCandidateMode ) 5505cdf0e10cSrcweir { 5506cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_EXTTEXTINPUT, (void*)&aEvt ); 5507cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_ENDEXTTEXTINPUT, (void*)NULL ); 5508cdf0e10cSrcweir } 5509cdf0e10cSrcweir else 5510cdf0e10cSrcweir { 5511cdf0e10cSrcweir // Because Cursor-Position and DeltaStart never updated 5512cdf0e10cSrcweir // from the korean input engine, we must handle this here 5513cdf0e10cSrcweir if ( lParam & CS_INSERTCHAR ) 5514cdf0e10cSrcweir { 5515cdf0e10cSrcweir aEvt.mnCursorPos = nTextLen; 5516cdf0e10cSrcweir if ( aEvt.mnCursorPos && (lParam & CS_NOMOVECARET) ) 5517cdf0e10cSrcweir aEvt.mnCursorPos--; 5518cdf0e10cSrcweir } 5519cdf0e10cSrcweir else 5520cdf0e10cSrcweir aEvt.mnCursorPos = LOWORD( ImmGetCompositionStringW( hIMC, GCS_CURSORPOS, 0, 0 ) ); 5521cdf0e10cSrcweir 5522cdf0e10cSrcweir if ( pFrame->mbCandidateMode ) 5523cdf0e10cSrcweir aEvt.mnCursorFlags |= SAL_EXTTEXTINPUT_CURSOR_INVISIBLE; 5524cdf0e10cSrcweir if ( lParam & CS_NOMOVECARET ) 5525cdf0e10cSrcweir aEvt.mnCursorFlags |= SAL_EXTTEXTINPUT_CURSOR_OVERWRITE; 5526cdf0e10cSrcweir 5527cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_EXTTEXTINPUT, (void*)&aEvt ); 5528cdf0e10cSrcweir } 5529cdf0e10cSrcweir ImplUpdateIMECursorPos( pFrame, hIMC ); 5530cdf0e10cSrcweir } 5531cdf0e10cSrcweir 5532cdf0e10cSrcweir if ( pSalAttrAry ) 5533cdf0e10cSrcweir delete [] pSalAttrAry; 5534cdf0e10cSrcweir } 5535cdf0e10cSrcweir 5536cdf0e10cSrcweir return !bDef; 5537cdf0e10cSrcweir } 5538cdf0e10cSrcweir 5539cdf0e10cSrcweir // ----------------------------------------------------------------------- 5540cdf0e10cSrcweir 5541cdf0e10cSrcweir static sal_Bool ImplHandleIMEComposition( HWND hWnd, LPARAM lParam ) 5542cdf0e10cSrcweir { 5543cdf0e10cSrcweir sal_Bool bDef = TRUE; 5544cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5545cdf0e10cSrcweir 5546cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5547cdf0e10cSrcweir if ( pFrame && (!lParam || (lParam & GCS_RESULTSTR)) ) 5548cdf0e10cSrcweir { 5549cdf0e10cSrcweir // Wir restaurieren den Background-Modus bei jeder Texteingabe, 5550cdf0e10cSrcweir // da einige Tools wie RichWin uns diesen hin- und wieder umsetzen 5551cdf0e10cSrcweir if ( pFrame->mpGraphics && 55525f27b83cSArmin Le Grand pFrame->mpGraphics->getHDC() ) 55535f27b83cSArmin Le Grand SetBkMode( pFrame->mpGraphics->getHDC(), TRANSPARENT ); 5554cdf0e10cSrcweir } 5555cdf0e10cSrcweir 5556cdf0e10cSrcweir if ( pFrame && pFrame->mbHandleIME ) 5557cdf0e10cSrcweir { 5558cdf0e10cSrcweir if ( !lParam ) 5559cdf0e10cSrcweir { 5560cdf0e10cSrcweir SalExtTextInputEvent aEvt; 5561cdf0e10cSrcweir aEvt.mnTime = GetMessageTime(); 5562cdf0e10cSrcweir aEvt.mpTextAttr = NULL; 5563cdf0e10cSrcweir aEvt.mnCursorPos = 0; 5564cdf0e10cSrcweir aEvt.mnDeltaStart = 0; 5565cdf0e10cSrcweir aEvt.mbOnlyCursor = FALSE; 5566cdf0e10cSrcweir aEvt.mnCursorFlags = 0; 5567cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_EXTTEXTINPUT, (void*)&aEvt ); 5568cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_ENDEXTTEXTINPUT, (void*)NULL ); 5569cdf0e10cSrcweir } 5570cdf0e10cSrcweir else if ( lParam & (GCS_RESULTSTR | GCS_COMPSTR | GCS_COMPATTR | GCS_CURSORPOS) ) 5571cdf0e10cSrcweir { 5572cdf0e10cSrcweir HIMC hIMC = ImmGetContext( hWnd ); 5573cdf0e10cSrcweir if ( hIMC ) 5574cdf0e10cSrcweir { 5575cdf0e10cSrcweir if ( ImplHandleIMECompositionInput( pFrame, hIMC, lParam ) ) 5576cdf0e10cSrcweir bDef = FALSE; 5577cdf0e10cSrcweir 5578cdf0e10cSrcweir ImmReleaseContext( hWnd, hIMC ); 5579cdf0e10cSrcweir } 5580cdf0e10cSrcweir } 5581cdf0e10cSrcweir } 5582cdf0e10cSrcweir 5583cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5584cdf0e10cSrcweir return bDef; 5585cdf0e10cSrcweir } 5586cdf0e10cSrcweir 5587cdf0e10cSrcweir // ----------------------------------------------------------------------- 5588cdf0e10cSrcweir 5589cdf0e10cSrcweir static sal_Bool ImplHandleIMEEndComposition( HWND hWnd ) 5590cdf0e10cSrcweir { 5591cdf0e10cSrcweir sal_Bool bDef = TRUE; 5592cdf0e10cSrcweir 5593cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5594cdf0e10cSrcweir 5595cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5596cdf0e10cSrcweir if ( pFrame && pFrame->mbHandleIME ) 5597cdf0e10cSrcweir { 5598cdf0e10cSrcweir if ( pFrame->mbAtCursorIME ) 5599cdf0e10cSrcweir bDef = FALSE; 5600cdf0e10cSrcweir } 5601cdf0e10cSrcweir 5602cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5603cdf0e10cSrcweir 5604cdf0e10cSrcweir return bDef; 5605cdf0e10cSrcweir } 5606cdf0e10cSrcweir 5607cdf0e10cSrcweir // ----------------------------------------------------------------------- 5608cdf0e10cSrcweir 5609cdf0e10cSrcweir static boolean ImplHandleAppCommand( HWND hWnd, LPARAM lParam ) 5610cdf0e10cSrcweir { 5611cdf0e10cSrcweir sal_Int16 nCommand = 0; 5612cdf0e10cSrcweir switch( GET_APPCOMMAND_LPARAM(lParam) ) 5613cdf0e10cSrcweir { 5614cdf0e10cSrcweir case APPCOMMAND_MEDIA_CHANNEL_DOWN: nCommand = MEDIA_COMMAND_CHANNEL_DOWN; break; 5615cdf0e10cSrcweir case APPCOMMAND_MEDIA_CHANNEL_UP: nCommand = MEDIA_COMMAND_CHANNEL_UP; break; 5616cdf0e10cSrcweir case APPCOMMAND_MEDIA_NEXTTRACK: nCommand = MEDIA_COMMAND_NEXTTRACK; break; 5617cdf0e10cSrcweir case APPCOMMAND_MEDIA_PAUSE: nCommand = MEDIA_COMMAND_PAUSE; break; 5618cdf0e10cSrcweir case APPCOMMAND_MEDIA_PLAY: nCommand = MEDIA_COMMAND_PLAY; break; 5619cdf0e10cSrcweir case APPCOMMAND_MEDIA_PLAY_PAUSE: nCommand = MEDIA_COMMAND_PLAY_PAUSE; break; 5620cdf0e10cSrcweir case APPCOMMAND_MEDIA_PREVIOUSTRACK: nCommand = MEDIA_COMMAND_PREVIOUSTRACK; break; 5621cdf0e10cSrcweir case APPCOMMAND_MEDIA_RECORD: nCommand = MEDIA_COMMAND_RECORD; break; 5622cdf0e10cSrcweir case APPCOMMAND_MEDIA_REWIND: nCommand = MEDIA_COMMAND_REWIND; break; 5623cdf0e10cSrcweir case APPCOMMAND_MEDIA_STOP: nCommand = MEDIA_COMMAND_STOP; break; 5624cdf0e10cSrcweir case APPCOMMAND_MIC_ON_OFF_TOGGLE: nCommand = MEDIA_COMMAND_MIC_ON_OFF_TOGGLE; break; 5625cdf0e10cSrcweir case APPCOMMAND_MICROPHONE_VOLUME_DOWN: nCommand = MEDIA_COMMAND_MICROPHONE_VOLUME_DOWN; break; 5626cdf0e10cSrcweir case APPCOMMAND_MICROPHONE_VOLUME_MUTE: nCommand = MEDIA_COMMAND_MICROPHONE_VOLUME_MUTE; break; 5627cdf0e10cSrcweir case APPCOMMAND_MICROPHONE_VOLUME_UP: nCommand = MEDIA_COMMAND_MICROPHONE_VOLUME_UP; break; 5628cdf0e10cSrcweir case APPCOMMAND_VOLUME_DOWN: nCommand = MEDIA_COMMAND_VOLUME_DOWN; break; 5629cdf0e10cSrcweir case APPCOMMAND_VOLUME_MUTE: nCommand = MEDIA_COMMAND_VOLUME_MUTE; break; 5630cdf0e10cSrcweir case APPCOMMAND_VOLUME_UP: nCommand = MEDIA_COMMAND_VOLUME_UP; break; 5631cdf0e10cSrcweir break; 5632cdf0e10cSrcweir default: 5633cdf0e10cSrcweir return false; 5634cdf0e10cSrcweir } 5635cdf0e10cSrcweir 5636cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5637cdf0e10cSrcweir Window *pWindow = pFrame ? pFrame->GetWindow() : NULL; 5638cdf0e10cSrcweir 5639cdf0e10cSrcweir if( pWindow ) 5640cdf0e10cSrcweir { 5641cdf0e10cSrcweir const Point aPoint; 5642cdf0e10cSrcweir CommandEvent aCEvt( aPoint, COMMAND_MEDIA, FALSE, &nCommand ); 5643cdf0e10cSrcweir NotifyEvent aNCmdEvt( EVENT_COMMAND, pWindow, &aCEvt ); 5644cdf0e10cSrcweir 5645cdf0e10cSrcweir if ( !ImplCallPreNotify( aNCmdEvt ) ) 5646cdf0e10cSrcweir { 5647cdf0e10cSrcweir pWindow->Command( aCEvt ); 5648cdf0e10cSrcweir return true; 5649cdf0e10cSrcweir } 5650cdf0e10cSrcweir } 5651cdf0e10cSrcweir 5652cdf0e10cSrcweir return false; 5653cdf0e10cSrcweir } 5654cdf0e10cSrcweir 5655cdf0e10cSrcweir 5656cdf0e10cSrcweir static void ImplHandleIMENotify( HWND hWnd, WPARAM wParam ) 5657cdf0e10cSrcweir { 5658cdf0e10cSrcweir if ( wParam == (WPARAM)IMN_OPENCANDIDATE ) 5659cdf0e10cSrcweir { 5660cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5661cdf0e10cSrcweir 5662cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5663cdf0e10cSrcweir if ( pFrame && pFrame->mbHandleIME && 5664cdf0e10cSrcweir pFrame->mbAtCursorIME ) 5665cdf0e10cSrcweir { 5666cdf0e10cSrcweir // Wir wollen den Cursor hiden 5667cdf0e10cSrcweir pFrame->mbCandidateMode = TRUE; 5668cdf0e10cSrcweir ImplHandleIMEComposition( hWnd, GCS_CURSORPOS ); 5669cdf0e10cSrcweir 5670cdf0e10cSrcweir HWND hWnd = pFrame->mhWnd; 5671cdf0e10cSrcweir HIMC hIMC = ImmGetContext( hWnd ); 5672cdf0e10cSrcweir if ( hIMC ) 5673cdf0e10cSrcweir { 5674cdf0e10cSrcweir LONG nBufLen = ImmGetCompositionStringW( hIMC, GCS_COMPSTR, 0, 0 ); 5675cdf0e10cSrcweir if ( nBufLen >= 1 ) 5676cdf0e10cSrcweir { 5677cdf0e10cSrcweir SalExtTextInputPosEvent aPosEvt; 5678cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_EXTTEXTINPUTPOS, (void*)&aPosEvt ); 5679cdf0e10cSrcweir 5680cdf0e10cSrcweir // Vertical !!! 5681cdf0e10cSrcweir CANDIDATEFORM aForm; 5682cdf0e10cSrcweir aForm.dwIndex = 0; 5683cdf0e10cSrcweir aForm.dwStyle = CFS_EXCLUDE; 5684cdf0e10cSrcweir aForm.ptCurrentPos.x = aPosEvt.mnX; 5685cdf0e10cSrcweir aForm.ptCurrentPos.y = aPosEvt.mnY+1; 5686cdf0e10cSrcweir aForm.rcArea.left = aPosEvt.mnX; 5687cdf0e10cSrcweir aForm.rcArea.top = aPosEvt.mnY; 5688cdf0e10cSrcweir aForm.rcArea.right = aForm.rcArea.left+aPosEvt.mnExtWidth+1; 5689cdf0e10cSrcweir aForm.rcArea.bottom = aForm.rcArea.top+aPosEvt.mnHeight+1; 5690cdf0e10cSrcweir ImmSetCandidateWindow( hIMC, &aForm ); 5691cdf0e10cSrcweir } 5692cdf0e10cSrcweir 5693cdf0e10cSrcweir ImmReleaseContext( hWnd, hIMC ); 5694cdf0e10cSrcweir } 5695cdf0e10cSrcweir } 5696cdf0e10cSrcweir 5697cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5698cdf0e10cSrcweir } 5699cdf0e10cSrcweir else if ( wParam == (WPARAM)IMN_CLOSECANDIDATE ) 5700cdf0e10cSrcweir { 5701cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5702cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5703cdf0e10cSrcweir if ( pFrame ) 5704cdf0e10cSrcweir pFrame->mbCandidateMode = FALSE; 5705cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5706cdf0e10cSrcweir } 5707cdf0e10cSrcweir } 5708cdf0e10cSrcweir 5709cdf0e10cSrcweir // ----------------------------------------------------------------------- 5710cdf0e10cSrcweir #if WINVER >= 0x0500 5711cdf0e10cSrcweir 5712cdf0e10cSrcweir static LRESULT ImplHandleIMEReconvertString( HWND hWnd, LPARAM lParam ) 5713cdf0e10cSrcweir { 5714cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5715cdf0e10cSrcweir LPRECONVERTSTRING pReconvertString = (LPRECONVERTSTRING) lParam; 5716cdf0e10cSrcweir LRESULT nRet = 0; 5717cdf0e10cSrcweir SalSurroundingTextRequestEvent aEvt; 5718cdf0e10cSrcweir aEvt.maText = UniString(); 5719cdf0e10cSrcweir aEvt.mnStart = aEvt.mnEnd = 0; 5720cdf0e10cSrcweir 5721cdf0e10cSrcweir UINT nImeProps = ImmGetProperty( GetKeyboardLayout( 0 ), IGP_SETCOMPSTR ); 5722cdf0e10cSrcweir if( (nImeProps & SCS_CAP_SETRECONVERTSTRING) == 0 ) 5723cdf0e10cSrcweir { 5724cdf0e10cSrcweir // This IME does not support reconversion. 5725cdf0e10cSrcweir return 0; 5726cdf0e10cSrcweir } 5727cdf0e10cSrcweir 5728cdf0e10cSrcweir if( !pReconvertString ) 5729cdf0e10cSrcweir { 5730cdf0e10cSrcweir // The first call for reconversion. 5731cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_STARTRECONVERSION, (void*)NULL ); 5732cdf0e10cSrcweir 5733cdf0e10cSrcweir // Retrieve the surrounding text from the focused control. 5734cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_SURROUNDINGTEXTREQUEST, (void*)&aEvt ); 5735cdf0e10cSrcweir 5736cdf0e10cSrcweir if( aEvt.maText.Len() == 0 ) 5737cdf0e10cSrcweir { 5738cdf0e10cSrcweir return 0; 5739cdf0e10cSrcweir } 5740cdf0e10cSrcweir 5741cdf0e10cSrcweir nRet = sizeof(RECONVERTSTRING) + (aEvt.maText.Len() + 1) * sizeof(WCHAR); 5742cdf0e10cSrcweir } 5743cdf0e10cSrcweir else 5744cdf0e10cSrcweir { 5745cdf0e10cSrcweir // The second call for reconversion. 5746cdf0e10cSrcweir 5747cdf0e10cSrcweir // Retrieve the surrounding text from the focused control. 5748cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_SURROUNDINGTEXTREQUEST, (void*)&aEvt ); 5749cdf0e10cSrcweir nRet = sizeof(RECONVERTSTRING) + (aEvt.maText.Len() + 1) * sizeof(WCHAR); 5750cdf0e10cSrcweir 5751cdf0e10cSrcweir pReconvertString->dwStrOffset = sizeof(RECONVERTSTRING); 5752cdf0e10cSrcweir pReconvertString->dwStrLen = aEvt.maText.Len(); 5753cdf0e10cSrcweir pReconvertString->dwCompStrOffset = aEvt.mnStart * sizeof(WCHAR); 5754cdf0e10cSrcweir pReconvertString->dwCompStrLen = aEvt.mnEnd - aEvt.mnStart; 5755cdf0e10cSrcweir pReconvertString->dwTargetStrOffset = pReconvertString->dwCompStrOffset; 5756cdf0e10cSrcweir pReconvertString->dwTargetStrLen = pReconvertString->dwCompStrLen; 5757cdf0e10cSrcweir 5758cdf0e10cSrcweir memcpy( (LPWSTR)(pReconvertString + 1), aEvt.maText.GetBuffer(), (aEvt.maText.Len() + 1) * sizeof(WCHAR) ); 5759cdf0e10cSrcweir } 5760cdf0e10cSrcweir 5761cdf0e10cSrcweir // just return the required size of buffer to reconvert. 5762cdf0e10cSrcweir return nRet; 5763cdf0e10cSrcweir } 5764cdf0e10cSrcweir 5765cdf0e10cSrcweir // ----------------------------------------------------------------------- 5766cdf0e10cSrcweir 5767cdf0e10cSrcweir static LRESULT ImplHandleIMEConfirmReconvertString( HWND hWnd, LPARAM lParam ) 5768cdf0e10cSrcweir { 5769cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 5770cdf0e10cSrcweir LPRECONVERTSTRING pReconvertString = (LPRECONVERTSTRING) lParam; 5771cdf0e10cSrcweir SalSurroundingTextRequestEvent aEvt; 5772cdf0e10cSrcweir aEvt.maText = UniString(); 5773cdf0e10cSrcweir aEvt.mnStart = aEvt.mnEnd = 0; 5774cdf0e10cSrcweir 5775cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_SURROUNDINGTEXTREQUEST, (void*)&aEvt ); 5776cdf0e10cSrcweir 5777cdf0e10cSrcweir sal_uLong nTmpStart = pReconvertString->dwCompStrOffset / sizeof(WCHAR); 5778cdf0e10cSrcweir sal_uLong nTmpEnd = nTmpStart + pReconvertString->dwCompStrLen; 5779cdf0e10cSrcweir 5780cdf0e10cSrcweir if( nTmpStart != aEvt.mnStart || nTmpEnd != aEvt.mnEnd ) 5781cdf0e10cSrcweir { 5782cdf0e10cSrcweir SalSurroundingTextSelectionChangeEvent aSelEvt; 5783cdf0e10cSrcweir aSelEvt.mnStart = nTmpStart; 5784cdf0e10cSrcweir aSelEvt.mnEnd = nTmpEnd; 5785cdf0e10cSrcweir 5786cdf0e10cSrcweir pFrame->CallCallback( SALEVENT_SURROUNDINGTEXTSELECTIONCHANGE, (void*)&aSelEvt ); 5787cdf0e10cSrcweir } 5788cdf0e10cSrcweir 5789cdf0e10cSrcweir return TRUE; 5790cdf0e10cSrcweir } 5791cdf0e10cSrcweir 5792cdf0e10cSrcweir #endif // WINVER >= 0x0500 5793cdf0e10cSrcweir 5794cdf0e10cSrcweir // ----------------------------------------------------------------------- 5795cdf0e10cSrcweir 5796cdf0e10cSrcweir void SalTestMouseLeave() 5797cdf0e10cSrcweir { 5798cdf0e10cSrcweir SalData* pSalData = GetSalData(); 5799cdf0e10cSrcweir 5800cdf0e10cSrcweir if ( pSalData->mhWantLeaveMsg && !::GetCapture() ) 5801cdf0e10cSrcweir { 5802cdf0e10cSrcweir POINT aPt; 5803cdf0e10cSrcweir GetCursorPos( &aPt ); 5804cdf0e10cSrcweir if ( pSalData->mhWantLeaveMsg != WindowFromPoint( aPt ) ) 5805cdf0e10cSrcweir ImplSendMessage( pSalData->mhWantLeaveMsg, SAL_MSG_MOUSELEAVE, 0, MAKELPARAM( aPt.x, aPt.y ) ); 5806cdf0e10cSrcweir } 5807cdf0e10cSrcweir } 5808cdf0e10cSrcweir 5809cdf0e10cSrcweir // ----------------------------------------------------------------------- 5810cdf0e10cSrcweir 5811cdf0e10cSrcweir static int ImplSalWheelMousePos( HWND hWnd, UINT nMsg, WPARAM wParam, LPARAM lParam , 5812cdf0e10cSrcweir LRESULT& rResult ) 5813cdf0e10cSrcweir { 5814cdf0e10cSrcweir POINT aPt; 5815cdf0e10cSrcweir POINT aScreenPt; 5816cdf0e10cSrcweir aScreenPt.x = (short)LOWORD( lParam ); 5817cdf0e10cSrcweir aScreenPt.y = (short)HIWORD( lParam ); 5818cdf0e10cSrcweir // Child-Fenster suchen, welches an der entsprechenden 5819cdf0e10cSrcweir // Position liegt 5820cdf0e10cSrcweir HWND hChildWnd; 5821cdf0e10cSrcweir HWND hWheelWnd = hWnd; 5822cdf0e10cSrcweir do 5823cdf0e10cSrcweir { 5824cdf0e10cSrcweir hChildWnd = hWheelWnd; 5825cdf0e10cSrcweir aPt = aScreenPt; 5826cdf0e10cSrcweir ScreenToClient( hChildWnd, &aPt ); 5827cdf0e10cSrcweir hWheelWnd = ChildWindowFromPointEx( hChildWnd, aPt, CWP_SKIPINVISIBLE | CWP_SKIPTRANSPARENT ); 5828cdf0e10cSrcweir } 5829cdf0e10cSrcweir while ( hWheelWnd && (hWheelWnd != hChildWnd) ); 5830cdf0e10cSrcweir if ( hWheelWnd && (hWheelWnd != hWnd) && 5831cdf0e10cSrcweir (hWheelWnd != ::GetFocus()) && IsWindowEnabled( hWheelWnd ) ) 5832cdf0e10cSrcweir { 5833cdf0e10cSrcweir rResult = ImplSendMessage( hWheelWnd, nMsg, wParam, lParam ); 5834cdf0e10cSrcweir return FALSE; 5835cdf0e10cSrcweir } 5836cdf0e10cSrcweir 5837cdf0e10cSrcweir return TRUE; 5838cdf0e10cSrcweir } 5839cdf0e10cSrcweir 5840cdf0e10cSrcweir // ----------------------------------------------------------------------- 5841cdf0e10cSrcweir 5842cdf0e10cSrcweir LRESULT CALLBACK SalFrameWndProc( HWND hWnd, UINT nMsg, WPARAM wParam, LPARAM lParam, int& rDef ) 5843cdf0e10cSrcweir { 5844cdf0e10cSrcweir LRESULT nRet = 0; 5845cdf0e10cSrcweir static int bInWheelMsg = FALSE; 5846cdf0e10cSrcweir static int bInQueryEnd = FALSE; 5847cdf0e10cSrcweir 5848cdf0e10cSrcweir // By WM_CRETAE we connect the frame with the window handle 5849cdf0e10cSrcweir if ( nMsg == WM_CREATE ) 5850cdf0e10cSrcweir { 5851cdf0e10cSrcweir // Window-Instanz am Windowhandle speichern 5852cdf0e10cSrcweir // Can also be used for the W-Version, because the struct 5853cdf0e10cSrcweir // to access lpCreateParams is the same structure 5854cdf0e10cSrcweir CREATESTRUCTA* pStruct = (CREATESTRUCTA*)lParam; 5855cdf0e10cSrcweir WinSalFrame* pFrame = (WinSalFrame*)pStruct->lpCreateParams; 5856cdf0e10cSrcweir if ( pFrame != 0 ) 5857cdf0e10cSrcweir { 5858cdf0e10cSrcweir SetWindowPtr( hWnd, pFrame ); 5859cdf0e10cSrcweir // HWND schon hier setzen, da schon auf den Instanzdaten 5860cdf0e10cSrcweir // gearbeitet werden kann, wenn Messages waehrend 5861cdf0e10cSrcweir // CreateWindow() gesendet werden 5862cdf0e10cSrcweir pFrame->mhWnd = hWnd; 5863cdf0e10cSrcweir pFrame->maSysData.hWnd = hWnd; 5864cdf0e10cSrcweir } 5865cdf0e10cSrcweir return 0; 5866cdf0e10cSrcweir } 5867cdf0e10cSrcweir 5868cdf0e10cSrcweir ImplSVData* pSVData = ImplGetSVData(); 5869cdf0e10cSrcweir // #i72707# TODO: the mbDeInit check will not be needed 5870cdf0e10cSrcweir // once all windows that are not properly closed on exit got fixed 5871cdf0e10cSrcweir if( pSVData->mbDeInit ) 5872cdf0e10cSrcweir return 0; 5873cdf0e10cSrcweir 5874cdf0e10cSrcweir if ( WM_USER_SYSTEM_WINDOW_ACTIVATED == nMsg ) 5875cdf0e10cSrcweir { 5876cdf0e10cSrcweir if (pSVData->mpIntroWindow) 5877cdf0e10cSrcweir pSVData->mpIntroWindow->Hide(); 5878cdf0e10cSrcweir 5879cdf0e10cSrcweir return 0; 5880cdf0e10cSrcweir } 5881cdf0e10cSrcweir 5882cdf0e10cSrcweir bool bCheckTimers = false; 5883cdf0e10cSrcweir 5884cdf0e10cSrcweir switch( nMsg ) 5885cdf0e10cSrcweir { 5886cdf0e10cSrcweir case WM_MOUSEMOVE: 5887cdf0e10cSrcweir case WM_LBUTTONDOWN: 5888cdf0e10cSrcweir case WM_MBUTTONDOWN: 5889cdf0e10cSrcweir case WM_RBUTTONDOWN: 5890cdf0e10cSrcweir case WM_LBUTTONUP: 5891cdf0e10cSrcweir case WM_MBUTTONUP: 5892cdf0e10cSrcweir case WM_RBUTTONUP: 5893cdf0e10cSrcweir case WM_NCMOUSEMOVE: 5894cdf0e10cSrcweir case SAL_MSG_MOUSELEAVE: 5895cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5896cdf0e10cSrcweir rDef = !ImplHandleMouseMsg( hWnd, nMsg, wParam, lParam ); 5897cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5898cdf0e10cSrcweir break; 5899cdf0e10cSrcweir 5900cdf0e10cSrcweir case WM_NCLBUTTONDOWN: 5901cdf0e10cSrcweir case WM_NCMBUTTONDOWN: 5902cdf0e10cSrcweir case WM_NCRBUTTONDOWN: 5903cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5904cdf0e10cSrcweir ImplCallClosePopupsHdl( hWnd ); // close popups... 5905cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5906cdf0e10cSrcweir break; 5907cdf0e10cSrcweir 5908cdf0e10cSrcweir case WM_MOUSEACTIVATE: 5909cdf0e10cSrcweir if ( LOWORD( lParam ) == HTCLIENT ) 5910cdf0e10cSrcweir { 5911cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5912cdf0e10cSrcweir nRet = ImplHandleMouseActivateMsg( hWnd ); 5913cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5914cdf0e10cSrcweir if ( nRet ) 5915cdf0e10cSrcweir { 5916cdf0e10cSrcweir nRet = MA_NOACTIVATE; 5917cdf0e10cSrcweir rDef = FALSE; 5918cdf0e10cSrcweir } 5919cdf0e10cSrcweir } 5920cdf0e10cSrcweir break; 5921cdf0e10cSrcweir 5922cdf0e10cSrcweir case WM_KEYDOWN: 5923cdf0e10cSrcweir case WM_KEYUP: 5924cdf0e10cSrcweir case WM_DEADCHAR: 5925cdf0e10cSrcweir case WM_CHAR: 5926cdf0e10cSrcweir case WM_UNICHAR: // MCD, 2003-01-13, Support for WM_UNICHAR & Keyman 6.0 5927cdf0e10cSrcweir case WM_SYSKEYDOWN: 5928cdf0e10cSrcweir case WM_SYSKEYUP: 5929cdf0e10cSrcweir case WM_SYSCHAR: 5930cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5931cdf0e10cSrcweir rDef = !ImplHandleKeyMsg( hWnd, nMsg, wParam, lParam, nRet ); 5932cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5933cdf0e10cSrcweir break; 5934cdf0e10cSrcweir 5935cdf0e10cSrcweir case WM_MOUSEWHEEL: 5936cdf0e10cSrcweir // FALLTHROUGH intended 5937cdf0e10cSrcweir case WM_MOUSEHWHEEL: 5938cdf0e10cSrcweir // Gegen Rekursion absichern, falls wir vom IE oder dem externen 5939cdf0e10cSrcweir // Fenster die Message wieder zurueckbekommen 5940cdf0e10cSrcweir if ( !bInWheelMsg ) 5941cdf0e10cSrcweir { 5942cdf0e10cSrcweir bInWheelMsg++; 5943cdf0e10cSrcweir rDef = !ImplHandleWheelMsg( hWnd, nMsg, wParam, lParam ); 5944cdf0e10cSrcweir // Wenn wir die Message nicht ausgewertet haben, schauen wir 5945cdf0e10cSrcweir // noch einmal nach, ob dort ein geplugtes Fenster steht, 5946cdf0e10cSrcweir // welches wir dann benachrichtigen 5947cdf0e10cSrcweir if ( rDef ) 5948cdf0e10cSrcweir rDef = ImplSalWheelMousePos( hWnd, nMsg, wParam, lParam, nRet ); 5949cdf0e10cSrcweir bInWheelMsg--; 5950cdf0e10cSrcweir } 5951cdf0e10cSrcweir break; 5952cdf0e10cSrcweir 5953cdf0e10cSrcweir case WM_COMMAND: 5954cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5955cdf0e10cSrcweir rDef = !ImplHandleCommand( hWnd, wParam, lParam ); 5956cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5957cdf0e10cSrcweir break; 5958cdf0e10cSrcweir 5959cdf0e10cSrcweir case WM_INITMENUPOPUP: 5960cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5961cdf0e10cSrcweir rDef = !ImplHandleMenuActivate( hWnd, wParam, lParam ); 5962cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5963cdf0e10cSrcweir break; 5964cdf0e10cSrcweir 5965cdf0e10cSrcweir case WM_MENUSELECT: 5966cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5967cdf0e10cSrcweir rDef = !ImplHandleMenuSelect( hWnd, wParam, lParam ); 5968cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5969cdf0e10cSrcweir break; 5970cdf0e10cSrcweir 5971cdf0e10cSrcweir case WM_SYSCOMMAND: 5972cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 5973cdf0e10cSrcweir nRet = ImplHandleSysCommand( hWnd, wParam, lParam ); 5974cdf0e10cSrcweir ImplSalYieldMutexRelease(); 5975cdf0e10cSrcweir if ( nRet ) 5976cdf0e10cSrcweir rDef = FALSE; 5977cdf0e10cSrcweir break; 5978cdf0e10cSrcweir 5979cdf0e10cSrcweir case WM_MENUCHAR: 5980cdf0e10cSrcweir nRet = ImplMenuChar( hWnd, wParam, lParam ); 5981cdf0e10cSrcweir if( nRet ) 5982cdf0e10cSrcweir rDef = FALSE; 5983cdf0e10cSrcweir break; 5984cdf0e10cSrcweir 5985cdf0e10cSrcweir case WM_MEASUREITEM: 5986cdf0e10cSrcweir nRet = ImplMeasureItem(hWnd, wParam, lParam); 5987cdf0e10cSrcweir if( nRet ) 5988cdf0e10cSrcweir rDef = FALSE; 5989cdf0e10cSrcweir break; 5990cdf0e10cSrcweir 5991cdf0e10cSrcweir case WM_DRAWITEM: 5992cdf0e10cSrcweir nRet = ImplDrawItem(hWnd, wParam, lParam); 5993cdf0e10cSrcweir if( nRet ) 5994cdf0e10cSrcweir rDef = FALSE; 5995cdf0e10cSrcweir break; 5996cdf0e10cSrcweir 5997cdf0e10cSrcweir case WM_MOVE: 5998cdf0e10cSrcweir case SAL_MSG_POSTMOVE: 5999cdf0e10cSrcweir ImplHandleMoveMsg( hWnd ); 6000cdf0e10cSrcweir rDef = FALSE; 6001cdf0e10cSrcweir break; 6002cdf0e10cSrcweir case WM_SIZE: 6003cdf0e10cSrcweir ImplHandleSizeMsg( hWnd, wParam, lParam ); 6004cdf0e10cSrcweir rDef = FALSE; 6005cdf0e10cSrcweir break; 6006cdf0e10cSrcweir case SAL_MSG_POSTCALLSIZE: 6007cdf0e10cSrcweir ImplCallSizeHdl( hWnd ); 6008cdf0e10cSrcweir rDef = FALSE; 6009cdf0e10cSrcweir break; 6010cdf0e10cSrcweir 6011cdf0e10cSrcweir case WM_GETMINMAXINFO: 6012cdf0e10cSrcweir if ( ImplHandleMinMax( hWnd, lParam ) ) 6013cdf0e10cSrcweir rDef = FALSE; 6014cdf0e10cSrcweir break; 6015cdf0e10cSrcweir 6016cdf0e10cSrcweir case WM_ERASEBKGND: 6017cdf0e10cSrcweir nRet = 1; 6018cdf0e10cSrcweir rDef = FALSE; 6019cdf0e10cSrcweir break; 6020cdf0e10cSrcweir case WM_PAINT: 6021cdf0e10cSrcweir bCheckTimers = ImplHandlePaintMsg( hWnd ); 6022cdf0e10cSrcweir rDef = FALSE; 6023cdf0e10cSrcweir break; 6024cdf0e10cSrcweir case SAL_MSG_POSTPAINT: 6025cdf0e10cSrcweir ImplHandlePaintMsg2( hWnd, (RECT*)wParam ); 6026cdf0e10cSrcweir bCheckTimers = true; 6027cdf0e10cSrcweir rDef = FALSE; 6028cdf0e10cSrcweir break; 6029cdf0e10cSrcweir 6030cdf0e10cSrcweir case SAL_MSG_FORCEPALETTE: 6031cdf0e10cSrcweir ImplHandleForcePalette( hWnd ); 6032cdf0e10cSrcweir rDef = FALSE; 6033cdf0e10cSrcweir break; 6034cdf0e10cSrcweir 6035cdf0e10cSrcweir case WM_QUERYNEWPALETTE: 6036cdf0e10cSrcweir case SAL_MSG_POSTQUERYNEWPAL: 6037cdf0e10cSrcweir nRet = ImplHandlePalette( TRUE, hWnd, nMsg, wParam, lParam, rDef ); 6038cdf0e10cSrcweir break; 6039cdf0e10cSrcweir 6040cdf0e10cSrcweir case WM_ACTIVATE: 6041cdf0e10cSrcweir // Wenn wir aktiviert werden, dann wollen wir auch unsere 6042cdf0e10cSrcweir // Palette setzen. Wir machen dieses in Activate, 6043cdf0e10cSrcweir // damit andere externe Child-Fenster auch unsere Palette 6044cdf0e10cSrcweir // ueberschreiben koennen. So wird unsere jedenfalls nur einmal 6045cdf0e10cSrcweir // gesetzt und nicht immer rekursiv, da an allen anderen Stellen 6046cdf0e10cSrcweir // diese nur als Background-Palette gesetzt wird 6047cdf0e10cSrcweir if ( LOWORD( wParam ) != WA_INACTIVE ) 6048cdf0e10cSrcweir ImplSendMessage( hWnd, SAL_MSG_FORCEPALETTE, 0, 0 ); 6049cdf0e10cSrcweir break; 6050cdf0e10cSrcweir 6051cdf0e10cSrcweir case WM_ENABLE: 6052cdf0e10cSrcweir // #95133# a system dialog is opened/closed, using our app window as parent 6053cdf0e10cSrcweir { 6054cdf0e10cSrcweir WinSalFrame* pFrame = GetWindowPtr( hWnd ); 6055cdf0e10cSrcweir Window *pWin = NULL; 6056cdf0e10cSrcweir if( pFrame ) 6057cdf0e10cSrcweir pWin = pFrame->GetWindow(); 6058cdf0e10cSrcweir 6059cdf0e10cSrcweir if( !wParam ) 6060cdf0e10cSrcweir { 6061cdf0e10cSrcweir ImplSVData* pSVData = ImplGetSVData(); 6062cdf0e10cSrcweir pSVData->maAppData.mnModalMode++; 6063cdf0e10cSrcweir 6064cdf0e10cSrcweir // #106431#, hide SplashScreen 6065cdf0e10cSrcweir if( pSVData->mpIntroWindow ) 6066cdf0e10cSrcweir pSVData->mpIntroWindow->Hide(); 6067cdf0e10cSrcweir 6068cdf0e10cSrcweir if( pWin ) 6069cdf0e10cSrcweir { 6070cdf0e10cSrcweir pWin->EnableInput( FALSE, TRUE, TRUE, NULL ); 6071cdf0e10cSrcweir pWin->ImplIncModalCount(); // #106303# support frame based modal count 6072cdf0e10cSrcweir } 6073cdf0e10cSrcweir } 6074cdf0e10cSrcweir else 6075cdf0e10cSrcweir { 6076cdf0e10cSrcweir ImplGetSVData()->maAppData.mnModalMode--; 6077cdf0e10cSrcweir if( pWin ) 6078cdf0e10cSrcweir { 6079cdf0e10cSrcweir pWin->EnableInput( TRUE, TRUE, TRUE, NULL ); 6080cdf0e10cSrcweir pWin->ImplDecModalCount(); // #106303# support frame based modal count 6081cdf0e10cSrcweir } 6082cdf0e10cSrcweir } 6083cdf0e10cSrcweir } 6084cdf0e10cSrcweir break; 6085cdf0e10cSrcweir 6086cdf0e10cSrcweir case WM_KILLFOCUS: 6087cdf0e10cSrcweir DestroyCaret(); 6088cdf0e10cSrcweir case WM_SETFOCUS: 6089cdf0e10cSrcweir case SAL_MSG_POSTFOCUS: 6090cdf0e10cSrcweir ImplHandleFocusMsg( hWnd ); 6091cdf0e10cSrcweir rDef = FALSE; 6092cdf0e10cSrcweir break; 6093cdf0e10cSrcweir 6094cdf0e10cSrcweir case WM_CLOSE: 6095cdf0e10cSrcweir ImplHandleCloseMsg( hWnd ); 6096cdf0e10cSrcweir rDef = FALSE; 6097cdf0e10cSrcweir break; 6098cdf0e10cSrcweir 6099cdf0e10cSrcweir case WM_QUERYENDSESSION: 6100cdf0e10cSrcweir if( !bInQueryEnd ) 6101cdf0e10cSrcweir { 6102cdf0e10cSrcweir // handle queryendsession only once 6103cdf0e10cSrcweir bInQueryEnd = TRUE; 6104cdf0e10cSrcweir nRet = !ImplHandleShutDownMsg( hWnd ); 6105cdf0e10cSrcweir rDef = FALSE; 6106cdf0e10cSrcweir 6107cdf0e10cSrcweir // Issue #16314#: ImplHandleShutDownMsg causes a PostMessage in case of allowing shutdown. 6108cdf0e10cSrcweir // This posted message was never processed and cause Windows XP to hang after log off 6109cdf0e10cSrcweir // if there are multiple sessions and the current session wasn't the first one started. 6110cdf0e10cSrcweir // So if shutdown is allowed we assume that a post message was done and retrieve all 6111cdf0e10cSrcweir // messages in the message queue and dispatch them before we return control to the system. 6112cdf0e10cSrcweir 6113cdf0e10cSrcweir if ( nRet ) 6114cdf0e10cSrcweir { 6115cdf0e10cSrcweir MSG msg; 6116cdf0e10cSrcweir 6117cdf0e10cSrcweir while( PeekMessage( &msg, NULL, 0, 0, PM_REMOVE ) ) 6118cdf0e10cSrcweir { 6119cdf0e10cSrcweir DispatchMessage( &msg ); 6120cdf0e10cSrcweir } 6121cdf0e10cSrcweir } 6122cdf0e10cSrcweir } 6123cdf0e10cSrcweir else 6124cdf0e10cSrcweir { 6125cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 6126cdf0e10cSrcweir ImplSalYieldMutexRelease(); 6127cdf0e10cSrcweir rDef = TRUE; 6128cdf0e10cSrcweir } 6129cdf0e10cSrcweir break; 6130cdf0e10cSrcweir 6131cdf0e10cSrcweir case WM_ENDSESSION: 6132cdf0e10cSrcweir if( !wParam ) 6133cdf0e10cSrcweir bInQueryEnd = FALSE; // no shutdown: allow query again 6134cdf0e10cSrcweir nRet = FALSE; 6135cdf0e10cSrcweir rDef = FALSE; 6136cdf0e10cSrcweir break; 6137cdf0e10cSrcweir 6138cdf0e10cSrcweir case WM_DISPLAYCHANGE: 6139cdf0e10cSrcweir case WM_SETTINGCHANGE: 6140cdf0e10cSrcweir case WM_DEVMODECHANGE: 6141cdf0e10cSrcweir case WM_FONTCHANGE: 6142cdf0e10cSrcweir case WM_SYSCOLORCHANGE: 6143cdf0e10cSrcweir case WM_TIMECHANGE: 6144cdf0e10cSrcweir ImplHandleSettingsChangeMsg( hWnd, nMsg, wParam, lParam ); 6145cdf0e10cSrcweir break; 6146cdf0e10cSrcweir 6147cdf0e10cSrcweir case WM_THEMECHANGED: 6148cdf0e10cSrcweir GetSalData()->mbThemeChanged = TRUE; 6149cdf0e10cSrcweir break; 6150cdf0e10cSrcweir 6151cdf0e10cSrcweir case SAL_MSG_USEREVENT: 6152cdf0e10cSrcweir ImplHandleUserEvent( hWnd, lParam ); 6153cdf0e10cSrcweir rDef = FALSE; 6154cdf0e10cSrcweir break; 6155cdf0e10cSrcweir 6156cdf0e10cSrcweir case SAL_MSG_CAPTUREMOUSE: 6157cdf0e10cSrcweir SetCapture( hWnd ); 6158cdf0e10cSrcweir rDef = FALSE; 6159cdf0e10cSrcweir break; 6160cdf0e10cSrcweir case SAL_MSG_RELEASEMOUSE: 6161cdf0e10cSrcweir if ( ::GetCapture() == hWnd ) 6162cdf0e10cSrcweir ReleaseCapture(); 6163cdf0e10cSrcweir rDef = FALSE; 6164cdf0e10cSrcweir break; 6165cdf0e10cSrcweir case SAL_MSG_TOTOP: 6166cdf0e10cSrcweir ImplSalToTop( hWnd, (sal_uInt16)wParam ); 6167cdf0e10cSrcweir rDef = FALSE; 6168cdf0e10cSrcweir break; 6169cdf0e10cSrcweir case SAL_MSG_SHOW: 6170cdf0e10cSrcweir ImplSalShow( hWnd, (sal_Bool)wParam, (sal_Bool)lParam ); 6171cdf0e10cSrcweir rDef = FALSE; 6172cdf0e10cSrcweir break; 6173cdf0e10cSrcweir case SAL_MSG_SETINPUTCONTEXT: 6174cdf0e10cSrcweir ImplSalFrameSetInputContext( hWnd, (const SalInputContext*)(void*)lParam ); 6175cdf0e10cSrcweir rDef = FALSE; 6176cdf0e10cSrcweir break; 6177cdf0e10cSrcweir case SAL_MSG_ENDEXTTEXTINPUT: 6178cdf0e10cSrcweir ImplSalFrameEndExtTextInput( hWnd, (sal_uInt16)(sal_uLong)(void*)wParam ); 6179cdf0e10cSrcweir rDef = FALSE; 6180cdf0e10cSrcweir break; 6181cdf0e10cSrcweir 6182cdf0e10cSrcweir case WM_INPUTLANGCHANGE: 6183cdf0e10cSrcweir ImplHandleInputLangChange( hWnd, wParam, lParam ); 6184cdf0e10cSrcweir break; 6185cdf0e10cSrcweir 6186cdf0e10cSrcweir case WM_IME_CHAR: 6187cdf0e10cSrcweir // #103487#, some IMEs (eg, those that do not work onspot) 6188cdf0e10cSrcweir // may send WM_IME_CHAR instead of WM_IME_COMPOSITION 6189cdf0e10cSrcweir // we just handle it like a WM_CHAR message - seems to work fine 6190cdf0e10cSrcweir ImplSalYieldMutexAcquireWithWait(); 6191cdf0e10cSrcweir rDef = !ImplHandleKeyMsg( hWnd, WM_CHAR, wParam, lParam, nRet ); 6192cdf0e10cSrcweir ImplSalYieldMutexRelease(); 6193cdf0e10cSrcweir break; 6194cdf0e10cSrcweir 6195cdf0e10cSrcweir case WM_IME_STARTCOMPOSITION: 6196cdf0e10cSrcweir rDef = ImplHandleIMEStartComposition( hWnd ); 6197cdf0e10cSrcweir break; 6198cdf0e10cSrcweir 6199cdf0e10cSrcweir case WM_IME_COMPOSITION: 6200cdf0e10cSrcweir rDef = ImplHandleIMEComposition( hWnd, lParam ); 6201cdf0e10cSrcweir break; 6202cdf0e10cSrcweir 6203cdf0e10cSrcweir case WM_IME_ENDCOMPOSITION: 6204cdf0e10cSrcweir rDef = ImplHandleIMEEndComposition( hWnd ); 6205cdf0e10cSrcweir break; 6206cdf0e10cSrcweir 6207cdf0e10cSrcweir case WM_IME_NOTIFY: 6208cdf0e10cSrcweir ImplHandleIMENotify( hWnd, wParam ); 6209cdf0e10cSrcweir break; 6210df906e24SSteve Yin 6211df906e24SSteve Yin //IAccessibility2 implementation 2009----- 6212df906e24SSteve Yin #ifdef WNT 6213df906e24SSteve Yin case WM_GETOBJECT: 6214df906e24SSteve Yin { 6215df906e24SSteve Yin if (!Application::IsEnableAccessInterface()) 6216df906e24SSteve Yin { 6217df906e24SSteve Yin break; 6218df906e24SSteve Yin } 6219df906e24SSteve Yin else 6220df906e24SSteve Yin { 62213a700b0aSSteve Yin if (Application::GetSettings().GetMiscSettings().GetEnableATToolSupport()) 62226fa810f3SSteve Yin { 6223df906e24SSteve Yin // Make sure to launch Accessibiliity only the following criterias are satisfied to avoid RFT interrupts regular acc processing 6224*b0a7a3cfSSteve Yin if (g_acc_manager1 == NULL) 6225df906e24SSteve Yin { 6226df906e24SSteve Yin sal_Bool bCancelled; 6227df906e24SSteve Yin InitAccessBridge(sal_False,bCancelled); 6228df906e24SSteve Yin if( bCancelled ) 6229df906e24SSteve Yin break; 6230df906e24SSteve Yin } 6231df906e24SSteve Yin if (g_acc_manager1 != NULL) 6232df906e24SSteve Yin { 6233df906e24SSteve Yin // MT: mhOnSetTitleWnd not set to reasonable value anywhere... 6234df906e24SSteve Yin /* 6235df906e24SSteve Yin sal_Bool bSkipSetTitleClient = sal_False; 6236df906e24SSteve Yin SalFrame* pFrame = GetWindowPtr( hWnd ); 6237df906e24SSteve Yin if(pFrame) 6238df906e24SSteve Yin { 6239df906e24SSteve Yin bSkipSetTitleClient = (lParam == OBJID_CLIENT && hWnd == ((WinSalFrame*)pFrame)->mhOnSetTitleWnd); 6240df906e24SSteve Yin } 6241df906e24SSteve Yin */ 6242df906e24SSteve Yin if ( (lParam == OBJID_CLIENT ) /* && !bSkipSetTitleClient */ ) 6243df906e24SSteve Yin { 6244df906e24SSteve Yin long RetResult = g_acc_manager1->getAccObjectPtr((long)hWnd, lParam, wParam); 6245df906e24SSteve Yin if(RetResult != 0) 6246df906e24SSteve Yin { 6247df906e24SSteve Yin rDef = FALSE; 6248df906e24SSteve Yin return (HRESULT)RetResult; 6249df906e24SSteve Yin } 6250df906e24SSteve Yin } 6251df906e24SSteve Yin } 6252df906e24SSteve Yin } 62536fa810f3SSteve Yin } 6254df906e24SSteve Yin break; 6255df906e24SSteve Yin } 6256df906e24SSteve Yin #endif 6257df906e24SSteve Yin //-----IAccessibility2 implementation 2009 6258df906e24SSteve Yin 6259cdf0e10cSrcweir case WM_APPCOMMAND: 6260cdf0e10cSrcweir if( ImplHandleAppCommand( hWnd, lParam ) ) 6261cdf0e10cSrcweir { 6262cdf0e10cSrcweir rDef = false; 6263cdf0e10cSrcweir nRet = 1; 6264cdf0e10cSrcweir } 6265cdf0e10cSrcweir break; 6266cdf0e10cSrcweir #if WINVER >= 0x0500 6267cdf0e10cSrcweir case WM_IME_REQUEST: 6268cdf0e10cSrcweir if ( PtrToInt( wParam ) == IMR_RECONVERTSTRING ) 6269cdf0e10cSrcweir { 6270cdf0e10cSrcweir nRet = ImplHandleIMEReconvertString( hWnd, lParam ); 6271cdf0e10cSrcweir rDef = FALSE; 6272cdf0e10cSrcweir } 6273cdf0e10cSrcweir else if( PtrToInt( wParam ) == IMR_CONFIRMRECONVERTSTRING ) 6274cdf0e10cSrcweir { 6275cdf0e10cSrcweir nRet = ImplHandleIMEConfirmReconvertString( hWnd, lParam ); 6276cdf0e10cSrcweir rDef = FALSE; 6277cdf0e10cSrcweir } 6278cdf0e10cSrcweir break; 6279cdf0e10cSrcweir #endif // WINVER >= 0x0500 6280cdf0e10cSrcweir } 6281cdf0e10cSrcweir 6282cdf0e10cSrcweir // WheelMouse-Message abfangen 6283cdf0e10cSrcweir if ( rDef && (nMsg == aSalShlData.mnWheelMsgId) && aSalShlData.mnWheelMsgId ) 6284cdf0e10cSrcweir { 6285cdf0e10cSrcweir // Gegen Rekursion absichern, falls wir vom IE oder dem externen 6286cdf0e10cSrcweir // Fenster die Message wieder zurueckbekommen 6287cdf0e10cSrcweir if ( !bInWheelMsg ) 6288cdf0e10cSrcweir { 6289cdf0e10cSrcweir bInWheelMsg++; 6290cdf0e10cSrcweir // Zuerst wollen wir die Message dispatchen und dann darf auch 6291cdf0e10cSrcweir // das SystemWindow drankommen 6292cdf0e10cSrcweir WORD nKeyState = 0; 6293cdf0e10cSrcweir if ( GetKeyState( VK_SHIFT ) & 0x8000 ) 6294cdf0e10cSrcweir nKeyState |= MK_SHIFT; 6295cdf0e10cSrcweir if ( GetKeyState( VK_CONTROL ) & 0x8000 ) 6296cdf0e10cSrcweir nKeyState |= MK_CONTROL; 6297cdf0e10cSrcweir // Mutex handling is inside from this call 6298cdf0e10cSrcweir rDef = !ImplHandleWheelMsg( hWnd, 6299cdf0e10cSrcweir WM_MOUSEWHEEL, 6300cdf0e10cSrcweir MAKEWPARAM( nKeyState, (WORD)wParam ), 6301cdf0e10cSrcweir lParam ); 6302cdf0e10cSrcweir if ( rDef ) 6303cdf0e10cSrcweir { 6304cdf0e10cSrcweir HWND hWheelWnd = ::GetFocus(); 6305cdf0e10cSrcweir if ( hWheelWnd && (hWheelWnd != hWnd) ) 6306cdf0e10cSrcweir { 6307cdf0e10cSrcweir nRet = ImplSendMessage( hWheelWnd, nMsg, wParam, lParam ); 6308cdf0e10cSrcweir rDef = FALSE; 6309cdf0e10cSrcweir } 6310cdf0e10cSrcweir else 6311cdf0e10cSrcweir rDef = ImplSalWheelMousePos( hWnd, nMsg, wParam, lParam, nRet ); 6312cdf0e10cSrcweir } 6313cdf0e10cSrcweir bInWheelMsg--; 6314cdf0e10cSrcweir } 6315cdf0e10cSrcweir } 6316cdf0e10cSrcweir 6317cdf0e10cSrcweir if( bCheckTimers ) 6318cdf0e10cSrcweir { 6319cdf0e10cSrcweir SalData* pSalData = GetSalData(); 6320cdf0e10cSrcweir if( pSalData->mnNextTimerTime ) 6321cdf0e10cSrcweir { 6322cdf0e10cSrcweir DWORD nCurTime = GetTickCount(); 6323cdf0e10cSrcweir if( pSalData->mnNextTimerTime < nCurTime ) 6324cdf0e10cSrcweir { 6325cdf0e10cSrcweir MSG aMsg; 6326cdf0e10cSrcweir if( ! ImplPeekMessage( &aMsg, 0, WM_PAINT, WM_PAINT, PM_NOREMOVE | PM_NOYIELD ) ) 6327cdf0e10cSrcweir ImplPostMessage( pSalData->mpFirstInstance->mhComWnd, SAL_MSG_POSTTIMER, 0, nCurTime ); 6328cdf0e10cSrcweir } 6329cdf0e10cSrcweir } 6330cdf0e10cSrcweir } 6331cdf0e10cSrcweir 6332cdf0e10cSrcweir return nRet; 6333cdf0e10cSrcweir } 6334cdf0e10cSrcweir 6335cdf0e10cSrcweir LRESULT CALLBACK SalFrameWndProcA( HWND hWnd, UINT nMsg, WPARAM wParam, LPARAM lParam ) 6336cdf0e10cSrcweir { 6337cdf0e10cSrcweir int bDef = TRUE; 6338cdf0e10cSrcweir LRESULT nRet = 0; 6339cdf0e10cSrcweir #ifdef __MINGW32__ 6340cdf0e10cSrcweir jmp_buf jmpbuf; 6341cdf0e10cSrcweir __SEHandler han; 6342cdf0e10cSrcweir if (__builtin_setjmp(jmpbuf) == 0) 6343cdf0e10cSrcweir { 6344cdf0e10cSrcweir han.Set(jmpbuf, NULL, (__SEHandler::PF)EXCEPTION_EXECUTE_HANDLER); 6345cdf0e10cSrcweir #else 6346cdf0e10cSrcweir __try 6347cdf0e10cSrcweir { 6348cdf0e10cSrcweir #endif 6349cdf0e10cSrcweir nRet = SalFrameWndProc( hWnd, nMsg, wParam, lParam, bDef ); 6350cdf0e10cSrcweir } 6351cdf0e10cSrcweir #ifdef __MINGW32__ 6352cdf0e10cSrcweir han.Reset(); 6353cdf0e10cSrcweir #else 6354cdf0e10cSrcweir __except(WinSalInstance::WorkaroundExceptionHandlingInUSER32Lib(GetExceptionCode(), GetExceptionInformation())) 6355cdf0e10cSrcweir { 6356cdf0e10cSrcweir } 6357cdf0e10cSrcweir #endif 6358cdf0e10cSrcweir if ( bDef ) 6359cdf0e10cSrcweir nRet = DefWindowProcA( hWnd, nMsg, wParam, lParam ); 6360cdf0e10cSrcweir return nRet; 6361cdf0e10cSrcweir } 6362cdf0e10cSrcweir 6363cdf0e10cSrcweir LRESULT CALLBACK SalFrameWndProcW( HWND hWnd, UINT nMsg, WPARAM wParam, LPARAM lParam ) 6364cdf0e10cSrcweir { 6365cdf0e10cSrcweir int bDef = TRUE; 6366cdf0e10cSrcweir LRESULT nRet = 0; 6367cdf0e10cSrcweir #ifdef __MINGW32__ 6368cdf0e10cSrcweir jmp_buf jmpbuf; 6369cdf0e10cSrcweir __SEHandler han; 6370cdf0e10cSrcweir if (__builtin_setjmp(jmpbuf) == 0) 6371cdf0e10cSrcweir { 6372cdf0e10cSrcweir han.Set(jmpbuf, NULL, (__SEHandler::PF)EXCEPTION_EXECUTE_HANDLER); 6373cdf0e10cSrcweir #else 6374cdf0e10cSrcweir __try 6375cdf0e10cSrcweir { 6376cdf0e10cSrcweir #endif 6377cdf0e10cSrcweir nRet = SalFrameWndProc( hWnd, nMsg, wParam, lParam, bDef ); 6378cdf0e10cSrcweir } 6379cdf0e10cSrcweir #ifdef __MINGW32__ 6380cdf0e10cSrcweir han.Reset(); 6381cdf0e10cSrcweir #else 6382cdf0e10cSrcweir __except(WinSalInstance::WorkaroundExceptionHandlingInUSER32Lib(GetExceptionCode(), GetExceptionInformation())) 6383cdf0e10cSrcweir { 6384cdf0e10cSrcweir } 6385cdf0e10cSrcweir #endif 6386cdf0e10cSrcweir 6387cdf0e10cSrcweir if ( bDef ) 6388cdf0e10cSrcweir nRet = DefWindowProcW( hWnd, nMsg, wParam, lParam ); 6389cdf0e10cSrcweir return nRet; 6390cdf0e10cSrcweir } 6391cdf0e10cSrcweir 6392cdf0e10cSrcweir // ----------------------------------------------------------------------- 6393cdf0e10cSrcweir 6394cdf0e10cSrcweir sal_Bool ImplHandleGlobalMsg( HWND hWnd, UINT nMsg, WPARAM wParam, LPARAM lParam, LRESULT& rlResult ) 6395cdf0e10cSrcweir { 6396cdf0e10cSrcweir // handle all messages concerning all frames so they get processed only once 6397cdf0e10cSrcweir // Must work for Unicode and none Unicode 6398cdf0e10cSrcweir sal_Bool bResult = FALSE; 6399cdf0e10cSrcweir if ( (nMsg == WM_PALETTECHANGED) || (nMsg == SAL_MSG_POSTPALCHANGED) ) 6400cdf0e10cSrcweir { 6401cdf0e10cSrcweir int bDef = TRUE; 6402cdf0e10cSrcweir rlResult = ImplHandlePalette( FALSE, hWnd, nMsg, wParam, lParam, bDef ); 6403cdf0e10cSrcweir bResult = (bDef != 0); 6404cdf0e10cSrcweir } 6405cdf0e10cSrcweir else if( nMsg == WM_DISPLAYCHANGE ) 6406cdf0e10cSrcweir { 6407cdf0e10cSrcweir WinSalSystem* pSys = static_cast<WinSalSystem*>(ImplGetSalSystem()); 6408cdf0e10cSrcweir if( pSys ) 6409cdf0e10cSrcweir pSys->clearMonitors(); 6410cdf0e10cSrcweir bResult = (pSys != NULL); 6411cdf0e10cSrcweir } 6412cdf0e10cSrcweir return bResult; 6413cdf0e10cSrcweir } 6414cdf0e10cSrcweir 6415cdf0e10cSrcweir // ----------------------------------------------------------------------- 6416cdf0e10cSrcweir 6417cdf0e10cSrcweir sal_Bool ImplWriteLastError( DWORD lastError, const char *szApiCall ) 6418cdf0e10cSrcweir { 6419cdf0e10cSrcweir static int first=1; 6420cdf0e10cSrcweir // if VCL_LOGFILE_ENABLED is set, Win32 API error messages can be written 6421cdf0e10cSrcweir // to %TMP%/vcl.log or %TEMP%/vcl.log 6422cdf0e10cSrcweir static char *logEnabled = getenv("VCL_LOGFILE_ENABLED"); 6423cdf0e10cSrcweir if( logEnabled ) 6424cdf0e10cSrcweir { 6425cdf0e10cSrcweir sal_Bool bSuccess = FALSE; 6426cdf0e10cSrcweir static char *szTmp = getenv("TMP"); 6427cdf0e10cSrcweir if( !szTmp || !*szTmp ) 6428cdf0e10cSrcweir szTmp = getenv("TEMP"); 6429cdf0e10cSrcweir if( szTmp && *szTmp ) 6430cdf0e10cSrcweir { 6431cdf0e10cSrcweir char fname[5000]; 6432cdf0e10cSrcweir strcpy( fname, szTmp ); 6433cdf0e10cSrcweir if( fname[strlen(fname) - 1] != '\\' ) 6434cdf0e10cSrcweir strcat( fname, "\\"); 6435cdf0e10cSrcweir strcat( fname, "vcl.log" ); 6436cdf0e10cSrcweir FILE *fp = fopen( fname, "a" ); // always append 6437cdf0e10cSrcweir if( fp ) 6438cdf0e10cSrcweir { 6439cdf0e10cSrcweir if( first ) 6440cdf0e10cSrcweir { 6441cdf0e10cSrcweir first = 0; 6442cdf0e10cSrcweir fprintf( fp, "Process ID: %d (0x%x)\n", GetCurrentProcessId(), GetCurrentProcessId() ); 6443cdf0e10cSrcweir } 6444cdf0e10cSrcweir time_t aclock; 6445cdf0e10cSrcweir time( &aclock ); // Get time in seconds 6446cdf0e10cSrcweir struct tm *newtime = localtime( &aclock ); // Convert time to struct tm form 6447cdf0e10cSrcweir fprintf( fp, asctime( newtime ) ); // print time stamp 6448cdf0e10cSrcweir 6449cdf0e10cSrcweir fprintf( fp, "%s returned %u (0x%x)\n", szApiCall, lastError, lastError ); 6450cdf0e10cSrcweir bSuccess = TRUE; // may be FormatMessage fails but we wrote at least the error code 6451cdf0e10cSrcweir 6452cdf0e10cSrcweir LPVOID lpMsgBuf; 6453cdf0e10cSrcweir if (FormatMessageA( 6454cdf0e10cSrcweir FORMAT_MESSAGE_ALLOCATE_BUFFER | 6455cdf0e10cSrcweir FORMAT_MESSAGE_FROM_SYSTEM | 6456cdf0e10cSrcweir FORMAT_MESSAGE_IGNORE_INSERTS, 6457cdf0e10cSrcweir NULL, 6458cdf0e10cSrcweir lastError, 6459cdf0e10cSrcweir MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language 6460cdf0e10cSrcweir (LPSTR) &lpMsgBuf, 6461cdf0e10cSrcweir 0, 6462cdf0e10cSrcweir NULL )) 6463cdf0e10cSrcweir { 6464cdf0e10cSrcweir fprintf( fp, " %s\n", (LPSTR)lpMsgBuf ); 6465cdf0e10cSrcweir LocalFree( lpMsgBuf ); 6466cdf0e10cSrcweir } 6467cdf0e10cSrcweir 6468cdf0e10cSrcweir fclose( fp ); 6469cdf0e10cSrcweir } 6470cdf0e10cSrcweir } 6471cdf0e10cSrcweir return bSuccess; 6472cdf0e10cSrcweir } 6473cdf0e10cSrcweir else 6474cdf0e10cSrcweir return TRUE; 6475cdf0e10cSrcweir } 6476cdf0e10cSrcweir 6477cdf0e10cSrcweir // ----------------------------------------------------------------------- 6478cdf0e10cSrcweir 6479df906e24SSteve Yin //IAccessibility2 implementation 2009----- 6480df906e24SSteve Yin #ifdef WNT 6481df906e24SSteve Yin bool IsWNTInitAccessBridge() 6482df906e24SSteve Yin { 6483df906e24SSteve Yin return NULL != g_acc_manager1; 6484df906e24SSteve Yin } 6485df906e24SSteve Yin #endif 6486df906e24SSteve Yin #ifdef WNT 6487df906e24SSteve Yin bool WNTEnableAccessInterface(bool bEnable) 6488df906e24SSteve Yin { 6489df906e24SSteve Yin ImplSVData* pSVData = ImplGetSVData(); 6490df906e24SSteve Yin 6491df906e24SSteve Yin BOOL bPreVal = pSVData->maAppData.m_bEnableAccessInterface; 6492df906e24SSteve Yin long nEnable= bEnable; 6493df906e24SSteve Yin ::InterlockedExchange( 6494df906e24SSteve Yin (LPLONG)&(pSVData->maAppData.m_bEnableAccessInterface), 6495df906e24SSteve Yin nEnable); 6496df906e24SSteve Yin 6497df906e24SSteve Yin return bPreVal; 6498df906e24SSteve Yin } 6499df906e24SSteve Yin #endif 6500df906e24SSteve Yin //-----IAccessibility2 implementation 2009 6501