1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 // MARKER(update_precomp.py): autogen include statement, do not remove 25 #include "precompiled_vcl.hxx" 26 27 #include "tools/time.hxx" 28 #include "tools/debug.hxx" 29 #include "tools/rc.h" 30 31 #include "unotools/fontcfg.hxx" 32 #include "unotools/confignode.hxx" 33 34 #include "vcl/unohelp.hxx" 35 #include "vcl/salgtype.hxx" 36 #include "vcl/event.hxx" 37 #include "vcl/help.hxx" 38 #include "vcl/cursor.hxx" 39 #include "vcl/svapp.hxx" 40 #include "vcl/window.hxx" 41 #include "vcl/syswin.hxx" 42 #include "vcl/syschild.hxx" 43 #include "vcl/dockwin.hxx" 44 #include "vcl/menu.hxx" 45 #include "vcl/wrkwin.hxx" 46 #include "vcl/wall.hxx" 47 #include "vcl/gradient.hxx" 48 #include "vcl/salctype.hxx" 49 #include "vcl/button.hxx" 50 #include "vcl/taskpanelist.hxx" 51 #include "vcl/dialog.hxx" 52 #include "vcl/unowrap.hxx" 53 #include "vcl/gdimtf.hxx" 54 #include "vcl/pdfextoutdevdata.hxx" 55 #include "vcl/lazydelete.hxx" 56 57 // declare system types in sysdata.hxx 58 #include "svsys.h" 59 #include "vcl/sysdata.hxx" 60 61 #include "salframe.hxx" 62 #include "salobj.hxx" 63 #include "salinst.hxx" 64 #include "salgdi.hxx" 65 #include "svdata.hxx" 66 #include "dbggui.hxx" 67 #include "outfont.hxx" 68 #include "window.h" 69 #include "toolbox.h" 70 #include "outdev.h" 71 #include "brdwin.hxx" 72 #include "helpwin.hxx" 73 #include "sallayout.hxx" 74 #include "dndlcon.hxx" 75 #include "dndevdis.hxx" 76 77 #include "com/sun/star/awt/XWindowPeer.hpp" 78 #include "com/sun/star/rendering/XCanvas.hpp" 79 #include "com/sun/star/rendering/XSpriteCanvas.hpp" 80 #include "com/sun/star/awt/XWindow.hpp" 81 #include "comphelper/processfactory.hxx" 82 #include "com/sun/star/datatransfer/dnd/XDragSource.hpp" 83 #include "com/sun/star/datatransfer/dnd/XDropTarget.hpp" 84 #include "com/sun/star/datatransfer/clipboard/XClipboard.hpp" 85 #include "com/sun/star/awt/XTopWindow.hpp" 86 #include "com/sun/star/awt/XDisplayConnection.hpp" 87 #include "com/sun/star/lang/XInitialization.hpp" 88 #include "com/sun/star/lang/XComponent.hpp" 89 #include "com/sun/star/lang/XServiceName.hpp" 90 #include "com/sun/star/accessibility/XAccessible.hpp" 91 #include "com/sun/star/accessibility/AccessibleRole.hpp" 92 93 #include <set> 94 #include <typeinfo> 95 96 using namespace rtl; 97 using namespace ::com::sun::star::uno; 98 using namespace ::com::sun::star::lang; 99 using namespace ::com::sun::star::datatransfer::clipboard; 100 using namespace ::com::sun::star::datatransfer::dnd; 101 using namespace ::com::sun::star; 102 using namespace com::sun; 103 104 using ::com::sun::star::awt::XTopWindow; 105 106 // ======================================================================= 107 108 DBG_NAME( Window ) 109 110 // ======================================================================= 111 112 #define IMPL_PAINT_PAINT ((sal_uInt16)0x0001) 113 #define IMPL_PAINT_PAINTALL ((sal_uInt16)0x0002) 114 #define IMPL_PAINT_PAINTALLCHILDS ((sal_uInt16)0x0004) 115 #define IMPL_PAINT_PAINTCHILDS ((sal_uInt16)0x0008) 116 #define IMPL_PAINT_ERASE ((sal_uInt16)0x0010) 117 #define IMPL_PAINT_CHECKRTL ((sal_uInt16)0x0020) 118 119 // ----------------------------------------------------------------------- 120 121 typedef Window* PWINDOW; 122 123 // ----------------------------------------------------------------------- 124 125 struct ImplCalcToTopData 126 { 127 ImplCalcToTopData* mpNext; 128 Window* mpWindow; 129 Region* mpInvalidateRegion; 130 }; 131 132 ImplAccessibleInfos::ImplAccessibleInfos() 133 { 134 nAccessibleRole = 0xFFFF; 135 pAccessibleName = NULL; 136 pAccessibleDescription = NULL; 137 pLabeledByWindow = NULL; 138 pLabelForWindow = NULL; 139 pMemberOfWindow = NULL; 140 } 141 142 ImplAccessibleInfos::~ImplAccessibleInfos() 143 { 144 delete pAccessibleName; 145 delete pAccessibleDescription; 146 } 147 148 // ----------------------------------------------------------------------- 149 150 WindowImpl::WindowImpl( WindowType nType ) 151 { 152 maZoom = Fraction( 1, 1 ); 153 maWinRegion = Region(true); 154 maWinClipRegion = Region(true); 155 mpWinData = NULL; // Extra Window Data, that we dont need for all windows 156 mpOverlapData = NULL; // Overlap Data 157 mpFrameData = NULL; // Frame Data 158 mpFrame = NULL; // Pointer to frame window 159 mpSysObj = NULL; 160 mpFrameWindow = NULL; // window to top level parent (same as frame window) 161 mpOverlapWindow = NULL; // first overlap parent 162 mpBorderWindow = NULL; // Border-Window 163 mpClientWindow = NULL; // Client-Window of a FrameWindow 164 mpParent = NULL; // parent (inkl. BorderWindow) 165 mpRealParent = NULL; // real parent (exkl. BorderWindow) 166 mpFirstChild = NULL; // first child window 167 mpLastChild = NULL; // last child window 168 mpFirstOverlap = NULL; // first overlap window (only set in overlap windows) 169 mpLastOverlap = NULL; // last overlap window (only set in overlap windows) 170 mpPrev = NULL; // prev window 171 mpNext = NULL; // next window 172 mpNextOverlap = NULL; // next overlap window of frame 173 mpLastFocusWindow = NULL; // window for focus restore 174 mpDlgCtrlDownWindow = NULL; // window for dialog control 175 mpFirstDel = NULL; // Dtor notification list 176 mpUserData = NULL; // user data 177 mpExtImpl = NULL; // extended implementation data 178 mpCursor = NULL; // cursor 179 mpControlFont = NULL; // font propertie 180 mpVCLXWindow = NULL; 181 mpAccessibleInfos = NULL; 182 maControlForeground = Color( COL_TRANSPARENT ); // foreground color not set 183 maControlBackground = Color( COL_TRANSPARENT ); // background color not set 184 mnLeftBorder = 0; // left border 185 mnTopBorder = 0; // top border 186 mnRightBorder = 0; // right border 187 mnBottomBorder = 0; // bottom border 188 mnX = 0; // X-Position to Parent 189 mnY = 0; // Y-Position to Parent 190 mnAbsScreenX = 0; // absolute X-position on screen, used for RTL window positioning 191 mpChildClipRegion = NULL; // Child-Clip-Region when ClipChildren 192 mpPaintRegion = NULL; // Paint-ClipRegion 193 mnStyle = 0; // style (init in ImplInitWindow) 194 mnPrevStyle = 0; // prevstyle (set in SetStyle) 195 mnExtendedStyle = 0; // extended style (init in ImplInitWindow) 196 mnPrevExtendedStyle = 0; // prevstyle (set in SetExtendedStyle) 197 mnType = nType; // window type 198 mnGetFocusFlags = 0; // Flags fuer GetFocus()-Aufruf 199 mnWaitCount = 0; // Wait-Count (>1 == Warte-MousePointer) 200 mnPaintFlags = 0; // Flags for ImplCallPaint 201 mnParentClipMode = 0; // Flags for Parent-ClipChildren-Mode 202 mnActivateMode = 0; // Wird bei System/Overlap-Windows umgesetzt 203 mnDlgCtrlFlags = 0; // DialogControl-Flags 204 mnLockCount = 0; // LockCount 205 meAlwaysInputMode = AlwaysInputNone; // neither AlwaysEnableInput nor AlwaysDisableInput called 206 mbFrame = sal_False; // sal_True: Window is a frame window 207 mbBorderWin = sal_False; // sal_True: Window is a border window 208 mbOverlapWin = sal_False; // sal_True: Window is a overlap window 209 mbSysWin = sal_False; // sal_True: SystemWindow is the base class 210 mbDialog = sal_False; // sal_True: Dialog is the base class 211 mbDockWin = sal_False; // sal_True: DockingWindow is the base class 212 mbFloatWin = sal_False; // sal_True: FloatingWindow is the base class 213 mbPushButton = sal_False; // sal_True: PushButton is the base class 214 mbToolBox = sal_False; // sal_True: ToolBox is the base class 215 mbMenuFloatingWindow= sal_False; // sal_True: MenuFloatingWindow is the base class 216 mbToolbarFloatingWindow= sal_False; // sal_True: ImplPopupFloatWin is the base class, used for subtoolbars 217 mbSplitter = sal_False; // sal_True: Splitter is the base class 218 mbVisible = sal_False; // sal_True: Show( sal_True ) called 219 mbOverlapVisible = sal_False; // sal_True: Hide called for visible window from ImplHideAllOverlapWindow() 220 mbDisabled = sal_False; // sal_True: Enable( sal_False ) called 221 mbInputDisabled = sal_False; // sal_True: EnableInput( sal_False ) called 222 mbDropDisabled = sal_False; // sal_True: Drop is enabled 223 mbNoUpdate = sal_False; // sal_True: SetUpdateMode( sal_False ) called 224 mbNoParentUpdate = sal_False; // sal_True: SetParentUpdateMode( sal_False ) called 225 mbActive = sal_False; // sal_True: Window Active 226 mbParentActive = sal_False; // sal_True: OverlapActive from Parent 227 mbReallyVisible = sal_False; // sal_True: this and all parents to an overlaped window are visible 228 mbReallyShown = sal_False; // sal_True: this and all parents to an overlaped window are shown 229 mbInInitShow = sal_False; // sal_True: we are in InitShow 230 mbChildNotify = sal_False; // sal_True: ChildNotify 231 mbChildPtrOverwrite = sal_False; // sal_True: PointerStyle overwrites Child-Pointer 232 mbNoPtrVisible = sal_False; // sal_True: ShowPointer( sal_False ) called 233 mbMouseMove = sal_False; // sal_True: BaseMouseMove called 234 mbPaintFrame = sal_False; // sal_True: Paint is visible, but not painted 235 mbInPaint = sal_False; // sal_True: Inside PaintHdl 236 mbMouseButtonDown = sal_False; // sal_True: BaseMouseButtonDown called 237 mbMouseButtonUp = sal_False; // sal_True: BaseMouseButtonUp called 238 mbKeyInput = sal_False; // sal_True: BaseKeyInput called 239 mbKeyUp = sal_False; // sal_True: BaseKeyUp called 240 mbCommand = sal_False; // sal_True: BaseCommand called 241 mbDefPos = sal_True; // sal_True: Position is not Set 242 mbDefSize = sal_True; // sal_True: Size is not Set 243 mbCallMove = sal_True; // sal_True: Move must be called by Show 244 mbCallResize = sal_True; // sal_True: Resize must be called by Show 245 mbWaitSystemResize = sal_True; // sal_True: Wait for System-Resize 246 mbInitWinClipRegion = sal_True; // sal_True: Calc Window Clip Region 247 mbInitChildRegion = sal_False; // sal_True: InitChildClipRegion 248 mbWinRegion = sal_False; // sal_True: Window Region 249 mbClipChildren = sal_False; // sal_True: request that child-windows get clipped 250 mbClipSiblings = sal_False; // sal_True: request that sibling child-windows get clipped 251 mbChildTransparent = sal_False; // sal_True: allow child-windows to enable transparency (incl. Parent-CLIPCHILDREN) 252 mbPaintTransparent = sal_False; // sal_True: Paints muessen auf Parent ausgeloest werden 253 mbMouseTransparent = sal_False; // sal_True: Window is transparent for Mouse 254 mbDlgCtrlStart = sal_False; // sal_True: Ab hier eigenes Dialog-Control 255 mbFocusVisible = sal_False; // sal_True: Focus Visible 256 mbUseNativeFocus = sal_False; 257 mbNativeFocusVisible= sal_False; // sal_True: native Focus Visible 258 mbInShowFocus = sal_False; // prevent recursion 259 mbInHideFocus = sal_False; // prevent recursion 260 mbTrackVisible = sal_False; // sal_True: Tracking Visible 261 mbControlForeground = sal_False; // sal_True: Foreground-Property set 262 mbControlBackground = sal_False; // sal_True: Background-Property set 263 mbAlwaysOnTop = sal_False; // sal_True: window is always on top 264 mbCompoundControl = sal_False; // sal_True: Zusammengesetztes Control => Listener... 265 mbCompoundControlHasFocus = sal_False; // sal_True: Zusammengesetztes Control hat irgendwo den Focus 266 mbPaintDisabled = sal_False; // sal_True: to disable paint events 267 mbAllResize = sal_False; // sal_True: to enable sending of ResizeEvents with both height=0 and width=0 268 mbInDtor = sal_False; // sal_True: is set when the window is being destructed 269 mbExtTextInput = sal_False; // sal_True: ExtTextInput-Mode is active 270 mbInFocusHdl = sal_False; // sal_True: is set when inside a GetFocus-Handler context 271 mbCreatedWithToolkit = sal_False; 272 mbSuppressAccessibilityEvents = sal_False; // sal_True: do not send any accessibility events 273 mbDrawSelectionBackground = sal_False; // sal_True: draws transparent window background to indicate (toolbox) selection 274 mbIsInTaskPaneList = sal_False; // sal_True: window was added to the taskpanelist in the topmost system window 275 mnNativeBackground = 0; // initialize later, depends on type 276 mbCallHandlersDuringInputDisabled = sal_False; // sal_True: call event handlers even if input is disabled 277 mbDisableAccessibleLabelForRelation = sal_False; // sal_True: do not set LabelFor relation on accessible objects 278 mbDisableAccessibleLabeledByRelation = sal_False; // sal_True: do not set LabeledBy relation on accessible objects 279 mbHelpTextDynamic = sal_False; // sal_True: append help id in HELP_DEBUG case 280 mbFakeFocusSet = sal_False; // sal_True: pretend as if the window has focus. 281 } 282 283 WindowImpl::~WindowImpl() 284 { 285 delete mpChildClipRegion; 286 delete mpAccessibleInfos; 287 delete mpControlFont; 288 } 289 290 291 // ----------------------------------------------------------------------- 292 293 // helper method to allow inline constructor even for pWindow!=NULL case 294 void ImplDelData::AttachToWindow( const Window* pWindow ) 295 { 296 if( pWindow ) 297 const_cast<Window*>(pWindow)->ImplAddDel( this ); 298 } 299 300 // ----------------------------------------------------------------------- 301 302 // define dtor for ImplDelData 303 ImplDelData::~ImplDelData() 304 { 305 // #112873# auto remove of ImplDelData 306 // due to this code actively calling ImplRemoveDel() is not mandatory anymore 307 if( !mbDel && mpWindow ) 308 { 309 // the window still exists but we were not removed 310 const_cast<Window*>(mpWindow)->ImplRemoveDel( this ); 311 mpWindow = NULL; 312 } 313 } 314 315 // ----------------------------------------------------------------------- 316 317 #ifdef DBG_UTIL 318 const char* ImplDbgCheckWindow( const void* pObj ) 319 { 320 DBG_TESTSOLARMUTEX(); 321 322 const Window* pWindow = (Window*)pObj; 323 324 if ( (pWindow->GetType() < WINDOW_FIRST) || (pWindow->GetType() > WINDOW_LAST) ) 325 return "Window data overwrite"; 326 327 // Fenster-Verkettung ueberpruefen 328 Window* pChild = pWindow->mpWindowImpl->mpFirstChild; 329 while ( pChild ) 330 { 331 if ( pChild->mpWindowImpl->mpParent != pWindow ) 332 return "Child-Window-Parent wrong"; 333 pChild = pChild->mpWindowImpl->mpNext; 334 } 335 336 return NULL; 337 } 338 #endif 339 340 // ======================================================================= 341 342 void Window::ImplInitAppFontData( Window* pWindow ) 343 { 344 ImplSVData* pSVData = ImplGetSVData(); 345 long nTextHeight = pWindow->GetTextHeight(); 346 long nTextWidth = pWindow->GetTextWidth( XubString( RTL_CONSTASCII_USTRINGPARAM( "aemnnxEM" ) ) ); 347 long nSymHeight = nTextHeight*4; 348 // Falls Font zu schmal ist, machen wir die Basis breiter, 349 // damit die Dialoge symetrisch aussehen und nicht zu schmal 350 // werden. Wenn der Dialog die gleiche breite hat, geben wir 351 // noch etwas Spielraum dazu, da etwas mehr Platz besser ist. 352 if ( nSymHeight > nTextWidth ) 353 nTextWidth = nSymHeight; 354 else if ( nSymHeight+5 > nTextWidth ) 355 nTextWidth = nSymHeight+5; 356 pSVData->maGDIData.mnAppFontX = nTextWidth * 10 / 8; 357 pSVData->maGDIData.mnAppFontY = nTextHeight * 10; 358 359 // FIXME: this is currently only on aqua, check with other 360 // platforms 361 if( pSVData->maNWFData.mbNoFocusRects ) 362 { 363 // try to find out wether there is a large correction 364 // of control sizes, if yes, make app font scalings larger 365 // so dialog positioning is not completely off 366 ImplControlValue aControlValue; 367 Rectangle aCtrlRegion( Point(), Size( nTextWidth < 10 ? 10 : nTextWidth, nTextHeight < 10 ? 10 : nTextHeight ) ); 368 Rectangle aBoundingRgn( aCtrlRegion ); 369 Rectangle aContentRgn( aCtrlRegion ); 370 if( pWindow->GetNativeControlRegion( CTRL_EDITBOX, PART_ENTIRE_CONTROL, aCtrlRegion, 371 CTRL_STATE_ENABLED, aControlValue, rtl::OUString(), 372 aBoundingRgn, aContentRgn ) ) 373 { 374 // comment: the magical +6 is for the extra border in bordered 375 // (which is the standard) edit fields 376 if( aContentRgn.GetHeight() - nTextHeight > (nTextHeight+4)/4 ) 377 pSVData->maGDIData.mnAppFontY = (aContentRgn.GetHeight()-4) * 10; 378 } 379 } 380 381 382 pSVData->maGDIData.mnRealAppFontX = pSVData->maGDIData.mnAppFontX; 383 if ( pSVData->maAppData.mnDialogScaleX ) 384 pSVData->maGDIData.mnAppFontX += (pSVData->maGDIData.mnAppFontX*pSVData->maAppData.mnDialogScaleX)/100; 385 } 386 387 // ----------------------------------------------------------------------- 388 389 bool Window::ImplCheckUIFont( const Font& rFont ) 390 { 391 if( ImplGetSVData()->maGDIData.mbNativeFontConfig ) 392 return true; 393 394 // create a text string using the localized text of important buttons 395 String aTestText; 396 static const StandardButtonType aTestButtons[] = 397 { 398 BUTTON_OK, BUTTON_CANCEL, BUTTON_CLOSE, BUTTON_ABORT, 399 BUTTON_YES, BUTTON_NO, BUTTON_MORE, BUTTON_IGNORE, 400 BUTTON_RETRY, BUTTON_HELP 401 }; 402 403 const int nTestButtonCount = sizeof(aTestButtons)/sizeof(*aTestButtons); 404 for( int n = 0; n < nTestButtonCount; ++n ) 405 { 406 String aButtonStr = Button::GetStandardText( aTestButtons[n] ); 407 // #i115432# ignore mnemonic+accelerator part of each string 408 // TODO: use a string filtering method when it becomes available 409 const int nLen = aButtonStr.Len(); 410 bool bInside = false; 411 for( int i = 0; i < nLen; ++i ) { 412 const sal_Unicode c = aButtonStr.GetChar( i ); 413 if( (c == '(')) 414 bInside = true; 415 if( (c == ')')) 416 bInside = false; 417 if( (c == '~') 418 || (c == '(') || (c == ')') 419 || ((c >= 'A') && (c <= 'Z') && bInside) ) 420 aButtonStr.SetChar( i, ' ' ); 421 } 422 // append sanitized button text to test string 423 aTestText.Append( aButtonStr ); 424 } 425 426 const int nFirstChar = HasGlyphs( rFont, aTestText ); 427 const bool bUIFontOk = (nFirstChar >= aTestText.Len()); 428 return bUIFontOk; 429 } 430 431 // ----------------------------------------------------------------------- 432 433 void Window::ImplUpdateGlobalSettings( AllSettings& rSettings, sal_Bool bCallHdl ) 434 { 435 // reset high contrast to false, so the system can either update it 436 // or AutoDetectSystemHC can kick in (see below) 437 StyleSettings aTmpSt( rSettings.GetStyleSettings() ); 438 aTmpSt.SetHighContrastMode( sal_False ); 439 rSettings.SetStyleSettings( aTmpSt ); 440 ImplGetFrame()->UpdateSettings( rSettings ); 441 // reset default border width for layouters 442 ImplGetSVData()->maAppData.mnDefaultLayoutBorder = -1; 443 444 // Verify availability of the configured UI font, otherwise choose "Andale Sans UI" 445 String aUserInterfaceFont; 446 bool bUseSystemFont = rSettings.GetStyleSettings().GetUseSystemUIFonts(); 447 448 // check whether system UI font can display a typical UI text 449 if( bUseSystemFont ) 450 bUseSystemFont = ImplCheckUIFont( rSettings.GetStyleSettings().GetAppFont() ); 451 452 if ( !bUseSystemFont ) 453 { 454 ImplInitFontList(); 455 String aConfigFont = utl::DefaultFontConfiguration::get()->getUserInterfaceFont( rSettings.GetUILocale() ); 456 xub_StrLen nIndex = 0; 457 while( nIndex != STRING_NOTFOUND ) 458 { 459 String aName( aConfigFont.GetToken( 0, ';', nIndex ) ); 460 if ( aName.Len() && mpWindowImpl->mpFrameData->mpFontList->FindFontFamily( aName ) ) 461 { 462 aUserInterfaceFont = aConfigFont; 463 break; 464 } 465 } 466 467 if ( ! aUserInterfaceFont.Len() ) 468 { 469 String aFallbackFont (RTL_CONSTASCII_USTRINGPARAM( "Andale Sans UI" )); 470 if ( mpWindowImpl->mpFrameData->mpFontList->FindFontFamily( aFallbackFont ) ) 471 aUserInterfaceFont = aFallbackFont; 472 } 473 } 474 475 if ( !bUseSystemFont && aUserInterfaceFont.Len() ) 476 { 477 StyleSettings aStyleSettings = rSettings.GetStyleSettings(); 478 Font aFont = aStyleSettings.GetAppFont(); 479 aFont.SetName( aUserInterfaceFont ); 480 aStyleSettings.SetAppFont( aFont ); 481 aFont = aStyleSettings.GetHelpFont(); 482 aFont.SetName( aUserInterfaceFont ); 483 aStyleSettings.SetHelpFont( aFont ); 484 aFont = aStyleSettings.GetTitleFont(); 485 aFont.SetName( aUserInterfaceFont ); 486 aStyleSettings.SetTitleFont( aFont ); 487 aFont = aStyleSettings.GetFloatTitleFont(); 488 aFont.SetName( aUserInterfaceFont ); 489 aStyleSettings.SetFloatTitleFont( aFont ); 490 aFont = aStyleSettings.GetMenuFont(); 491 aFont.SetName( aUserInterfaceFont ); 492 aStyleSettings.SetMenuFont( aFont ); 493 aFont = aStyleSettings.GetToolFont(); 494 aFont.SetName( aUserInterfaceFont ); 495 aStyleSettings.SetToolFont( aFont ); 496 aFont = aStyleSettings.GetLabelFont(); 497 aFont.SetName( aUserInterfaceFont ); 498 aStyleSettings.SetLabelFont( aFont ); 499 aFont = aStyleSettings.GetInfoFont(); 500 aFont.SetName( aUserInterfaceFont ); 501 aStyleSettings.SetInfoFont( aFont ); 502 aFont = aStyleSettings.GetRadioCheckFont(); 503 aFont.SetName( aUserInterfaceFont ); 504 aStyleSettings.SetRadioCheckFont( aFont ); 505 aFont = aStyleSettings.GetPushButtonFont(); 506 aFont.SetName( aUserInterfaceFont ); 507 aStyleSettings.SetPushButtonFont( aFont ); 508 aFont = aStyleSettings.GetFieldFont(); 509 aFont.SetName( aUserInterfaceFont ); 510 aStyleSettings.SetFieldFont( aFont ); 511 aFont = aStyleSettings.GetIconFont(); 512 aFont.SetName( aUserInterfaceFont ); 513 aStyleSettings.SetIconFont( aFont ); 514 aFont = aStyleSettings.GetGroupFont(); 515 aFont.SetName( aUserInterfaceFont ); 516 aStyleSettings.SetGroupFont( aFont ); 517 rSettings.SetStyleSettings( aStyleSettings ); 518 } 519 520 StyleSettings aStyleSettings = rSettings.GetStyleSettings(); 521 // #97047: Force all fonts except Menu and Help to a fixed height 522 // to avoid UI scaling due to large fonts 523 // - but allow bigger fonts on bigger screens (i16682, i21238) 524 // dialogs were designed to fit 800x600 with an 8pt font, so scale accordingly 525 int maxFontheight = 9; // #107886#: 9 is default for some asian systems, so always allow if requested 526 if( GetDesktopRectPixel().getHeight() > 600 ) 527 maxFontheight = (int) ((( 8.0 * (double) GetDesktopRectPixel().getHeight()) / 600.0) + 1.5); 528 529 Font aFont = aStyleSettings.GetMenuFont(); 530 int defFontheight = aFont.GetHeight(); 531 if( defFontheight > maxFontheight ) 532 defFontheight = maxFontheight; 533 534 // if the UI is korean, chinese or another locale 535 // where the system font size is kown to be often too small to 536 // generate readable fonts enforce a minimum font size of 9 points 537 bool bBrokenLangFontHeight = false; 538 static const LanguageType eBrokenSystemFontSizeLanguages[] = 539 { LANGUAGE_KOREAN, LANGUAGE_KOREAN_JOHAB, 540 LANGUAGE_CHINESE_HONGKONG, LANGUAGE_CHINESE_MACAU, LANGUAGE_CHINESE_SIMPLIFIED, LANGUAGE_CHINESE_SINGAPORE, LANGUAGE_CHINESE_TRADITIONAL 541 }; 542 static std::set< LanguageType > aBrokenSystemFontSizeLanguagesSet( 543 eBrokenSystemFontSizeLanguages, 544 eBrokenSystemFontSizeLanguages + 545 (sizeof(eBrokenSystemFontSizeLanguages)/sizeof(eBrokenSystemFontSizeLanguages[0])) 546 ); 547 LanguageType aLang = Application::GetSettings().GetUILanguage(); 548 if( aBrokenSystemFontSizeLanguagesSet.find( aLang ) != aBrokenSystemFontSizeLanguagesSet.end() ) 549 { 550 defFontheight = Max(9, defFontheight); 551 bBrokenLangFontHeight = true; 552 } 553 554 // i22098, toolfont will be scaled differently to avoid bloated rulers and status bars for big fonts 555 int toolfontheight = defFontheight; 556 if( toolfontheight > 9 ) 557 toolfontheight = (defFontheight+8) / 2; 558 559 aFont = aStyleSettings.GetAppFont(); 560 aFont.SetHeight( defFontheight ); 561 aStyleSettings.SetAppFont( aFont ); 562 aFont = aStyleSettings.GetTitleFont(); 563 aFont.SetHeight( defFontheight ); 564 aStyleSettings.SetTitleFont( aFont ); 565 aFont = aStyleSettings.GetFloatTitleFont(); 566 aFont.SetHeight( defFontheight ); 567 aStyleSettings.SetFloatTitleFont( aFont ); 568 // keep menu and help font size from system unless in broken locale size 569 if( bBrokenLangFontHeight ) 570 { 571 aFont = aStyleSettings.GetMenuFont(); 572 if( aFont.GetHeight() < defFontheight ) 573 { 574 aFont.SetHeight( defFontheight ); 575 aStyleSettings.SetMenuFont( aFont ); 576 } 577 aFont = aStyleSettings.GetHelpFont(); 578 if( aFont.GetHeight() < defFontheight ) 579 { 580 aFont.SetHeight( defFontheight ); 581 aStyleSettings.SetHelpFont( aFont ); 582 } 583 } 584 585 // use different height for toolfont 586 aFont = aStyleSettings.GetToolFont(); 587 aFont.SetHeight( toolfontheight ); 588 aStyleSettings.SetToolFont( aFont ); 589 590 aFont = aStyleSettings.GetLabelFont(); 591 aFont.SetHeight( defFontheight ); 592 aStyleSettings.SetLabelFont( aFont ); 593 aFont = aStyleSettings.GetInfoFont(); 594 aFont.SetHeight( defFontheight ); 595 aStyleSettings.SetInfoFont( aFont ); 596 aFont = aStyleSettings.GetRadioCheckFont(); 597 aFont.SetHeight( defFontheight ); 598 aStyleSettings.SetRadioCheckFont( aFont ); 599 aFont = aStyleSettings.GetPushButtonFont(); 600 aFont.SetHeight( defFontheight ); 601 aStyleSettings.SetPushButtonFont( aFont ); 602 aFont = aStyleSettings.GetFieldFont(); 603 aFont.SetHeight( defFontheight ); 604 aStyleSettings.SetFieldFont( aFont ); 605 aFont = aStyleSettings.GetIconFont(); 606 aFont.SetHeight( defFontheight ); 607 aStyleSettings.SetIconFont( aFont ); 608 aFont = aStyleSettings.GetGroupFont(); 609 aFont.SetHeight( defFontheight ); 610 aStyleSettings.SetGroupFont( aFont ); 611 612 // set workspace gradient to black in dark themes 613 if( aStyleSettings.GetWindowColor().IsDark() ) 614 aStyleSettings.SetWorkspaceGradient( Wallpaper( Color( COL_BLACK ) ) ); 615 else 616 { 617 Gradient aGrad( GRADIENT_LINEAR, DEFAULT_WORKSPACE_GRADIENT_START_COLOR, DEFAULT_WORKSPACE_GRADIENT_END_COLOR ); 618 aStyleSettings.SetWorkspaceGradient( Wallpaper( aGrad ) ); 619 } 620 621 rSettings.SetStyleSettings( aStyleSettings ); 622 623 624 // auto detect HC mode; if the system already set it to "yes" 625 // (see above) then accept that 626 if( !rSettings.GetStyleSettings().GetHighContrastMode() ) 627 { 628 sal_Bool bTmp = sal_False, bAutoHCMode = sal_True; 629 utl::OConfigurationNode aNode = utl::OConfigurationTreeRoot::tryCreateWithServiceFactory( 630 vcl::unohelper::GetMultiServiceFactory(), 631 OUString::createFromAscii( "org.openoffice.Office.Common/Accessibility" ) ); // note: case sensisitive ! 632 if ( aNode.isValid() ) 633 { 634 ::com::sun::star::uno::Any aValue = aNode.getNodeValue( OUString::createFromAscii( "AutoDetectSystemHC" ) ); 635 if( aValue >>= bTmp ) 636 bAutoHCMode = bTmp; 637 } 638 if( bAutoHCMode ) 639 { 640 if( rSettings.GetStyleSettings().GetFaceColor().IsDark() 641 || rSettings.GetStyleSettings().GetWindowColor().IsDark() ) 642 { 643 aStyleSettings = rSettings.GetStyleSettings(); 644 aStyleSettings.SetHighContrastMode( sal_True ); 645 rSettings.SetStyleSettings( aStyleSettings ); 646 } 647 } 648 } 649 650 static const char* pEnvHC = getenv( "SAL_FORCE_HC" ); 651 if( pEnvHC && *pEnvHC ) 652 { 653 aStyleSettings.SetHighContrastMode( sal_True ); 654 rSettings.SetStyleSettings( aStyleSettings ); 655 } 656 657 #ifdef DBG_UTIL 658 // Evt. AppFont auf Fett schalten, damit man feststellen kann, 659 // ob fuer die Texte auf anderen Systemen genuegend Platz 660 // vorhanden ist 661 if ( DbgIsBoldAppFont() ) 662 { 663 aStyleSettings = rSettings.GetStyleSettings(); 664 aFont = aStyleSettings.GetAppFont(); 665 aFont.SetWeight( WEIGHT_BOLD ); 666 aStyleSettings.SetAppFont( aFont ); 667 aFont = aStyleSettings.GetGroupFont(); 668 aFont.SetWeight( WEIGHT_BOLD ); 669 aStyleSettings.SetGroupFont( aFont ); 670 aFont = aStyleSettings.GetLabelFont(); 671 aFont.SetWeight( WEIGHT_BOLD ); 672 aStyleSettings.SetLabelFont( aFont ); 673 aFont = aStyleSettings.GetRadioCheckFont(); 674 aFont.SetWeight( WEIGHT_BOLD ); 675 aStyleSettings.SetRadioCheckFont( aFont ); 676 aFont = aStyleSettings.GetPushButtonFont(); 677 aFont.SetWeight( WEIGHT_BOLD ); 678 aStyleSettings.SetPushButtonFont( aFont ); 679 aFont = aStyleSettings.GetFieldFont(); 680 aFont.SetWeight( WEIGHT_BOLD ); 681 aStyleSettings.SetFieldFont( aFont ); 682 aFont = aStyleSettings.GetIconFont(); 683 aFont.SetWeight( WEIGHT_BOLD ); 684 aStyleSettings.SetIconFont( aFont ); 685 rSettings.SetStyleSettings( aStyleSettings ); 686 } 687 #endif 688 689 if ( bCallHdl ) 690 GetpApp()->SystemSettingsChanging( rSettings, this ); 691 } 692 693 // ----------------------------------------------------------------------- 694 695 MouseEvent ImplTranslateMouseEvent( const MouseEvent& rE, Window* pSource, Window* pDest ) 696 { 697 Point aPos = pSource->OutputToScreenPixel( rE.GetPosPixel() ); 698 aPos = pDest->ScreenToOutputPixel( aPos ); 699 return MouseEvent( aPos, rE.GetClicks(), rE.GetMode(), rE.GetButtons(), rE.GetModifier() ); 700 } 701 702 // ----------------------------------------------------------------------- 703 704 CommandEvent ImplTranslateCommandEvent( const CommandEvent& rCEvt, Window* pSource, Window* pDest ) 705 { 706 if ( !rCEvt.IsMouseEvent() ) 707 return rCEvt; 708 709 Point aPos = pSource->OutputToScreenPixel( rCEvt.GetMousePosPixel() ); 710 aPos = pDest->ScreenToOutputPixel( aPos ); 711 return CommandEvent( aPos, rCEvt.GetCommand(), rCEvt.IsMouseEvent(), rCEvt.GetData() ); 712 } 713 714 // ======================================================================= 715 716 void Window::ImplInitWindowData( WindowType nType ) 717 { 718 mpWindowImpl = new WindowImpl( nType ); 719 720 meOutDevType = OUTDEV_WINDOW; 721 722 mbEnableRTL = Application::GetSettings().GetLayoutRTL(); // sal_True: this outdev will be mirrored if RTL window layout (UI mirroring) is globally active 723 } 724 725 // ----------------------------------------------------------------------- 726 727 void Window::ImplInit( Window* pParent, WinBits nStyle, const ::com::sun::star::uno::Any& /*aSystemWorkWindowToken*/ ) 728 { 729 ImplInit( pParent, nStyle, NULL ); 730 } 731 732 // ----------------------------------------------------------------------- 733 734 void Window::ImplInit( Window* pParent, WinBits nStyle, SystemParentData* pSystemParentData ) 735 { 736 DBG_ASSERT( mpWindowImpl->mbFrame || pParent, "Window::Window(): pParent == NULL" ); 737 738 ImplSVData* pSVData = ImplGetSVData(); 739 Window* pRealParent = pParent; 740 741 // 3D-Look vererben 742 if ( !mpWindowImpl->mbOverlapWin && pParent && (pParent->GetStyle() & WB_3DLOOK) ) 743 nStyle |= WB_3DLOOK; 744 745 // create border window if necessary 746 if ( !mpWindowImpl->mbFrame && !mpWindowImpl->mbBorderWin && !mpWindowImpl->mpBorderWindow 747 && (nStyle & (WB_BORDER | WB_SYSTEMCHILDWINDOW) ) ) 748 { 749 sal_uInt16 nBorderTypeStyle = 0; 750 if( (nStyle & WB_SYSTEMCHILDWINDOW) ) 751 { 752 // handle WB_SYSTEMCHILDWINDOW 753 // these should be analogous to a top level frame; meaning they 754 // should have a border window with style BORDERWINDOW_STYLE_FRAME 755 // which controls their size 756 nBorderTypeStyle |= BORDERWINDOW_STYLE_FRAME; 757 nStyle |= WB_BORDER; 758 } 759 ImplBorderWindow* pBorderWin = new ImplBorderWindow( pParent, nStyle & (WB_BORDER | WB_DIALOGCONTROL | WB_NODIALOGCONTROL | WB_NEEDSFOCUS), nBorderTypeStyle ); 760 ((Window*)pBorderWin)->mpWindowImpl->mpClientWindow = this; 761 pBorderWin->GetBorder( mpWindowImpl->mnLeftBorder, mpWindowImpl->mnTopBorder, mpWindowImpl->mnRightBorder, mpWindowImpl->mnBottomBorder ); 762 mpWindowImpl->mpBorderWindow = pBorderWin; 763 pParent = mpWindowImpl->mpBorderWindow; 764 } 765 else if( !mpWindowImpl->mbFrame && ! pParent ) 766 { 767 mpWindowImpl->mbOverlapWin = sal_True; 768 mpWindowImpl->mbFrame = sal_True; 769 } 770 771 // insert window in list 772 ImplInsertWindow( pParent ); 773 mpWindowImpl->mnStyle = nStyle; 774 775 // Overlap-Window-Daten 776 if ( mpWindowImpl->mbOverlapWin ) 777 { 778 mpWindowImpl->mpOverlapData = new ImplOverlapData; 779 mpWindowImpl->mpOverlapData->mpSaveBackDev = NULL; 780 mpWindowImpl->mpOverlapData->mpSaveBackRgn = NULL; 781 mpWindowImpl->mpOverlapData->mpNextBackWin = NULL; 782 mpWindowImpl->mpOverlapData->mnSaveBackSize = 0; 783 mpWindowImpl->mpOverlapData->mbSaveBack = sal_False; 784 mpWindowImpl->mpOverlapData->mnTopLevel = 1; 785 } 786 787 if( pParent && ! mpWindowImpl->mbFrame ) 788 mbEnableRTL = pParent->mbEnableRTL; 789 790 // test for frame creation 791 if ( mpWindowImpl->mbFrame ) 792 { 793 // create frame 794 sal_uLong nFrameStyle = 0; 795 796 if ( nStyle & WB_MOVEABLE ) 797 nFrameStyle |= SAL_FRAME_STYLE_MOVEABLE; 798 if ( nStyle & WB_SIZEABLE ) 799 nFrameStyle |= SAL_FRAME_STYLE_SIZEABLE; 800 if ( nStyle & WB_CLOSEABLE ) 801 nFrameStyle |= SAL_FRAME_STYLE_CLOSEABLE; 802 if ( nStyle & WB_APP ) 803 nFrameStyle |= SAL_FRAME_STYLE_DEFAULT; 804 // check for undecorated floating window 805 if( // 1. floating windows that are not moveable/sizeable (only closeable allowed) 806 ( !(nFrameStyle & ~SAL_FRAME_STYLE_CLOSEABLE) && 807 ( mpWindowImpl->mbFloatWin || ((GetType() == WINDOW_BORDERWINDOW) && ((ImplBorderWindow*)this)->mbFloatWindow) || (nStyle & WB_SYSTEMFLOATWIN) ) ) || 808 // 2. borderwindows of floaters with ownerdraw decoration 809 ( ((GetType() == WINDOW_BORDERWINDOW) && ((ImplBorderWindow*)this)->mbFloatWindow && (nStyle & WB_OWNERDRAWDECORATION) ) ) ) 810 { 811 nFrameStyle = SAL_FRAME_STYLE_FLOAT; 812 if( nStyle & WB_OWNERDRAWDECORATION ) 813 nFrameStyle |= (SAL_FRAME_STYLE_OWNERDRAWDECORATION | SAL_FRAME_STYLE_NOSHADOW); 814 if( nStyle & WB_NEEDSFOCUS ) 815 nFrameStyle |= SAL_FRAME_STYLE_FLOAT_FOCUSABLE; 816 } 817 else if( mpWindowImpl->mbFloatWin ) 818 nFrameStyle |= SAL_FRAME_STYLE_TOOLWINDOW; 819 820 if( nStyle & WB_INTROWIN ) 821 nFrameStyle |= SAL_FRAME_STYLE_INTRO; 822 if( nStyle & WB_TOOLTIPWIN ) 823 nFrameStyle |= SAL_FRAME_STYLE_TOOLTIP; 824 825 if( nStyle & WB_NOSHADOW ) 826 nFrameStyle |= SAL_FRAME_STYLE_NOSHADOW; 827 828 if( nStyle & WB_SYSTEMCHILDWINDOW ) 829 nFrameStyle |= SAL_FRAME_STYLE_SYSTEMCHILD; 830 831 switch (mpWindowImpl->mnType) 832 { 833 case WINDOW_DIALOG: 834 case WINDOW_TABDIALOG: 835 case WINDOW_MODALDIALOG: 836 case WINDOW_MODELESSDIALOG: 837 case WINDOW_MESSBOX: 838 case WINDOW_INFOBOX: 839 case WINDOW_WARNINGBOX: 840 case WINDOW_ERRORBOX: 841 case WINDOW_QUERYBOX: 842 nFrameStyle |= SAL_FRAME_STYLE_DIALOG; 843 default: 844 break; 845 } 846 847 SalFrame* pParentFrame = NULL; 848 if ( pParent ) 849 pParentFrame = pParent->mpWindowImpl->mpFrame; 850 SalFrame* pFrame; 851 if ( pSystemParentData ) 852 pFrame = pSVData->mpDefInst->CreateChildFrame( pSystemParentData, nFrameStyle | SAL_FRAME_STYLE_PLUG ); 853 else 854 pFrame = pSVData->mpDefInst->CreateFrame( pParentFrame, nFrameStyle ); 855 if ( !pFrame ) 856 { 857 // do not abort but throw an exception, may be the current thread terminates anyway (plugin-scenario) 858 throw ::com::sun::star::uno::RuntimeException( 859 OUString( RTL_CONSTASCII_USTRINGPARAM( "Could not create system window!" ) ), 860 ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >() ); 861 //GetpApp()->Exception( EXC_SYSOBJNOTCREATED ); 862 } 863 864 pFrame->SetCallback( this, ImplWindowFrameProc ); 865 866 // set window frame data 867 mpWindowImpl->mpFrameData = new ImplFrameData; 868 mpWindowImpl->mpFrame = pFrame; 869 mpWindowImpl->mpFrameWindow = this; 870 mpWindowImpl->mpOverlapWindow = this; 871 872 // set frame data 873 mpWindowImpl->mpFrameData->mpNextFrame = pSVData->maWinData.mpFirstFrame; 874 pSVData->maWinData.mpFirstFrame = this; 875 mpWindowImpl->mpFrameData->mpFirstOverlap = NULL; 876 mpWindowImpl->mpFrameData->mpFocusWin = NULL; 877 mpWindowImpl->mpFrameData->mpMouseMoveWin = NULL; 878 mpWindowImpl->mpFrameData->mpMouseDownWin = NULL; 879 mpWindowImpl->mpFrameData->mpFirstBackWin = NULL; 880 mpWindowImpl->mpFrameData->mpFontList = pSVData->maGDIData.mpScreenFontList; 881 mpWindowImpl->mpFrameData->mpFontCache = pSVData->maGDIData.mpScreenFontCache; 882 mpWindowImpl->mpFrameData->mnAllSaveBackSize = 0; 883 mpWindowImpl->mpFrameData->mnFocusId = 0; 884 mpWindowImpl->mpFrameData->mnMouseMoveId = 0; 885 mpWindowImpl->mpFrameData->mnLastMouseX = -1; 886 mpWindowImpl->mpFrameData->mnLastMouseY = -1; 887 mpWindowImpl->mpFrameData->mnBeforeLastMouseX = -1; 888 mpWindowImpl->mpFrameData->mnBeforeLastMouseY = -1; 889 mpWindowImpl->mpFrameData->mnFirstMouseX = -1; 890 mpWindowImpl->mpFrameData->mnFirstMouseY = -1; 891 mpWindowImpl->mpFrameData->mnLastMouseWinX = -1; 892 mpWindowImpl->mpFrameData->mnLastMouseWinY = -1; 893 mpWindowImpl->mpFrameData->mnModalMode = 0; 894 mpWindowImpl->mpFrameData->mnMouseDownTime = 0; 895 mpWindowImpl->mpFrameData->mnClickCount = 0; 896 mpWindowImpl->mpFrameData->mnFirstMouseCode = 0; 897 mpWindowImpl->mpFrameData->mnMouseCode = 0; 898 mpWindowImpl->mpFrameData->mnMouseMode = 0; 899 mpWindowImpl->mpFrameData->meMapUnit = MAP_PIXEL; 900 mpWindowImpl->mpFrameData->mbHasFocus = sal_False; 901 mpWindowImpl->mpFrameData->mbInMouseMove = sal_False; 902 mpWindowImpl->mpFrameData->mbMouseIn = sal_False; 903 mpWindowImpl->mpFrameData->mbStartDragCalled = sal_False; 904 mpWindowImpl->mpFrameData->mbNeedSysWindow = sal_False; 905 mpWindowImpl->mpFrameData->mbMinimized = sal_False; 906 mpWindowImpl->mpFrameData->mbStartFocusState = sal_False; 907 mpWindowImpl->mpFrameData->mbInSysObjFocusHdl = sal_False; 908 mpWindowImpl->mpFrameData->mbInSysObjToTopHdl = sal_False; 909 mpWindowImpl->mpFrameData->mbSysObjFocus = sal_False; 910 mpWindowImpl->mpFrameData->maPaintTimer.SetTimeout( 30 ); 911 mpWindowImpl->mpFrameData->maPaintTimer.SetTimeoutHdl( LINK( this, Window, ImplHandlePaintHdl ) ); 912 mpWindowImpl->mpFrameData->maResizeTimer.SetTimeout( 50 ); 913 mpWindowImpl->mpFrameData->maResizeTimer.SetTimeoutHdl( LINK( this, Window, ImplHandleResizeTimerHdl ) ); 914 mpWindowImpl->mpFrameData->mbInternalDragGestureRecognizer = sal_False; 915 916 if ( pRealParent && IsTopWindow() ) 917 { 918 ImplWinData* pParentWinData = pRealParent->ImplGetWinData(); 919 pParentWinData->maTopWindowChildren.push_back( this ); 920 } 921 } 922 923 // init data 924 mpWindowImpl->mpRealParent = pRealParent; 925 926 // #99318: make sure fontcache and list is available before call to SetSettings 927 mpFontList = mpWindowImpl->mpFrameData->mpFontList; 928 mpFontCache = mpWindowImpl->mpFrameData->mpFontCache; 929 930 if ( mpWindowImpl->mbFrame ) 931 { 932 if ( pParent ) 933 { 934 mpWindowImpl->mpFrameData->mnDPIX = pParent->mpWindowImpl->mpFrameData->mnDPIX; 935 mpWindowImpl->mpFrameData->mnDPIY = pParent->mpWindowImpl->mpFrameData->mnDPIY; 936 } 937 else 938 { 939 if ( ImplGetGraphics() ) 940 { 941 mpGraphics->GetResolution( mpWindowImpl->mpFrameData->mnDPIX, mpWindowImpl->mpFrameData->mnDPIY ); 942 } 943 } 944 945 // add ownerdraw decorated frame windows to list in the top-most frame window 946 // so they can be hidden on lose focus 947 if( nStyle & WB_OWNERDRAWDECORATION ) 948 ImplGetOwnerDrawList().push_back( this ); 949 950 // delay settings initialization until first "real" frame 951 // this relies on the IntroWindow not needing any system settings 952 if ( !pSVData->maAppData.mbSettingsInit && 953 ! (nStyle & (WB_INTROWIN|WB_DEFAULTWIN)) 954 ) 955 { 956 // side effect: ImplUpdateGlobalSettings does an ImplGetFrame()->UpdateSettings 957 ImplUpdateGlobalSettings( *pSVData->maAppData.mpSettings ); 958 OutputDevice::SetSettings( *pSVData->maAppData.mpSettings ); 959 pSVData->maAppData.mbSettingsInit = sal_True; 960 } 961 962 // If we create a Window with default size, query this 963 // size directly, because we want resize all Controls to 964 // the correct size before we display the window 965 if ( nStyle & (WB_MOVEABLE | WB_SIZEABLE | WB_APP) ) 966 mpWindowImpl->mpFrame->GetClientSize( mnOutWidth, mnOutHeight ); 967 } 968 else 969 { 970 if ( pParent ) 971 { 972 if ( !ImplIsOverlapWindow() ) 973 { 974 mpWindowImpl->mbDisabled = pParent->mpWindowImpl->mbDisabled; 975 mpWindowImpl->mbInputDisabled = pParent->mpWindowImpl->mbInputDisabled; 976 mpWindowImpl->meAlwaysInputMode = pParent->mpWindowImpl->meAlwaysInputMode; 977 } 978 979 OutputDevice::SetSettings( pParent->GetSettings() ); 980 } 981 982 } 983 984 const StyleSettings& rStyleSettings = maSettings.GetStyleSettings(); 985 sal_uInt16 nScreenZoom = rStyleSettings.GetScreenZoom(); 986 mnDPIX = (mpWindowImpl->mpFrameData->mnDPIX*nScreenZoom)/100; 987 mnDPIY = (mpWindowImpl->mpFrameData->mnDPIY*nScreenZoom)/100; 988 maFont = rStyleSettings.GetAppFont(); 989 ImplPointToLogic( maFont ); 990 991 if ( nStyle & WB_3DLOOK ) 992 { 993 SetTextColor( rStyleSettings.GetButtonTextColor() ); 994 SetBackground( Wallpaper( rStyleSettings.GetFaceColor() ) ); 995 } 996 else 997 { 998 SetTextColor( rStyleSettings.GetWindowTextColor() ); 999 SetBackground( Wallpaper( rStyleSettings.GetWindowColor() ) ); 1000 } 1001 1002 ImplUpdatePos(); 1003 1004 // calculate app font res (except for the Intro Window or the default window) 1005 if ( mpWindowImpl->mbFrame && !pSVData->maGDIData.mnAppFontX && ! (nStyle & (WB_INTROWIN|WB_DEFAULTWIN)) ) 1006 ImplInitAppFontData( this ); 1007 1008 if ( GetAccessibleParentWindow() && GetParent() != Application::GetDefDialogParent() ) 1009 GetAccessibleParentWindow()->ImplCallEventListeners( VCLEVENT_WINDOW_CHILDCREATED, this ); 1010 } 1011 1012 // ----------------------------------------------------------------------- 1013 1014 void Window::ImplSetFrameParent( const Window* pParent ) 1015 { 1016 Window* pFrameWindow = ImplGetSVData()->maWinData.mpFirstFrame; 1017 while( pFrameWindow ) 1018 { 1019 // search all frames that are children of this window 1020 // and reparent them 1021 if( ImplIsRealParentPath( pFrameWindow ) ) 1022 { 1023 DBG_ASSERT( mpWindowImpl->mpFrame != pFrameWindow->mpWindowImpl->mpFrame, "SetFrameParent to own" ); 1024 DBG_ASSERT( mpWindowImpl->mpFrame, "no frame" ); 1025 SalFrame* pParentFrame = pParent ? pParent->mpWindowImpl->mpFrame : NULL; 1026 pFrameWindow->mpWindowImpl->mpFrame->SetParent( pParentFrame ); 1027 } 1028 pFrameWindow = pFrameWindow->mpWindowImpl->mpFrameData->mpNextFrame; 1029 } 1030 } 1031 1032 // ----------------------------------------------------------------------- 1033 1034 void Window::ImplInsertWindow( Window* pParent ) 1035 { 1036 mpWindowImpl->mpParent = pParent; 1037 mpWindowImpl->mpRealParent = pParent; 1038 1039 if ( pParent && !mpWindowImpl->mbFrame ) 1040 { 1041 // search frame window and set window frame data 1042 Window* pFrameParent = pParent->mpWindowImpl->mpFrameWindow; 1043 mpWindowImpl->mpFrameData = pFrameParent->mpWindowImpl->mpFrameData; 1044 mpWindowImpl->mpFrame = pFrameParent->mpWindowImpl->mpFrame; 1045 mpWindowImpl->mpFrameWindow = pFrameParent; 1046 mpWindowImpl->mbFrame = sal_False; 1047 1048 // search overlap window and insert window in list 1049 if ( ImplIsOverlapWindow() ) 1050 { 1051 Window* pFirstOverlapParent = pParent; 1052 while ( !pFirstOverlapParent->ImplIsOverlapWindow() ) 1053 pFirstOverlapParent = pFirstOverlapParent->ImplGetParent(); 1054 mpWindowImpl->mpOverlapWindow = pFirstOverlapParent; 1055 1056 mpWindowImpl->mpNextOverlap = mpWindowImpl->mpFrameData->mpFirstOverlap; 1057 mpWindowImpl->mpFrameData->mpFirstOverlap = this; 1058 1059 // Overlap-Windows sind per default die obersten 1060 mpWindowImpl->mpNext = pFirstOverlapParent->mpWindowImpl->mpFirstOverlap; 1061 pFirstOverlapParent->mpWindowImpl->mpFirstOverlap = this; 1062 if ( !pFirstOverlapParent->mpWindowImpl->mpLastOverlap ) 1063 pFirstOverlapParent->mpWindowImpl->mpLastOverlap = this; 1064 else 1065 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = this; 1066 } 1067 else 1068 { 1069 if ( pParent->ImplIsOverlapWindow() ) 1070 mpWindowImpl->mpOverlapWindow = pParent; 1071 else 1072 mpWindowImpl->mpOverlapWindow = pParent->mpWindowImpl->mpOverlapWindow; 1073 mpWindowImpl->mpPrev = pParent->mpWindowImpl->mpLastChild; 1074 pParent->mpWindowImpl->mpLastChild = this; 1075 if ( !pParent->mpWindowImpl->mpFirstChild ) 1076 pParent->mpWindowImpl->mpFirstChild = this; 1077 else 1078 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = this; 1079 } 1080 } 1081 } 1082 1083 // ----------------------------------------------------------------------- 1084 1085 void Window::ImplRemoveWindow( sal_Bool bRemoveFrameData ) 1086 { 1087 // Fenster aus den Listen austragen 1088 if ( !mpWindowImpl->mbFrame ) 1089 { 1090 if ( ImplIsOverlapWindow() ) 1091 { 1092 if ( mpWindowImpl->mpFrameData->mpFirstOverlap == this ) 1093 mpWindowImpl->mpFrameData->mpFirstOverlap = mpWindowImpl->mpNextOverlap; 1094 else 1095 { 1096 Window* pTempWin = mpWindowImpl->mpFrameData->mpFirstOverlap; 1097 while ( pTempWin->mpWindowImpl->mpNextOverlap != this ) 1098 pTempWin = pTempWin->mpWindowImpl->mpNextOverlap; 1099 pTempWin->mpWindowImpl->mpNextOverlap = mpWindowImpl->mpNextOverlap; 1100 } 1101 1102 if ( mpWindowImpl->mpPrev ) 1103 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = mpWindowImpl->mpNext; 1104 else 1105 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap = mpWindowImpl->mpNext; 1106 if ( mpWindowImpl->mpNext ) 1107 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = mpWindowImpl->mpPrev; 1108 else 1109 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpLastOverlap = mpWindowImpl->mpPrev; 1110 } 1111 else 1112 { 1113 if ( mpWindowImpl->mpPrev ) 1114 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = mpWindowImpl->mpNext; 1115 else 1116 mpWindowImpl->mpParent->mpWindowImpl->mpFirstChild = mpWindowImpl->mpNext; 1117 if ( mpWindowImpl->mpNext ) 1118 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = mpWindowImpl->mpPrev; 1119 else 1120 mpWindowImpl->mpParent->mpWindowImpl->mpLastChild = mpWindowImpl->mpPrev; 1121 } 1122 1123 mpWindowImpl->mpPrev = NULL; 1124 mpWindowImpl->mpNext = NULL; 1125 } 1126 1127 if ( bRemoveFrameData ) 1128 { 1129 // Graphic freigeben 1130 ImplReleaseGraphics(); 1131 } 1132 } 1133 1134 // ----------------------------------------------------------------------- 1135 1136 void Window::ImplCallResize() 1137 { 1138 mpWindowImpl->mbCallResize = sal_False; 1139 1140 if( GetBackground().IsGradient() ) 1141 Invalidate(); 1142 1143 Resize(); 1144 1145 // #88419# Most classes don't call the base class in Resize() and Move(), 1146 // => Call ImpleResize/Move instead of Resize/Move directly... 1147 ImplCallEventListeners( VCLEVENT_WINDOW_RESIZE ); 1148 1149 ImplExtResize(); 1150 } 1151 1152 // ----------------------------------------------------------------------- 1153 1154 void Window::ImplCallMove() 1155 { 1156 mpWindowImpl->mbCallMove = sal_False; 1157 1158 if( mpWindowImpl->mbFrame ) 1159 { 1160 // update frame position 1161 SalFrame *pParentFrame = NULL; 1162 Window *pParent = ImplGetParent(); 1163 while( pParent ) 1164 { 1165 if( pParent->mpWindowImpl->mpFrame != mpWindowImpl->mpFrame ) 1166 { 1167 pParentFrame = pParent->mpWindowImpl->mpFrame; 1168 break; 1169 } 1170 pParent = pParent->GetParent(); 1171 } 1172 1173 SalFrameGeometry g = mpWindowImpl->mpFrame->GetGeometry(); 1174 mpWindowImpl->maPos = Point( g.nX, g.nY ); 1175 if( pParentFrame ) 1176 { 1177 g = pParentFrame->GetGeometry(); 1178 mpWindowImpl->maPos -= Point( g.nX, g.nY ); 1179 } 1180 // the client window and and all its subclients have the same position as the borderframe 1181 // this is important for floating toolbars where the borderwindow is a floating window 1182 // which has another borderwindow (ie the system floating window) 1183 Window *pClientWin = mpWindowImpl->mpClientWindow; 1184 while( pClientWin ) 1185 { 1186 pClientWin->mpWindowImpl->maPos = mpWindowImpl->maPos; 1187 pClientWin = pClientWin->mpWindowImpl->mpClientWindow; 1188 } 1189 } 1190 1191 Move(); 1192 1193 ImplCallEventListeners( VCLEVENT_WINDOW_MOVE ); 1194 } 1195 1196 // ----------------------------------------------------------------------- 1197 1198 static rtl::OString ImplAutoHelpID( ResMgr* pResMgr ) 1199 { 1200 rtl::OString aRet; 1201 1202 if( pResMgr && Application::IsAutoHelpIdEnabled() ) 1203 aRet = pResMgr->GetAutoHelpId(); 1204 1205 return aRet; 1206 } 1207 1208 // ----------------------------------------------------------------------- 1209 1210 WinBits Window::ImplInitRes( const ResId& rResId ) 1211 { 1212 GetRes( rResId ); 1213 1214 char* pRes = (char*)GetClassRes(); 1215 pRes += 8; 1216 sal_uInt32 nStyle = (sal_uInt32)GetLongRes( (void*)pRes ); 1217 rResId.SetWinBits( nStyle ); 1218 return nStyle; 1219 } 1220 1221 // ----------------------------------------------------------------------- 1222 1223 void Window::ImplLoadRes( const ResId& rResId ) 1224 { 1225 sal_uLong nObjMask = ReadLongRes(); 1226 1227 // we need to calculate auto helpids before the resource gets closed 1228 // if the resource only contains flags, it will be closed before we try to read a help id 1229 // so we always create an auto help id that might be overwritten later 1230 // HelpId 1231 rtl::OString aHelpId = ImplAutoHelpID( rResId.GetResMgr() ); 1232 1233 // ResourceStyle 1234 sal_uLong nRSStyle = ReadLongRes(); 1235 // WinBits 1236 ReadLongRes(); 1237 1238 if( nObjMask & WINDOW_HELPID ) 1239 aHelpId = ReadByteStringRes(); 1240 1241 SetHelpId( aHelpId ); 1242 1243 sal_Bool bPos = sal_False; 1244 sal_Bool bSize = sal_False; 1245 Point aPos; 1246 Size aSize; 1247 1248 if ( nObjMask & (WINDOW_XYMAPMODE | WINDOW_X | WINDOW_Y) ) 1249 { 1250 // Groessenangabe aus der Resource verwenden 1251 MapUnit ePosMap = MAP_PIXEL; 1252 1253 bPos = sal_True; 1254 1255 if ( nObjMask & WINDOW_XYMAPMODE ) 1256 ePosMap = (MapUnit)ReadLongRes(); 1257 if ( nObjMask & WINDOW_X ) 1258 aPos.X() = ImplLogicUnitToPixelX( ReadLongRes(), ePosMap ); 1259 if ( nObjMask & WINDOW_Y ) 1260 aPos.Y() = ImplLogicUnitToPixelY( ReadLongRes(), ePosMap ); 1261 } 1262 1263 if ( nObjMask & (WINDOW_WHMAPMODE | WINDOW_WIDTH | WINDOW_HEIGHT) ) 1264 { 1265 // Groessenangabe aus der Resource verwenden 1266 MapUnit eSizeMap = MAP_PIXEL; 1267 1268 bSize = sal_True; 1269 1270 if ( nObjMask & WINDOW_WHMAPMODE ) 1271 eSizeMap = (MapUnit)ReadLongRes(); 1272 if ( nObjMask & WINDOW_WIDTH ) 1273 aSize.Width() = ImplLogicUnitToPixelX( ReadLongRes(), eSizeMap ); 1274 if ( nObjMask & WINDOW_HEIGHT ) 1275 aSize.Height() = ImplLogicUnitToPixelY( ReadLongRes(), eSizeMap ); 1276 } 1277 1278 // Wegen Optimierung so schlimm aussehend 1279 if ( nRSStyle & RSWND_CLIENTSIZE ) 1280 { 1281 if ( bPos ) 1282 SetPosPixel( aPos ); 1283 if ( bSize ) 1284 SetOutputSizePixel( aSize ); 1285 } 1286 else if ( bPos && bSize ) 1287 SetPosSizePixel( aPos, aSize ); 1288 else if ( bPos ) 1289 SetPosPixel( aPos ); 1290 else if ( bSize ) 1291 SetSizePixel( aSize ); 1292 1293 if ( nRSStyle & RSWND_DISABLED ) 1294 Enable( sal_False ); 1295 1296 if ( nObjMask & WINDOW_TEXT ) 1297 SetText( ReadStringRes() ); 1298 if ( nObjMask & WINDOW_HELPTEXT ) 1299 { 1300 SetHelpText( ReadStringRes() ); 1301 mpWindowImpl->mbHelpTextDynamic = sal_True; 1302 } 1303 if ( nObjMask & WINDOW_QUICKTEXT ) 1304 SetQuickHelpText( ReadStringRes() ); 1305 if ( nObjMask & WINDOW_EXTRALONG ) 1306 SetData( (void*)ReadLongRes() ); 1307 if ( nObjMask & WINDOW_UNIQUEID ) 1308 SetUniqueId( ReadByteStringRes() ); 1309 1310 if ( nObjMask & WINDOW_BORDER_STYLE ) 1311 { 1312 sal_uInt16 nBorderStyle = (sal_uInt16)ReadLongRes(); 1313 SetBorderStyle( nBorderStyle ); 1314 } 1315 } 1316 1317 // ----------------------------------------------------------------------- 1318 1319 ImplWinData* Window::ImplGetWinData() const 1320 { 1321 if ( !mpWindowImpl->mpWinData ) 1322 { 1323 static const char* pNoNWF = getenv( "SAL_NO_NWF" ); 1324 1325 ((Window*)this)->mpWindowImpl->mpWinData = new ImplWinData; 1326 mpWindowImpl->mpWinData->mpExtOldText = NULL; 1327 mpWindowImpl->mpWinData->mpExtOldAttrAry = NULL; 1328 mpWindowImpl->mpWinData->mpCursorRect = 0; 1329 mpWindowImpl->mpWinData->mnCursorExtWidth = 0; 1330 mpWindowImpl->mpWinData->mpFocusRect = NULL; 1331 mpWindowImpl->mpWinData->mpTrackRect = NULL; 1332 mpWindowImpl->mpWinData->mnTrackFlags = 0; 1333 mpWindowImpl->mpWinData->mnIsTopWindow = (sal_uInt16) ~0; // not initialized yet, 0/1 will indicate TopWindow (see IsTopWindow()) 1334 mpWindowImpl->mpWinData->mbMouseOver = sal_False; 1335 mpWindowImpl->mpWinData->mbEnableNativeWidget = (pNoNWF && *pNoNWF) ? sal_False : sal_True; // sal_True: try to draw this control with native theme API 1336 } 1337 1338 return mpWindowImpl->mpWinData; 1339 } 1340 1341 // ----------------------------------------------------------------------- 1342 1343 SalGraphics* Window::ImplGetFrameGraphics() const 1344 { 1345 if ( mpWindowImpl->mpFrameWindow->mpGraphics ) 1346 mpWindowImpl->mpFrameWindow->mbInitClipRegion = sal_True; 1347 else 1348 mpWindowImpl->mpFrameWindow->ImplGetGraphics(); 1349 mpWindowImpl->mpFrameWindow->mpGraphics->ResetClipRegion(); 1350 return mpWindowImpl->mpFrameWindow->mpGraphics; 1351 } 1352 1353 // ----------------------------------------------------------------------- 1354 1355 Window* Window::ImplFindWindow( const Point& rFramePos ) 1356 { 1357 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 1358 1359 Window* pTempWindow; 1360 Window* pFindWindow; 1361 1362 // Zuerst alle ueberlappenden Fenster ueberpruefen 1363 pTempWindow = mpWindowImpl->mpFirstOverlap; 1364 while ( pTempWindow ) 1365 { 1366 pFindWindow = pTempWindow->ImplFindWindow( rFramePos ); 1367 if ( pFindWindow ) 1368 return pFindWindow; 1369 pTempWindow = pTempWindow->mpWindowImpl->mpNext; 1370 } 1371 1372 // dann testen wir unser Fenster 1373 if ( !mpWindowImpl->mbVisible ) 1374 return NULL; 1375 1376 sal_uInt16 nHitTest = ImplHitTest( rFramePos ); 1377 if ( nHitTest & WINDOW_HITTEST_INSIDE ) 1378 { 1379 // und danach gehen wir noch alle Child-Fenster durch 1380 pTempWindow = mpWindowImpl->mpFirstChild; 1381 while ( pTempWindow ) 1382 { 1383 pFindWindow = pTempWindow->ImplFindWindow( rFramePos ); 1384 if ( pFindWindow ) 1385 return pFindWindow; 1386 pTempWindow = pTempWindow->mpWindowImpl->mpNext; 1387 } 1388 1389 if ( nHitTest & WINDOW_HITTEST_TRANSPARENT ) 1390 return NULL; 1391 else 1392 return this; 1393 } 1394 1395 return NULL; 1396 } 1397 1398 // ----------------------------------------------------------------------- 1399 1400 sal_uInt16 Window::ImplHitTest( const Point& rFramePos ) 1401 { 1402 Point aFramePos( rFramePos ); 1403 if( ImplIsAntiparallel() ) 1404 { 1405 // - RTL - re-mirror frame pos at this window 1406 ImplReMirror( aFramePos ); 1407 } 1408 Rectangle aRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 1409 if ( !aRect.IsInside( aFramePos ) ) 1410 return 0; 1411 if ( mpWindowImpl->mbWinRegion ) 1412 { 1413 Point aTempPos = aFramePos; 1414 aTempPos.X() -= mnOutOffX; 1415 aTempPos.Y() -= mnOutOffY; 1416 if ( !mpWindowImpl->maWinRegion.IsInside( aTempPos ) ) 1417 return 0; 1418 } 1419 1420 sal_uInt16 nHitTest = WINDOW_HITTEST_INSIDE; 1421 if ( mpWindowImpl->mbMouseTransparent ) 1422 nHitTest |= WINDOW_HITTEST_TRANSPARENT; 1423 return nHitTest; 1424 } 1425 1426 // ----------------------------------------------------------------------- 1427 1428 sal_Bool Window::ImplIsRealParentPath( const Window* pWindow ) const 1429 { 1430 pWindow = pWindow->GetParent(); 1431 while ( pWindow ) 1432 { 1433 if ( pWindow == this ) 1434 return sal_True; 1435 pWindow = pWindow->GetParent(); 1436 } 1437 1438 return sal_False; 1439 } 1440 1441 // ----------------------------------------------------------------------- 1442 1443 sal_Bool Window::ImplIsChild( const Window* pWindow, sal_Bool bSystemWindow ) const 1444 { 1445 do 1446 { 1447 if ( !bSystemWindow && pWindow->ImplIsOverlapWindow() ) 1448 break; 1449 1450 pWindow = pWindow->ImplGetParent(); 1451 1452 if ( pWindow == this ) 1453 return sal_True; 1454 } 1455 while ( pWindow ); 1456 1457 return sal_False; 1458 } 1459 1460 // ----------------------------------------------------------------------- 1461 1462 sal_Bool Window::ImplIsWindowOrChild( const Window* pWindow, sal_Bool bSystemWindow ) const 1463 { 1464 if ( this == pWindow ) 1465 return sal_True; 1466 return ImplIsChild( pWindow, bSystemWindow ); 1467 } 1468 1469 // ----------------------------------------------------------------------- 1470 1471 Window* Window::ImplGetSameParent( const Window* pWindow ) const 1472 { 1473 if ( mpWindowImpl->mpFrameWindow != pWindow->mpWindowImpl->mpFrameWindow ) 1474 return NULL; 1475 else 1476 { 1477 if ( pWindow->ImplIsChild( this ) ) 1478 return (Window*)pWindow; 1479 else 1480 { 1481 Window* pTestWindow = (Window*)this; 1482 while ( (pTestWindow == pWindow) || pTestWindow->ImplIsChild( pWindow ) ) 1483 pTestWindow = pTestWindow->ImplGetParent(); 1484 return pTestWindow; 1485 } 1486 } 1487 } 1488 1489 // ----------------------------------------------------------------------- 1490 1491 int Window::ImplTestMousePointerSet() 1492 { 1493 // Wenn Mouse gecaptured ist, dann soll MousePointer umgeschaltet werden 1494 if ( IsMouseCaptured() ) 1495 return sal_True; 1496 1497 // Wenn sich Mouse ueber dem Fenster befindet, dann soll MousePointer 1498 // umgeschaltet werden 1499 Rectangle aClientRect( Point( 0, 0 ), GetOutputSizePixel() ); 1500 if ( aClientRect.IsInside( GetPointerPosPixel() ) ) 1501 return sal_True; 1502 1503 return sal_False; 1504 } 1505 1506 // ----------------------------------------------------------------------- 1507 1508 PointerStyle Window::ImplGetMousePointer() const 1509 { 1510 PointerStyle ePointerStyle; 1511 sal_Bool bWait = sal_False; 1512 1513 if ( IsEnabled() && IsInputEnabled() && ! IsInModalMode() ) 1514 ePointerStyle = GetPointer().GetStyle(); 1515 else 1516 ePointerStyle = POINTER_ARROW; 1517 1518 const Window* pWindow = this; 1519 do 1520 { 1521 // Wenn Pointer nicht sichtbar, dann wird suche abgebrochen, da 1522 // dieser Status nicht ueberschrieben werden darf 1523 if ( pWindow->mpWindowImpl->mbNoPtrVisible ) 1524 return POINTER_NULL; 1525 1526 if ( !bWait ) 1527 { 1528 if ( pWindow->mpWindowImpl->mnWaitCount ) 1529 { 1530 ePointerStyle = POINTER_WAIT; 1531 bWait = sal_True; 1532 } 1533 else 1534 { 1535 if ( pWindow->mpWindowImpl->mbChildPtrOverwrite ) 1536 ePointerStyle = pWindow->GetPointer().GetStyle(); 1537 } 1538 } 1539 1540 if ( pWindow->ImplIsOverlapWindow() ) 1541 break; 1542 1543 pWindow = pWindow->ImplGetParent(); 1544 } 1545 while ( pWindow ); 1546 1547 return ePointerStyle; 1548 } 1549 1550 // ----------------------------------------------------------------------- 1551 1552 void Window::ImplResetReallyVisible() 1553 { 1554 sal_Bool bBecameReallyInvisible = mpWindowImpl->mbReallyVisible; 1555 1556 mbDevOutput = sal_False; 1557 mpWindowImpl->mbReallyVisible = sal_False; 1558 mpWindowImpl->mbReallyShown = sal_False; 1559 1560 // the SHOW/HIDE events serve as indicators to send child creation/destroy events to the access bridge. 1561 // For this, the data member of the event must not be NULL. 1562 // Previously, we did this in Window::Show, but there some events got lost in certain situations. 1563 // #104887# - 2004-08-10 - fs@openoffice.org 1564 if( bBecameReallyInvisible && ImplIsAccessibleCandidate() ) 1565 ImplCallEventListeners( VCLEVENT_WINDOW_HIDE, this ); 1566 // TODO. It's kind of a hack that we're re-using the VCLEVENT_WINDOW_HIDE. Normally, we should 1567 // introduce another event which explicitly triggers the Accessibility implementations. 1568 1569 Window* pWindow = mpWindowImpl->mpFirstOverlap; 1570 while ( pWindow ) 1571 { 1572 if ( pWindow->mpWindowImpl->mbReallyVisible ) 1573 pWindow->ImplResetReallyVisible(); 1574 pWindow = pWindow->mpWindowImpl->mpNext; 1575 } 1576 1577 pWindow = mpWindowImpl->mpFirstChild; 1578 while ( pWindow ) 1579 { 1580 if ( pWindow->mpWindowImpl->mbReallyVisible ) 1581 pWindow->ImplResetReallyVisible(); 1582 pWindow = pWindow->mpWindowImpl->mpNext; 1583 } 1584 } 1585 1586 // ----------------------------------------------------------------------- 1587 1588 void Window::ImplSetReallyVisible() 1589 { 1590 // #i43594# it is possible that INITSHOW was never send, because the visibility state changed between 1591 // ImplCallInitShow() and ImplSetReallyVisible() when called from Show() 1592 // mbReallyShown is a useful indicator 1593 if( !mpWindowImpl->mbReallyShown ) 1594 ImplCallInitShow(); 1595 1596 sal_Bool bBecameReallyVisible = !mpWindowImpl->mbReallyVisible; 1597 1598 mbDevOutput = sal_True; 1599 mpWindowImpl->mbReallyVisible = sal_True; 1600 mpWindowImpl->mbReallyShown = sal_True; 1601 1602 // the SHOW/HIDE events serve as indicators to send child creation/destroy events to the access bridge. 1603 // For this, the data member of the event must not be NULL. 1604 // Previously, we did this in Window::Show, but there some events got lost in certain situations. Now 1605 // we're doing it when the visibility really changes 1606 // #104887# - 2004-08-10 - fs@openoffice.org 1607 if( bBecameReallyVisible && ImplIsAccessibleCandidate() ) 1608 ImplCallEventListeners( VCLEVENT_WINDOW_SHOW, this ); 1609 // TODO. It's kind of a hack that we're re-using the VCLEVENT_WINDOW_SHOW. Normally, we should 1610 // introduce another event which explicitly triggers the Accessibility implementations. 1611 1612 Window* pWindow = mpWindowImpl->mpFirstOverlap; 1613 while ( pWindow ) 1614 { 1615 if ( pWindow->mpWindowImpl->mbVisible ) 1616 pWindow->ImplSetReallyVisible(); 1617 pWindow = pWindow->mpWindowImpl->mpNext; 1618 } 1619 1620 pWindow = mpWindowImpl->mpFirstChild; 1621 while ( pWindow ) 1622 { 1623 if ( pWindow->mpWindowImpl->mbVisible ) 1624 pWindow->ImplSetReallyVisible(); 1625 pWindow = pWindow->mpWindowImpl->mpNext; 1626 } 1627 } 1628 1629 // ----------------------------------------------------------------------- 1630 1631 void Window::ImplCallInitShow() 1632 { 1633 mpWindowImpl->mbReallyShown = sal_True; 1634 mpWindowImpl->mbInInitShow = sal_True; 1635 StateChanged( STATE_CHANGE_INITSHOW ); 1636 mpWindowImpl->mbInInitShow = sal_False; 1637 1638 Window* pWindow = mpWindowImpl->mpFirstOverlap; 1639 while ( pWindow ) 1640 { 1641 if ( pWindow->mpWindowImpl->mbVisible ) 1642 pWindow->ImplCallInitShow(); 1643 pWindow = pWindow->mpWindowImpl->mpNext; 1644 } 1645 1646 pWindow = mpWindowImpl->mpFirstChild; 1647 while ( pWindow ) 1648 { 1649 if ( pWindow->mpWindowImpl->mbVisible ) 1650 pWindow->ImplCallInitShow(); 1651 pWindow = pWindow->mpWindowImpl->mpNext; 1652 } 1653 } 1654 1655 // ----------------------------------------------------------------------- 1656 1657 void Window::ImplAddDel( ImplDelData* pDel ) // TODO: make "const" when incompatiblity ok 1658 { 1659 DBG_ASSERT( !pDel->mpWindow, "Window::ImplAddDel(): cannot add ImplDelData twice !" ); 1660 if( !pDel->mpWindow ) 1661 { 1662 pDel->mpWindow = this; // #112873# store ref to this window, so pDel can remove itself 1663 pDel->mpNext = mpWindowImpl->mpFirstDel; 1664 mpWindowImpl->mpFirstDel = pDel; 1665 } 1666 } 1667 1668 // ----------------------------------------------------------------------- 1669 1670 void Window::ImplRemoveDel( ImplDelData* pDel ) // TODO: make "const" when incompatiblity ok 1671 { 1672 pDel->mpWindow = NULL; // #112873# pDel is not associated with a Window anymore 1673 if ( mpWindowImpl->mpFirstDel == pDel ) 1674 mpWindowImpl->mpFirstDel = pDel->mpNext; 1675 else 1676 { 1677 ImplDelData* pData = mpWindowImpl->mpFirstDel; 1678 while ( pData->mpNext != pDel ) 1679 pData = pData->mpNext; 1680 pData->mpNext = pDel->mpNext; 1681 } 1682 } 1683 1684 // ----------------------------------------------------------------------- 1685 1686 void Window::ImplInitResolutionSettings() 1687 { 1688 // AppFont-Aufloesung und DPI-Aufloesung neu berechnen 1689 if ( mpWindowImpl->mbFrame ) 1690 { 1691 const StyleSettings& rStyleSettings = maSettings.GetStyleSettings(); 1692 sal_uInt16 nScreenZoom = rStyleSettings.GetScreenZoom(); 1693 mnDPIX = (mpWindowImpl->mpFrameData->mnDPIX*nScreenZoom)/100; 1694 mnDPIY = (mpWindowImpl->mpFrameData->mnDPIY*nScreenZoom)/100; 1695 SetPointFont( rStyleSettings.GetAppFont() ); 1696 } 1697 else if ( mpWindowImpl->mpParent ) 1698 { 1699 mnDPIX = mpWindowImpl->mpParent->mnDPIX; 1700 mnDPIY = mpWindowImpl->mpParent->mnDPIY; 1701 } 1702 1703 // Vorberechnete Werte fuer logische Einheiten updaten und auch 1704 // die entsprechenden Tools dazu 1705 if ( IsMapMode() ) 1706 { 1707 MapMode aMapMode = GetMapMode(); 1708 SetMapMode(); 1709 SetMapMode( aMapMode ); 1710 } 1711 } 1712 1713 // ----------------------------------------------------------------------- 1714 1715 void Window::ImplPointToLogic( Font& rFont ) const 1716 { 1717 Size aSize = rFont.GetSize(); 1718 sal_uInt16 nScreenFontZoom = maSettings.GetStyleSettings().GetScreenFontZoom(); 1719 1720 if ( aSize.Width() ) 1721 { 1722 aSize.Width() *= mpWindowImpl->mpFrameData->mnDPIX; 1723 aSize.Width() += 72/2; 1724 aSize.Width() /= 72; 1725 aSize.Width() *= nScreenFontZoom; 1726 aSize.Width() /= 100; 1727 } 1728 aSize.Height() *= mpWindowImpl->mpFrameData->mnDPIY; 1729 aSize.Height() += 72/2; 1730 aSize.Height() /= 72; 1731 aSize.Height() *= nScreenFontZoom; 1732 aSize.Height() /= 100; 1733 1734 if ( IsMapModeEnabled() ) 1735 aSize = PixelToLogic( aSize ); 1736 1737 rFont.SetSize( aSize ); 1738 } 1739 1740 // ----------------------------------------------------------------------- 1741 1742 void Window::ImplLogicToPoint( Font& rFont ) const 1743 { 1744 Size aSize = rFont.GetSize(); 1745 sal_uInt16 nScreenFontZoom = maSettings.GetStyleSettings().GetScreenFontZoom(); 1746 1747 if ( IsMapModeEnabled() ) 1748 aSize = LogicToPixel( aSize ); 1749 1750 if ( aSize.Width() ) 1751 { 1752 aSize.Width() *= 100; 1753 aSize.Width() /= nScreenFontZoom; 1754 aSize.Width() *= 72; 1755 aSize.Width() += mpWindowImpl->mpFrameData->mnDPIX/2; 1756 aSize.Width() /= mpWindowImpl->mpFrameData->mnDPIX; 1757 } 1758 aSize.Height() *= 100; 1759 aSize.Height() /= nScreenFontZoom; 1760 aSize.Height() *= 72; 1761 aSize.Height() += mpWindowImpl->mpFrameData->mnDPIY/2; 1762 aSize.Height() /= mpWindowImpl->mpFrameData->mnDPIY; 1763 1764 rFont.SetSize( aSize ); 1765 } 1766 1767 // ----------------------------------------------------------------------- 1768 1769 sal_Bool Window::ImplSysObjClip( const Region* pOldRegion ) 1770 { 1771 sal_Bool bUpdate = sal_True; 1772 1773 if ( mpWindowImpl->mpSysObj ) 1774 { 1775 sal_Bool bVisibleState = mpWindowImpl->mbReallyVisible; 1776 1777 if ( bVisibleState ) 1778 { 1779 Region* pWinChildClipRegion = ImplGetWinChildClipRegion(); 1780 1781 if ( !pWinChildClipRegion->IsEmpty() ) 1782 { 1783 if ( pOldRegion ) 1784 { 1785 Region aNewRegion = *pWinChildClipRegion; 1786 pWinChildClipRegion->Intersect( *pOldRegion ); 1787 bUpdate = aNewRegion == *pWinChildClipRegion; 1788 } 1789 1790 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 1791 ImplInvalidateAllOverlapBackgrounds(); 1792 1793 Region aRegion = *pWinChildClipRegion; 1794 Rectangle aWinRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 1795 Region aWinRectRegion( aWinRect ); 1796 sal_uInt16 nClipFlags = mpWindowImpl->mpSysObj->GetClipRegionType(); 1797 1798 if ( aRegion == aWinRectRegion ) 1799 mpWindowImpl->mpSysObj->ResetClipRegion(); 1800 else 1801 { 1802 if ( nClipFlags & SAL_OBJECT_CLIP_EXCLUDERECTS ) 1803 { 1804 aWinRectRegion.Exclude( aRegion ); 1805 aRegion = aWinRectRegion; 1806 } 1807 if ( !(nClipFlags & SAL_OBJECT_CLIP_ABSOLUTE) ) 1808 aRegion.Move( -mnOutOffX, -mnOutOffY ); 1809 1810 // ClipRegion setzen/updaten 1811 RectangleVector aRectangles; 1812 aRegion.GetRegionRectangles(aRectangles); 1813 mpWindowImpl->mpSysObj->BeginSetClipRegion(aRectangles.size()); 1814 1815 for(RectangleVector::const_iterator aRectIter(aRectangles.begin()); aRectIter != aRectangles.end(); aRectIter++) 1816 { 1817 mpWindowImpl->mpSysObj->UnionClipRegion( 1818 aRectIter->Left(), 1819 aRectIter->Top(), 1820 aRectIter->GetWidth(), // orig nWidth was ((R - L) + 1), same as GetWidth does 1821 aRectIter->GetHeight()); // same for height 1822 } 1823 1824 mpWindowImpl->mpSysObj->EndSetClipRegion(); 1825 1826 //long nX; 1827 //long nY; 1828 //long nWidth; 1829 //long nHeight; 1830 //sal_uLong nRectCount; 1831 //ImplRegionInfo aInfo; 1832 //sal_Bool bRegionRect; 1833 // 1834 //nRectCount = aRegion.GetRectCount(); 1835 //mpWindowImpl->mpSysObj->BeginSetClipRegion( nRectCount ); 1836 //bRegionRect = aRegion.ImplGetFirstRect( aInfo, nX, nY, nWidth, nHeight ); 1837 //while ( bRegionRect ) 1838 //{ 1839 // mpWindowImpl->mpSysObj->UnionClipRegion( nX, nY, nWidth, nHeight ); 1840 // bRegionRect = aRegion.ImplGetNextRect( aInfo, nX, nY, nWidth, nHeight ); 1841 //} 1842 //mpWindowImpl->mpSysObj->EndSetClipRegion(); 1843 } 1844 } 1845 else 1846 bVisibleState = sal_False; 1847 } 1848 1849 // Visible-Status updaten 1850 mpWindowImpl->mpSysObj->Show( bVisibleState ); 1851 } 1852 1853 return bUpdate; 1854 } 1855 1856 // ----------------------------------------------------------------------- 1857 1858 void Window::ImplUpdateSysObjChildsClip() 1859 { 1860 if ( mpWindowImpl->mpSysObj && mpWindowImpl->mbInitWinClipRegion ) 1861 ImplSysObjClip( NULL ); 1862 1863 Window* pWindow = mpWindowImpl->mpFirstChild; 1864 while ( pWindow ) 1865 { 1866 pWindow->ImplUpdateSysObjChildsClip(); 1867 pWindow = pWindow->mpWindowImpl->mpNext; 1868 } 1869 } 1870 1871 // ----------------------------------------------------------------------- 1872 1873 void Window::ImplUpdateSysObjOverlapsClip() 1874 { 1875 ImplUpdateSysObjChildsClip(); 1876 1877 Window* pWindow = mpWindowImpl->mpFirstOverlap; 1878 while ( pWindow ) 1879 { 1880 pWindow->ImplUpdateSysObjOverlapsClip(); 1881 pWindow = pWindow->mpWindowImpl->mpNext; 1882 } 1883 } 1884 1885 // ----------------------------------------------------------------------- 1886 1887 void Window::ImplUpdateSysObjClip() 1888 { 1889 if ( !ImplIsOverlapWindow() ) 1890 { 1891 ImplUpdateSysObjChildsClip(); 1892 1893 // Schwestern muessen ihre ClipRegion auch neu berechnen 1894 if ( mpWindowImpl->mbClipSiblings ) 1895 { 1896 Window* pWindow = mpWindowImpl->mpNext; 1897 while ( pWindow ) 1898 { 1899 pWindow->ImplUpdateSysObjChildsClip(); 1900 pWindow = pWindow->mpWindowImpl->mpNext; 1901 } 1902 } 1903 } 1904 else 1905 mpWindowImpl->mpFrameWindow->ImplUpdateSysObjOverlapsClip(); 1906 } 1907 1908 // ----------------------------------------------------------------------- 1909 1910 sal_Bool Window::ImplSetClipFlagChilds( sal_Bool bSysObjOnlySmaller ) 1911 { 1912 sal_Bool bUpdate = sal_True; 1913 if ( mpWindowImpl->mpSysObj ) 1914 { 1915 Region* pOldRegion = NULL; 1916 if ( bSysObjOnlySmaller && !mpWindowImpl->mbInitWinClipRegion ) 1917 pOldRegion = new Region( mpWindowImpl->maWinClipRegion ); 1918 1919 mbInitClipRegion = sal_True; 1920 mpWindowImpl->mbInitWinClipRegion = sal_True; 1921 1922 Window* pWindow = mpWindowImpl->mpFirstChild; 1923 while ( pWindow ) 1924 { 1925 if ( !pWindow->ImplSetClipFlagChilds( bSysObjOnlySmaller ) ) 1926 bUpdate = sal_False; 1927 pWindow = pWindow->mpWindowImpl->mpNext; 1928 } 1929 1930 if ( !ImplSysObjClip( pOldRegion ) ) 1931 { 1932 mbInitClipRegion = sal_True; 1933 mpWindowImpl->mbInitWinClipRegion = sal_True; 1934 bUpdate = sal_False; 1935 } 1936 1937 if ( pOldRegion ) 1938 delete pOldRegion; 1939 } 1940 else 1941 { 1942 mbInitClipRegion = sal_True; 1943 mpWindowImpl->mbInitWinClipRegion = sal_True; 1944 1945 Window* pWindow = mpWindowImpl->mpFirstChild; 1946 while ( pWindow ) 1947 { 1948 if ( !pWindow->ImplSetClipFlagChilds( bSysObjOnlySmaller ) ) 1949 bUpdate = sal_False; 1950 pWindow = pWindow->mpWindowImpl->mpNext; 1951 } 1952 } 1953 return bUpdate; 1954 } 1955 1956 // ----------------------------------------------------------------------- 1957 1958 sal_Bool Window::ImplSetClipFlagOverlapWindows( sal_Bool bSysObjOnlySmaller ) 1959 { 1960 sal_Bool bUpdate = ImplSetClipFlagChilds( bSysObjOnlySmaller ); 1961 1962 Window* pWindow = mpWindowImpl->mpFirstOverlap; 1963 while ( pWindow ) 1964 { 1965 if ( !pWindow->ImplSetClipFlagOverlapWindows( bSysObjOnlySmaller ) ) 1966 bUpdate = sal_False; 1967 pWindow = pWindow->mpWindowImpl->mpNext; 1968 } 1969 1970 return bUpdate; 1971 } 1972 1973 // ----------------------------------------------------------------------- 1974 1975 sal_Bool Window::ImplSetClipFlag( sal_Bool bSysObjOnlySmaller ) 1976 { 1977 if ( !ImplIsOverlapWindow() ) 1978 { 1979 sal_Bool bUpdate = ImplSetClipFlagChilds( bSysObjOnlySmaller ); 1980 1981 Window* pParent = ImplGetParent(); 1982 if ( pParent && 1983 ((pParent->GetStyle() & WB_CLIPCHILDREN) || (mpWindowImpl->mnParentClipMode & PARENTCLIPMODE_CLIP)) ) 1984 { 1985 pParent->mbInitClipRegion = sal_True; 1986 pParent->mpWindowImpl->mbInitChildRegion = sal_True; 1987 } 1988 1989 // Schwestern muessen ihre ClipRegion auch neu berechnen 1990 if ( mpWindowImpl->mbClipSiblings ) 1991 { 1992 Window* pWindow = mpWindowImpl->mpNext; 1993 while ( pWindow ) 1994 { 1995 if ( !pWindow->ImplSetClipFlagChilds( bSysObjOnlySmaller ) ) 1996 bUpdate = sal_False; 1997 pWindow = pWindow->mpWindowImpl->mpNext; 1998 } 1999 } 2000 2001 return bUpdate; 2002 } 2003 else 2004 return mpWindowImpl->mpFrameWindow->ImplSetClipFlagOverlapWindows( bSysObjOnlySmaller ); 2005 } 2006 2007 // ----------------------------------------------------------------------- 2008 2009 void Window::ImplIntersectWindowClipRegion( Region& rRegion ) 2010 { 2011 if ( mpWindowImpl->mbInitWinClipRegion ) 2012 ImplInitWinClipRegion(); 2013 2014 rRegion.Intersect( mpWindowImpl->maWinClipRegion ); 2015 } 2016 2017 // ----------------------------------------------------------------------- 2018 2019 void Window::ImplIntersectWindowRegion( Region& rRegion ) 2020 { 2021 rRegion.Intersect( Rectangle( Point( mnOutOffX, mnOutOffY ), 2022 Size( mnOutWidth, mnOutHeight ) ) ); 2023 if ( mpWindowImpl->mbWinRegion ) 2024 rRegion.Intersect( ImplPixelToDevicePixel( mpWindowImpl->maWinRegion ) ); 2025 } 2026 2027 // ----------------------------------------------------------------------- 2028 2029 void Window::ImplExcludeWindowRegion( Region& rRegion ) 2030 { 2031 if ( mpWindowImpl->mbWinRegion ) 2032 { 2033 Point aPoint( mnOutOffX, mnOutOffY ); 2034 Region aRegion( Rectangle( aPoint, 2035 Size( mnOutWidth, mnOutHeight ) ) ); 2036 aRegion.Intersect( ImplPixelToDevicePixel( mpWindowImpl->maWinRegion ) ); 2037 rRegion.Exclude( aRegion ); 2038 } 2039 else 2040 { 2041 Point aPoint( mnOutOffX, mnOutOffY ); 2042 rRegion.Exclude( Rectangle( aPoint, 2043 Size( mnOutWidth, mnOutHeight ) ) ); 2044 } 2045 } 2046 2047 // ----------------------------------------------------------------------- 2048 2049 void Window::ImplExcludeOverlapWindows( Region& rRegion ) 2050 { 2051 Window* pWindow = mpWindowImpl->mpFirstOverlap; 2052 while ( pWindow ) 2053 { 2054 if ( pWindow->mpWindowImpl->mbReallyVisible ) 2055 { 2056 pWindow->ImplExcludeWindowRegion( rRegion ); 2057 pWindow->ImplExcludeOverlapWindows( rRegion ); 2058 } 2059 2060 pWindow = pWindow->mpWindowImpl->mpNext; 2061 } 2062 } 2063 2064 // ----------------------------------------------------------------------- 2065 2066 void Window::ImplExcludeOverlapWindows2( Region& rRegion ) 2067 { 2068 if ( mpWindowImpl->mbReallyVisible ) 2069 ImplExcludeWindowRegion( rRegion ); 2070 2071 ImplExcludeOverlapWindows( rRegion ); 2072 } 2073 2074 // ----------------------------------------------------------------------- 2075 2076 void Window::ImplClipBoundaries( Region& rRegion, sal_Bool bThis, sal_Bool bOverlaps ) 2077 { 2078 if ( bThis ) 2079 ImplIntersectWindowClipRegion( rRegion ); 2080 else if ( ImplIsOverlapWindow() ) 2081 { 2082 // Evt. noch am Frame clippen 2083 if ( !mpWindowImpl->mbFrame ) 2084 rRegion.Intersect( Rectangle( Point( 0, 0 ), Size( mpWindowImpl->mpFrameWindow->mnOutWidth, mpWindowImpl->mpFrameWindow->mnOutHeight ) ) ); 2085 2086 if ( bOverlaps && !rRegion.IsEmpty() ) 2087 { 2088 // Clip Overlap Siblings 2089 Window* pStartOverlapWindow = this; 2090 while ( !pStartOverlapWindow->mpWindowImpl->mbFrame ) 2091 { 2092 Window* pOverlapWindow = pStartOverlapWindow->mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap; 2093 while ( pOverlapWindow && (pOverlapWindow != pStartOverlapWindow) ) 2094 { 2095 pOverlapWindow->ImplExcludeOverlapWindows2( rRegion ); 2096 pOverlapWindow = pOverlapWindow->mpWindowImpl->mpNext; 2097 } 2098 pStartOverlapWindow = pStartOverlapWindow->mpWindowImpl->mpOverlapWindow; 2099 } 2100 2101 // Clip Child Overlap Windows 2102 ImplExcludeOverlapWindows( rRegion ); 2103 } 2104 } 2105 else 2106 ImplGetParent()->ImplIntersectWindowClipRegion( rRegion ); 2107 } 2108 2109 // ----------------------------------------------------------------------- 2110 2111 sal_Bool Window::ImplClipChilds( Region& rRegion ) 2112 { 2113 sal_Bool bOtherClip = sal_False; 2114 Window* pWindow = mpWindowImpl->mpFirstChild; 2115 while ( pWindow ) 2116 { 2117 if ( pWindow->mpWindowImpl->mbReallyVisible ) 2118 { 2119 // ParentClipMode-Flags auswerten 2120 sal_uInt16 nClipMode = pWindow->GetParentClipMode(); 2121 if ( !(nClipMode & PARENTCLIPMODE_NOCLIP) && 2122 ((nClipMode & PARENTCLIPMODE_CLIP) || (GetStyle() & WB_CLIPCHILDREN)) ) 2123 pWindow->ImplExcludeWindowRegion( rRegion ); 2124 else 2125 bOtherClip = sal_True; 2126 } 2127 2128 pWindow = pWindow->mpWindowImpl->mpNext; 2129 } 2130 2131 return bOtherClip; 2132 } 2133 2134 // ----------------------------------------------------------------------- 2135 2136 void Window::ImplClipAllChilds( Region& rRegion ) 2137 { 2138 Window* pWindow = mpWindowImpl->mpFirstChild; 2139 while ( pWindow ) 2140 { 2141 if ( pWindow->mpWindowImpl->mbReallyVisible ) 2142 pWindow->ImplExcludeWindowRegion( rRegion ); 2143 pWindow = pWindow->mpWindowImpl->mpNext; 2144 } 2145 } 2146 2147 // ----------------------------------------------------------------------- 2148 2149 void Window::ImplClipSiblings( Region& rRegion ) 2150 { 2151 Window* pWindow = ImplGetParent()->mpWindowImpl->mpFirstChild; 2152 while ( pWindow ) 2153 { 2154 if ( pWindow == this ) 2155 break; 2156 2157 if ( pWindow->mpWindowImpl->mbReallyVisible ) 2158 pWindow->ImplExcludeWindowRegion( rRegion ); 2159 2160 pWindow = pWindow->mpWindowImpl->mpNext; 2161 } 2162 } 2163 2164 // ----------------------------------------------------------------------- 2165 2166 void Window::ImplInitWinClipRegion() 2167 { 2168 // Build Window Region 2169 mpWindowImpl->maWinClipRegion = Rectangle( Point( mnOutOffX, mnOutOffY ), 2170 Size( mnOutWidth, mnOutHeight ) ); 2171 if ( mpWindowImpl->mbWinRegion ) 2172 mpWindowImpl->maWinClipRegion.Intersect( ImplPixelToDevicePixel( mpWindowImpl->maWinRegion ) ); 2173 2174 // ClipSiblings 2175 if ( mpWindowImpl->mbClipSiblings && !ImplIsOverlapWindow() ) 2176 ImplClipSiblings( mpWindowImpl->maWinClipRegion ); 2177 2178 // Clip Parent Boundaries 2179 ImplClipBoundaries( mpWindowImpl->maWinClipRegion, sal_False, sal_True ); 2180 2181 // Clip Children 2182 if ( (GetStyle() & WB_CLIPCHILDREN) || mpWindowImpl->mbClipChildren ) 2183 mpWindowImpl->mbInitChildRegion = sal_True; 2184 2185 mpWindowImpl->mbInitWinClipRegion = sal_False; 2186 } 2187 2188 // ----------------------------------------------------------------------- 2189 2190 void Window::ImplInitWinChildClipRegion() 2191 { 2192 if ( !mpWindowImpl->mpFirstChild ) 2193 { 2194 if ( mpWindowImpl->mpChildClipRegion ) 2195 { 2196 delete mpWindowImpl->mpChildClipRegion; 2197 mpWindowImpl->mpChildClipRegion = NULL; 2198 } 2199 } 2200 else 2201 { 2202 if ( !mpWindowImpl->mpChildClipRegion ) 2203 mpWindowImpl->mpChildClipRegion = new Region( mpWindowImpl->maWinClipRegion ); 2204 else 2205 *mpWindowImpl->mpChildClipRegion = mpWindowImpl->maWinClipRegion; 2206 2207 ImplClipChilds( *mpWindowImpl->mpChildClipRegion ); 2208 } 2209 2210 mpWindowImpl->mbInitChildRegion = sal_False; 2211 } 2212 2213 // ----------------------------------------------------------------------- 2214 2215 Region* Window::ImplGetWinChildClipRegion() 2216 { 2217 if ( mpWindowImpl->mbInitWinClipRegion ) 2218 ImplInitWinClipRegion(); 2219 if ( mpWindowImpl->mbInitChildRegion ) 2220 ImplInitWinChildClipRegion(); 2221 if ( mpWindowImpl->mpChildClipRegion ) 2222 return mpWindowImpl->mpChildClipRegion; 2223 else 2224 return &mpWindowImpl->maWinClipRegion; 2225 } 2226 2227 // ----------------------------------------------------------------------- 2228 2229 void Window::ImplIntersectAndUnionOverlapWindows( const Region& rInterRegion, Region& rRegion ) 2230 { 2231 Window* pWindow = mpWindowImpl->mpFirstOverlap; 2232 while ( pWindow ) 2233 { 2234 if ( pWindow->mpWindowImpl->mbReallyVisible ) 2235 { 2236 Region aTempRegion( rInterRegion ); 2237 pWindow->ImplIntersectWindowRegion( aTempRegion ); 2238 rRegion.Union( aTempRegion ); 2239 pWindow->ImplIntersectAndUnionOverlapWindows( rInterRegion, rRegion ); 2240 } 2241 2242 pWindow = pWindow->mpWindowImpl->mpNext; 2243 } 2244 } 2245 2246 // ----------------------------------------------------------------------- 2247 2248 void Window::ImplIntersectAndUnionOverlapWindows2( const Region& rInterRegion, Region& rRegion ) 2249 { 2250 if ( mpWindowImpl->mbReallyVisible ) 2251 { 2252 Region aTempRegion( rInterRegion ); 2253 ImplIntersectWindowRegion( aTempRegion ); 2254 rRegion.Union( aTempRegion ); 2255 } 2256 2257 ImplIntersectAndUnionOverlapWindows( rInterRegion, rRegion ); 2258 } 2259 2260 // ----------------------------------------------------------------------- 2261 2262 void Window::ImplCalcOverlapRegionOverlaps( const Region& rInterRegion, Region& rRegion ) 2263 { 2264 // Clip Overlap Siblings 2265 Window* pStartOverlapWindow; 2266 if ( !ImplIsOverlapWindow() ) 2267 pStartOverlapWindow = mpWindowImpl->mpOverlapWindow; 2268 else 2269 pStartOverlapWindow = this; 2270 while ( !pStartOverlapWindow->mpWindowImpl->mbFrame ) 2271 { 2272 Window* pOverlapWindow = pStartOverlapWindow->mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap; 2273 while ( pOverlapWindow && (pOverlapWindow != pStartOverlapWindow) ) 2274 { 2275 pOverlapWindow->ImplIntersectAndUnionOverlapWindows2( rInterRegion, rRegion ); 2276 pOverlapWindow = pOverlapWindow->mpWindowImpl->mpNext; 2277 } 2278 pStartOverlapWindow = pStartOverlapWindow->mpWindowImpl->mpOverlapWindow; 2279 } 2280 2281 // Clip Child Overlap Windows 2282 if ( !ImplIsOverlapWindow() ) 2283 mpWindowImpl->mpOverlapWindow->ImplIntersectAndUnionOverlapWindows( rInterRegion, rRegion ); 2284 else 2285 ImplIntersectAndUnionOverlapWindows( rInterRegion, rRegion ); 2286 } 2287 2288 // ----------------------------------------------------------------------- 2289 2290 void Window::ImplCalcOverlapRegion( const Rectangle& rSourceRect, Region& rRegion, 2291 sal_Bool bChilds, sal_Bool bParent, sal_Bool bSiblings ) 2292 { 2293 Region aRegion( rSourceRect ); 2294 if ( mpWindowImpl->mbWinRegion ) 2295 rRegion.Intersect( ImplPixelToDevicePixel( mpWindowImpl->maWinRegion ) ); 2296 Region aTempRegion; 2297 Window* pWindow; 2298 2299 ImplCalcOverlapRegionOverlaps( aRegion, rRegion ); 2300 2301 // Parent-Boundaries 2302 if ( bParent ) 2303 { 2304 pWindow = this; 2305 if ( !ImplIsOverlapWindow() ) 2306 { 2307 pWindow = ImplGetParent(); 2308 do 2309 { 2310 aTempRegion = aRegion; 2311 pWindow->ImplExcludeWindowRegion( aTempRegion ); 2312 rRegion.Union( aTempRegion ); 2313 if ( pWindow->ImplIsOverlapWindow() ) 2314 break; 2315 pWindow = pWindow->ImplGetParent(); 2316 } 2317 while ( pWindow ); 2318 } 2319 if ( !pWindow->mpWindowImpl->mbFrame ) 2320 { 2321 aTempRegion = aRegion; 2322 aTempRegion.Exclude( Rectangle( Point( 0, 0 ), Size( mpWindowImpl->mpFrameWindow->mnOutWidth, mpWindowImpl->mpFrameWindow->mnOutHeight ) ) ); 2323 rRegion.Union( aTempRegion ); 2324 } 2325 } 2326 2327 // Siblings 2328 if ( bSiblings && !ImplIsOverlapWindow() ) 2329 { 2330 pWindow = mpWindowImpl->mpParent->mpWindowImpl->mpFirstChild; 2331 do 2332 { 2333 if ( pWindow->mpWindowImpl->mbReallyVisible && (pWindow != this) ) 2334 { 2335 aTempRegion = aRegion; 2336 pWindow->ImplIntersectWindowRegion( aTempRegion ); 2337 rRegion.Union( aTempRegion ); 2338 } 2339 pWindow = pWindow->mpWindowImpl->mpNext; 2340 } 2341 while ( pWindow ); 2342 } 2343 2344 // Childs 2345 if ( bChilds ) 2346 { 2347 pWindow = mpWindowImpl->mpFirstChild; 2348 while ( pWindow ) 2349 { 2350 if ( pWindow->mpWindowImpl->mbReallyVisible ) 2351 { 2352 aTempRegion = aRegion; 2353 pWindow->ImplIntersectWindowRegion( aTempRegion ); 2354 rRegion.Union( aTempRegion ); 2355 } 2356 pWindow = pWindow->mpWindowImpl->mpNext; 2357 } 2358 } 2359 } 2360 2361 // ----------------------------------------------------------------------- 2362 2363 void Window::ImplCallPaint( const Region* pRegion, sal_uInt16 nPaintFlags ) 2364 { 2365 Exception aException; 2366 bool bExceptionCaught(false); 2367 2368 // call PrePaint. PrePaint may add to the invalidate region as well as 2369 // other parameters used below. 2370 PrePaint(); 2371 2372 mpWindowImpl->mbPaintFrame = sal_False; 2373 2374 if ( nPaintFlags & IMPL_PAINT_PAINTALLCHILDS ) 2375 mpWindowImpl->mnPaintFlags |= IMPL_PAINT_PAINT | IMPL_PAINT_PAINTALLCHILDS | (nPaintFlags & IMPL_PAINT_PAINTALL); 2376 if ( nPaintFlags & IMPL_PAINT_PAINTCHILDS ) 2377 mpWindowImpl->mnPaintFlags |= IMPL_PAINT_PAINTCHILDS; 2378 if ( nPaintFlags & IMPL_PAINT_ERASE ) 2379 mpWindowImpl->mnPaintFlags |= IMPL_PAINT_ERASE; 2380 if ( nPaintFlags & IMPL_PAINT_CHECKRTL ) 2381 mpWindowImpl->mnPaintFlags |= IMPL_PAINT_CHECKRTL; 2382 if ( !mpWindowImpl->mpFirstChild ) 2383 mpWindowImpl->mnPaintFlags &= ~IMPL_PAINT_PAINTALLCHILDS; 2384 2385 if ( mpWindowImpl->mbPaintDisabled ) 2386 { 2387 if ( mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALL ) 2388 Invalidate( INVALIDATE_NOCHILDREN | INVALIDATE_NOERASE | INVALIDATE_NOTRANSPARENT | INVALIDATE_NOCLIPCHILDREN ); 2389 else if ( pRegion ) 2390 Invalidate( *pRegion, INVALIDATE_NOCHILDREN | INVALIDATE_NOERASE | INVALIDATE_NOTRANSPARENT | INVALIDATE_NOCLIPCHILDREN ); 2391 return; 2392 } 2393 2394 nPaintFlags = mpWindowImpl->mnPaintFlags & ~(IMPL_PAINT_PAINT); 2395 2396 Region* pChildRegion = NULL; 2397 Rectangle aSelectionRect; 2398 if ( mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINT ) 2399 { 2400 Region* pWinChildClipRegion = ImplGetWinChildClipRegion(); 2401 if ( mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALL ) 2402 mpWindowImpl->maInvalidateRegion = *pWinChildClipRegion; 2403 else 2404 { 2405 if ( pRegion ) 2406 mpWindowImpl->maInvalidateRegion.Union( *pRegion ); 2407 2408 if( mpWindowImpl->mpWinData && mpWindowImpl->mbTrackVisible ) 2409 /* #98602# need to repaint all children within the 2410 * tracking rectangle, so the following invert 2411 * operation takes places without traces of the previous 2412 * one. 2413 */ 2414 mpWindowImpl->maInvalidateRegion.Union( *mpWindowImpl->mpWinData->mpTrackRect ); 2415 2416 if ( mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALLCHILDS ) 2417 pChildRegion = new Region( mpWindowImpl->maInvalidateRegion ); 2418 mpWindowImpl->maInvalidateRegion.Intersect( *pWinChildClipRegion ); 2419 } 2420 mpWindowImpl->mnPaintFlags = 0; 2421 if ( !mpWindowImpl->maInvalidateRegion.IsEmpty() ) 2422 { 2423 bool bRestoreCursor = false; 2424 if ( mpWindowImpl->mpCursor ) 2425 bRestoreCursor = mpWindowImpl->mpCursor->ImplHide( false ); 2426 2427 mbInitClipRegion = sal_True; 2428 mpWindowImpl->mbInPaint = sal_True; 2429 2430 // Paint-Region zuruecksetzen 2431 Region aPaintRegion( mpWindowImpl->maInvalidateRegion ); 2432 Rectangle aPaintRect = aPaintRegion.GetBoundRect(); 2433 2434 // - RTL - re-mirror paint rect and region at this window 2435 if( ImplIsAntiparallel() ) 2436 { 2437 ImplReMirror( aPaintRect ); 2438 ImplReMirror( aPaintRegion ); 2439 } 2440 aPaintRect = ImplDevicePixelToLogic( aPaintRect); 2441 mpWindowImpl->mpPaintRegion = &aPaintRegion; 2442 mpWindowImpl->maInvalidateRegion.SetEmpty(); 2443 2444 if ( (nPaintFlags & IMPL_PAINT_ERASE) && IsBackground() ) 2445 { 2446 if ( IsClipRegion() ) 2447 { 2448 Region aOldRegion = GetClipRegion(); 2449 SetClipRegion(); 2450 Erase(); 2451 SetClipRegion( aOldRegion ); 2452 } 2453 else 2454 Erase(); 2455 } 2456 2457 // #98943# trigger drawing of toolbox selection after all childern are painted 2458 if( mpWindowImpl->mbDrawSelectionBackground ) 2459 aSelectionRect = aPaintRect; 2460 2461 // Paint can throw exceptions; to not have a situation where 2462 // mpWindowImpl->mbInPaint keeps to be on true (and other 2463 // settings, too) better catch here to avoid to go completely out of 2464 // this method without executing the after-paint stuff 2465 try 2466 { 2467 Paint( aPaintRect ); 2468 } 2469 catch(Exception& rException) 2470 { 2471 aException = rException; 2472 bExceptionCaught = true; 2473 } 2474 2475 if ( mpWindowImpl->mpWinData ) 2476 { 2477 if ( mpWindowImpl->mbFocusVisible ) 2478 ImplInvertFocus( *(mpWindowImpl->mpWinData->mpFocusRect) ); 2479 } 2480 mpWindowImpl->mbInPaint = sal_False; 2481 mbInitClipRegion = sal_True; 2482 mpWindowImpl->mpPaintRegion = NULL; 2483 if ( mpWindowImpl->mpCursor ) 2484 mpWindowImpl->mpCursor->ImplShow( false, bRestoreCursor ); 2485 } 2486 } 2487 else 2488 mpWindowImpl->mnPaintFlags = 0; 2489 2490 if ( nPaintFlags & (IMPL_PAINT_PAINTALLCHILDS | IMPL_PAINT_PAINTCHILDS) ) 2491 { 2492 // die Childfenster ausgeben 2493 Window* pTempWindow = mpWindowImpl->mpFirstChild; 2494 while ( pTempWindow ) 2495 { 2496 if ( pTempWindow->mpWindowImpl->mbVisible ) 2497 pTempWindow->ImplCallPaint( pChildRegion, nPaintFlags ); 2498 pTempWindow = pTempWindow->mpWindowImpl->mpNext; 2499 } 2500 } 2501 2502 if ( mpWindowImpl->mpWinData && mpWindowImpl->mbTrackVisible && (mpWindowImpl->mpWinData->mnTrackFlags & SHOWTRACK_WINDOW) ) 2503 /* #98602# need to invert the tracking rect AFTER 2504 * the children have painted 2505 */ 2506 InvertTracking( *(mpWindowImpl->mpWinData->mpTrackRect), mpWindowImpl->mpWinData->mnTrackFlags ); 2507 2508 // #98943# draw toolbox selection 2509 if( !aSelectionRect.IsEmpty() ) 2510 DrawSelectionBackground( aSelectionRect, 3, sal_False, sal_True, sal_False ); 2511 2512 if ( pChildRegion ) 2513 delete pChildRegion; 2514 2515 if(bExceptionCaught) 2516 { 2517 throw(aException); 2518 } 2519 } 2520 2521 // ----------------------------------------------------------------------- 2522 2523 void Window::ImplCallOverlapPaint() 2524 { 2525 // Zuerst geben wir die ueberlappenden Fenster aus 2526 Window* pTempWindow = mpWindowImpl->mpFirstOverlap; 2527 while ( pTempWindow ) 2528 { 2529 if ( pTempWindow->mpWindowImpl->mbReallyVisible ) 2530 pTempWindow->ImplCallOverlapPaint(); 2531 pTempWindow = pTempWindow->mpWindowImpl->mpNext; 2532 } 2533 2534 // und dann erst uns selber 2535 if ( mpWindowImpl->mnPaintFlags & (IMPL_PAINT_PAINT | IMPL_PAINT_PAINTCHILDS) ) 2536 { 2537 // - RTL - notify ImplCallPaint to check for re-mirroring (CHECKRTL) 2538 // because we were called from the Sal layer 2539 ImplCallPaint( NULL, mpWindowImpl->mnPaintFlags /*| IMPL_PAINT_CHECKRTL */); 2540 } 2541 } 2542 2543 // ----------------------------------------------------------------------- 2544 2545 void Window::ImplPostPaint() 2546 { 2547 if ( !mpWindowImpl->mpFrameData->maPaintTimer.IsActive() ) 2548 mpWindowImpl->mpFrameData->maPaintTimer.Start(); 2549 } 2550 2551 // ----------------------------------------------------------------------- 2552 2553 IMPL_LINK( Window, ImplHandlePaintHdl, void*, EMPTYARG ) 2554 { 2555 // save paint events until resizing is done 2556 if( mpWindowImpl->mbFrame && mpWindowImpl->mpFrameData->maResizeTimer.IsActive() ) 2557 mpWindowImpl->mpFrameData->maPaintTimer.Start(); 2558 else if ( mpWindowImpl->mbReallyVisible ) 2559 ImplCallOverlapPaint(); 2560 return 0; 2561 } 2562 2563 // ----------------------------------------------------------------------- 2564 2565 IMPL_LINK( Window, ImplHandleResizeTimerHdl, void*, EMPTYARG ) 2566 { 2567 if( mpWindowImpl->mbReallyVisible ) 2568 { 2569 ImplCallResize(); 2570 if( mpWindowImpl->mpFrameData->maPaintTimer.IsActive() ) 2571 { 2572 mpWindowImpl->mpFrameData->maPaintTimer.Stop(); 2573 mpWindowImpl->mpFrameData->maPaintTimer.GetTimeoutHdl().Call( NULL ); 2574 } 2575 } 2576 2577 return 0; 2578 } 2579 2580 // ----------------------------------------------------------------------- 2581 2582 void Window::ImplInvalidateFrameRegion( const Region* pRegion, sal_uInt16 nFlags ) 2583 { 2584 // PAINTCHILDS bei allen Parent-Fenster bis zum ersten OverlapWindow 2585 // setzen 2586 if ( !ImplIsOverlapWindow() ) 2587 { 2588 Window* pTempWindow = this; 2589 sal_uInt16 nTranspPaint = IsPaintTransparent() ? IMPL_PAINT_PAINT : 0; 2590 do 2591 { 2592 pTempWindow = pTempWindow->ImplGetParent(); 2593 if ( pTempWindow->mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTCHILDS ) 2594 break; 2595 pTempWindow->mpWindowImpl->mnPaintFlags |= IMPL_PAINT_PAINTCHILDS | nTranspPaint; 2596 if( ! pTempWindow->IsPaintTransparent() ) 2597 nTranspPaint = 0; 2598 } 2599 while ( !pTempWindow->ImplIsOverlapWindow() ); 2600 } 2601 2602 // Paint-Flags setzen 2603 mpWindowImpl->mnPaintFlags |= IMPL_PAINT_PAINT; 2604 if ( nFlags & INVALIDATE_CHILDREN ) 2605 mpWindowImpl->mnPaintFlags |= IMPL_PAINT_PAINTALLCHILDS; 2606 if ( !(nFlags & INVALIDATE_NOERASE) ) 2607 mpWindowImpl->mnPaintFlags |= IMPL_PAINT_ERASE; 2608 if ( !pRegion ) 2609 mpWindowImpl->mnPaintFlags |= IMPL_PAINT_PAINTALL; 2610 2611 // Wenn nicht alles neu ausgegeben werden muss, dann die Region 2612 // dazupacken 2613 if ( !(mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALL) ) 2614 mpWindowImpl->maInvalidateRegion.Union( *pRegion ); 2615 2616 // Handle transparent windows correctly: invalidate must be done on the first opaque parent 2617 if( ((IsPaintTransparent() && !(nFlags & INVALIDATE_NOTRANSPARENT)) || (nFlags & INVALIDATE_TRANSPARENT) ) 2618 && ImplGetParent() ) 2619 { 2620 Window *pParent = ImplGetParent(); 2621 while( pParent && pParent->IsPaintTransparent() ) 2622 pParent = pParent->ImplGetParent(); 2623 if( pParent ) 2624 { 2625 Region *pChildRegion; 2626 if ( mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALL ) 2627 // invalidate the whole child window region in the parent 2628 pChildRegion = ImplGetWinChildClipRegion(); 2629 else 2630 // invalidate the same region in the parent that has to be repainted in the child 2631 pChildRegion = &mpWindowImpl->maInvalidateRegion; 2632 2633 nFlags |= INVALIDATE_CHILDREN; // paint should also be done on all children 2634 nFlags &= ~INVALIDATE_NOERASE; // parent should paint and erase to create proper background 2635 pParent->ImplInvalidateFrameRegion( pChildRegion, nFlags ); 2636 } 2637 } 2638 ImplPostPaint(); 2639 } 2640 2641 // ----------------------------------------------------------------------- 2642 2643 void Window::ImplInvalidateOverlapFrameRegion( const Region& rRegion ) 2644 { 2645 Region aRegion = rRegion; 2646 2647 ImplClipBoundaries( aRegion, sal_True, sal_True ); 2648 if ( !aRegion.IsEmpty() ) 2649 ImplInvalidateFrameRegion( &aRegion, INVALIDATE_CHILDREN ); 2650 2651 // Dann invalidieren wir die ueberlappenden Fenster 2652 Window* pTempWindow = mpWindowImpl->mpFirstOverlap; 2653 while ( pTempWindow ) 2654 { 2655 if ( pTempWindow->IsVisible() ) 2656 pTempWindow->ImplInvalidateOverlapFrameRegion( rRegion ); 2657 2658 pTempWindow = pTempWindow->mpWindowImpl->mpNext; 2659 } 2660 } 2661 2662 // ----------------------------------------------------------------------- 2663 2664 void Window::ImplInvalidateParentFrameRegion( Region& rRegion ) 2665 { 2666 if ( mpWindowImpl->mbOverlapWin ) 2667 mpWindowImpl->mpFrameWindow->ImplInvalidateOverlapFrameRegion( rRegion ); 2668 else 2669 { 2670 if( ImplGetParent() ) 2671 ImplGetParent()->ImplInvalidateFrameRegion( &rRegion, INVALIDATE_CHILDREN ); 2672 } 2673 } 2674 2675 // ----------------------------------------------------------------------- 2676 2677 void Window::ImplInvalidate( const Region* pRegion, sal_uInt16 nFlags ) 2678 { 2679 2680 // Hintergrund-Sicherung zuruecksetzen 2681 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 2682 ImplInvalidateAllOverlapBackgrounds(); 2683 2684 // Feststellen, was neu ausgegeben werden muss 2685 sal_Bool bInvalidateAll = !pRegion; 2686 2687 // Transparent-Invalidate beruecksichtigen 2688 Window* pOpaqueWindow = this; 2689 if ( (mpWindowImpl->mbPaintTransparent && !(nFlags & INVALIDATE_NOTRANSPARENT)) || (nFlags & INVALIDATE_TRANSPARENT) ) 2690 { 2691 Window* pTempWindow = pOpaqueWindow->ImplGetParent(); 2692 while ( pTempWindow ) 2693 { 2694 if ( !pTempWindow->IsPaintTransparent() ) 2695 { 2696 pOpaqueWindow = pTempWindow; 2697 nFlags |= INVALIDATE_CHILDREN; 2698 bInvalidateAll = sal_False; 2699 break; 2700 } 2701 2702 if ( pTempWindow->ImplIsOverlapWindow() ) 2703 break; 2704 2705 pTempWindow = pTempWindow->ImplGetParent(); 2706 } 2707 } 2708 2709 // Region zusammenbauen 2710 sal_uInt16 nOrgFlags = nFlags; 2711 if ( !(nFlags & (INVALIDATE_CHILDREN | INVALIDATE_NOCHILDREN)) ) 2712 { 2713 if ( GetStyle() & WB_CLIPCHILDREN ) 2714 nFlags |= INVALIDATE_NOCHILDREN; 2715 else 2716 nFlags |= INVALIDATE_CHILDREN; 2717 } 2718 if ( (nFlags & INVALIDATE_NOCHILDREN) && mpWindowImpl->mpFirstChild ) 2719 bInvalidateAll = sal_False; 2720 if ( bInvalidateAll ) 2721 ImplInvalidateFrameRegion( NULL, nFlags ); 2722 else 2723 { 2724 Rectangle aRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 2725 Region aRegion( aRect ); 2726 if ( pRegion ) 2727 { 2728 // --- RTL --- remirror region before intersecting it 2729 if ( ImplIsAntiparallel() ) 2730 { 2731 Region aRgn( *pRegion ); 2732 ImplReMirror( aRgn ); 2733 aRegion.Intersect( aRgn ); 2734 } 2735 else 2736 aRegion.Intersect( *pRegion ); 2737 } 2738 ImplClipBoundaries( aRegion, sal_True, sal_True ); 2739 if ( nFlags & INVALIDATE_NOCHILDREN ) 2740 { 2741 nFlags &= ~INVALIDATE_CHILDREN; 2742 if ( !(nFlags & INVALIDATE_NOCLIPCHILDREN) ) 2743 { 2744 if ( nOrgFlags & INVALIDATE_NOCHILDREN ) 2745 ImplClipAllChilds( aRegion ); 2746 else 2747 { 2748 if ( ImplClipChilds( aRegion ) ) 2749 nFlags |= INVALIDATE_CHILDREN; 2750 } 2751 } 2752 } 2753 if ( !aRegion.IsEmpty() ) 2754 ImplInvalidateFrameRegion( &aRegion, nFlags ); // transparency is handled here, pOpaqueWindow not required 2755 } 2756 2757 if ( nFlags & INVALIDATE_UPDATE ) 2758 pOpaqueWindow->Update(); // start painting at the opaque parent 2759 } 2760 2761 // ----------------------------------------------------------------------- 2762 2763 void Window::ImplMoveInvalidateRegion( const Rectangle& rRect, 2764 long nHorzScroll, long nVertScroll, 2765 sal_Bool bChilds ) 2766 { 2767 if ( (mpWindowImpl->mnPaintFlags & (IMPL_PAINT_PAINT | IMPL_PAINT_PAINTALL)) == IMPL_PAINT_PAINT ) 2768 { 2769 Region aTempRegion = mpWindowImpl->maInvalidateRegion; 2770 aTempRegion.Intersect( rRect ); 2771 aTempRegion.Move( nHorzScroll, nVertScroll ); 2772 mpWindowImpl->maInvalidateRegion.Union( aTempRegion ); 2773 } 2774 2775 if ( bChilds && (mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTCHILDS) ) 2776 { 2777 Window* pWindow = mpWindowImpl->mpFirstChild; 2778 while ( pWindow ) 2779 { 2780 pWindow->ImplMoveInvalidateRegion( rRect, nHorzScroll, nVertScroll, sal_True ); 2781 pWindow = pWindow->mpWindowImpl->mpNext; 2782 } 2783 } 2784 } 2785 2786 // ----------------------------------------------------------------------- 2787 2788 void Window::ImplMoveAllInvalidateRegions( const Rectangle& rRect, 2789 long nHorzScroll, long nVertScroll, 2790 sal_Bool bChilds ) 2791 { 2792 // Paint-Region auch verschieben, wenn noch Paints anstehen 2793 ImplMoveInvalidateRegion( rRect, nHorzScroll, nVertScroll, bChilds ); 2794 // Paint-Region muss bei uns verschoben gesetzt werden, die durch 2795 // die Parents gezeichnet werden 2796 if ( !ImplIsOverlapWindow() ) 2797 { 2798 Region aPaintAllRegion; 2799 Window* pPaintAllWindow = this; 2800 do 2801 { 2802 pPaintAllWindow = pPaintAllWindow->ImplGetParent(); 2803 if ( pPaintAllWindow->mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALLCHILDS ) 2804 { 2805 if ( pPaintAllWindow->mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALL ) 2806 { 2807 aPaintAllRegion.SetEmpty(); 2808 break; 2809 } 2810 else 2811 aPaintAllRegion.Union( pPaintAllWindow->mpWindowImpl->maInvalidateRegion ); 2812 } 2813 } 2814 while ( !pPaintAllWindow->ImplIsOverlapWindow() ); 2815 if ( !aPaintAllRegion.IsEmpty() ) 2816 { 2817 aPaintAllRegion.Move( nHorzScroll, nVertScroll ); 2818 sal_uInt16 nPaintFlags = 0; 2819 if ( bChilds ) 2820 mpWindowImpl->mnPaintFlags |= INVALIDATE_CHILDREN; 2821 ImplInvalidateFrameRegion( &aPaintAllRegion, nPaintFlags ); 2822 } 2823 } 2824 } 2825 2826 // ----------------------------------------------------------------------- 2827 2828 void Window::ImplValidateFrameRegion( const Region* pRegion, sal_uInt16 nFlags ) 2829 { 2830 if ( !pRegion ) 2831 mpWindowImpl->maInvalidateRegion.SetEmpty(); 2832 else 2833 { 2834 // Wenn alle Childfenster neu ausgegeben werden muessen, 2835 // dann invalidieren wir diese vorher 2836 if ( (mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALLCHILDS) && mpWindowImpl->mpFirstChild ) 2837 { 2838 Region aChildRegion = mpWindowImpl->maInvalidateRegion; 2839 if ( mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALL ) 2840 { 2841 Rectangle aRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 2842 aChildRegion = aRect; 2843 } 2844 Window* pChild = mpWindowImpl->mpFirstChild; 2845 while ( pChild ) 2846 { 2847 pChild->Invalidate( aChildRegion, INVALIDATE_CHILDREN | INVALIDATE_NOTRANSPARENT ); 2848 pChild = pChild->mpWindowImpl->mpNext; 2849 } 2850 } 2851 if ( mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALL ) 2852 { 2853 Rectangle aRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 2854 mpWindowImpl->maInvalidateRegion = aRect; 2855 } 2856 mpWindowImpl->maInvalidateRegion.Exclude( *pRegion ); 2857 } 2858 mpWindowImpl->mnPaintFlags &= ~IMPL_PAINT_PAINTALL; 2859 2860 if ( nFlags & VALIDATE_CHILDREN ) 2861 { 2862 Window* pChild = mpWindowImpl->mpFirstChild; 2863 while ( pChild ) 2864 { 2865 pChild->ImplValidateFrameRegion( pRegion, nFlags ); 2866 pChild = pChild->mpWindowImpl->mpNext; 2867 } 2868 } 2869 } 2870 2871 // ----------------------------------------------------------------------- 2872 2873 void Window::ImplValidate( const Region* pRegion, sal_uInt16 nFlags ) 2874 { 2875 // Region zusammenbauen 2876 sal_Bool bValidateAll = !pRegion; 2877 sal_uInt16 nOrgFlags = nFlags; 2878 if ( !(nFlags & (VALIDATE_CHILDREN | VALIDATE_NOCHILDREN)) ) 2879 { 2880 if ( GetStyle() & WB_CLIPCHILDREN ) 2881 nFlags |= VALIDATE_NOCHILDREN; 2882 else 2883 nFlags |= VALIDATE_CHILDREN; 2884 } 2885 if ( (nFlags & VALIDATE_NOCHILDREN) && mpWindowImpl->mpFirstChild ) 2886 bValidateAll = sal_False; 2887 if ( bValidateAll ) 2888 ImplValidateFrameRegion( NULL, nFlags ); 2889 else 2890 { 2891 Rectangle aRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 2892 Region aRegion( aRect ); 2893 if ( pRegion ) 2894 aRegion.Intersect( *pRegion ); 2895 ImplClipBoundaries( aRegion, sal_True, sal_True ); 2896 if ( nFlags & VALIDATE_NOCHILDREN ) 2897 { 2898 nFlags &= ~VALIDATE_CHILDREN; 2899 if ( nOrgFlags & VALIDATE_NOCHILDREN ) 2900 ImplClipAllChilds( aRegion ); 2901 else 2902 { 2903 if ( ImplClipChilds( aRegion ) ) 2904 nFlags |= VALIDATE_CHILDREN; 2905 } 2906 } 2907 if ( !aRegion.IsEmpty() ) 2908 ImplValidateFrameRegion( &aRegion, nFlags ); 2909 } 2910 } 2911 2912 // ----------------------------------------------------------------------- 2913 2914 void Window::ImplScroll( const Rectangle& rRect, 2915 long nHorzScroll, long nVertScroll, sal_uInt16 nFlags ) 2916 { 2917 if ( !IsDeviceOutputNecessary() ) 2918 return; 2919 2920 nHorzScroll = ImplLogicWidthToDevicePixel( nHorzScroll ); 2921 nVertScroll = ImplLogicHeightToDevicePixel( nVertScroll ); 2922 2923 if ( !nHorzScroll && !nVertScroll ) 2924 return; 2925 2926 // Hintergrund-Sicherung zuruecksetzen 2927 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 2928 ImplInvalidateAllOverlapBackgrounds(); 2929 2930 if ( mpWindowImpl->mpCursor ) 2931 mpWindowImpl->mpCursor->ImplHide( false ); 2932 2933 sal_uInt16 nOrgFlags = nFlags; 2934 if ( !(nFlags & (SCROLL_CHILDREN | SCROLL_NOCHILDREN)) ) 2935 { 2936 if ( GetStyle() & WB_CLIPCHILDREN ) 2937 nFlags |= SCROLL_NOCHILDREN; 2938 else 2939 nFlags |= SCROLL_CHILDREN; 2940 } 2941 2942 Region aInvalidateRegion; 2943 sal_Bool bScrollChilds = (nFlags & SCROLL_CHILDREN) != 0; 2944 sal_Bool bErase = (nFlags & SCROLL_NOERASE) == 0; 2945 2946 if ( !mpWindowImpl->mpFirstChild ) 2947 bScrollChilds = sal_False; 2948 2949 // --- RTL --- check if this window requires special action 2950 sal_Bool bReMirror = ( ImplIsAntiparallel() ); 2951 2952 Rectangle aRectMirror( rRect ); 2953 if( bReMirror ) 2954 { 2955 // --- RTL --- make sure the invalidate region of this window is 2956 // computed in the same coordinate space as the one from the overlap windows 2957 ImplReMirror( aRectMirror ); 2958 } 2959 2960 // Paint-Bereiche anpassen 2961 ImplMoveAllInvalidateRegions( aRectMirror, nHorzScroll, nVertScroll, bScrollChilds ); 2962 2963 if ( !(nFlags & SCROLL_NOINVALIDATE) ) 2964 { 2965 ImplCalcOverlapRegion( aRectMirror, aInvalidateRegion, !bScrollChilds, sal_True, sal_False ); 2966 2967 // --- RTL --- 2968 // if the scrolling on the device is performed in the opposite direction 2969 // then move the overlaps in that direction to compute the invalidate region 2970 // on the correct side, i.e., revert nHorzScroll 2971 2972 if ( !aInvalidateRegion.IsEmpty() ) 2973 { 2974 aInvalidateRegion.Move( bReMirror ? -nHorzScroll : nHorzScroll, nVertScroll ); 2975 bErase = sal_True; 2976 } 2977 if ( !(nFlags & SCROLL_NOWINDOWINVALIDATE) ) 2978 { 2979 Rectangle aDestRect( aRectMirror ); 2980 aDestRect.Move( bReMirror ? -nHorzScroll : nHorzScroll, nVertScroll ); 2981 Region aWinInvalidateRegion( aRectMirror ); 2982 aWinInvalidateRegion.Exclude( aDestRect ); 2983 2984 aInvalidateRegion.Union( aWinInvalidateRegion ); 2985 } 2986 } 2987 2988 Point aPoint( mnOutOffX, mnOutOffY ); 2989 Region aRegion( Rectangle( aPoint, Size( mnOutWidth, mnOutHeight ) ) ); 2990 if ( nFlags & SCROLL_CLIP ) 2991 aRegion.Intersect( rRect ); 2992 if ( mpWindowImpl->mbWinRegion ) 2993 aRegion.Intersect( ImplPixelToDevicePixel( mpWindowImpl->maWinRegion ) ); 2994 2995 aRegion.Exclude( aInvalidateRegion ); 2996 2997 ImplClipBoundaries( aRegion, sal_False, sal_True ); 2998 if ( !bScrollChilds ) 2999 { 3000 if ( nOrgFlags & SCROLL_NOCHILDREN ) 3001 ImplClipAllChilds( aRegion ); 3002 else 3003 ImplClipChilds( aRegion ); 3004 } 3005 if ( mbClipRegion && (nFlags & SCROLL_USECLIPREGION) ) 3006 aRegion.Intersect( maRegion ); 3007 if ( !aRegion.IsEmpty() ) 3008 { 3009 if ( mpWindowImpl->mpWinData ) 3010 { 3011 if ( mpWindowImpl->mbFocusVisible ) 3012 ImplInvertFocus( *(mpWindowImpl->mpWinData->mpFocusRect) ); 3013 if ( mpWindowImpl->mbTrackVisible && (mpWindowImpl->mpWinData->mnTrackFlags & SHOWTRACK_WINDOW) ) 3014 InvertTracking( *(mpWindowImpl->mpWinData->mpTrackRect), mpWindowImpl->mpWinData->mnTrackFlags ); 3015 } 3016 3017 SalGraphics* pGraphics = ImplGetFrameGraphics(); 3018 if ( pGraphics ) 3019 { 3020 if( bReMirror ) 3021 { 3022 // --- RTL --- frame coordinates require re-mirroring 3023 ImplReMirror( aRegion ); 3024 } 3025 3026 ImplSelectClipRegion( aRegion, pGraphics ); 3027 pGraphics->CopyArea( rRect.Left()+nHorzScroll, rRect.Top()+nVertScroll, 3028 rRect.Left(), rRect.Top(), 3029 rRect.GetWidth(), rRect.GetHeight(), 3030 SAL_COPYAREA_WINDOWINVALIDATE, this ); 3031 } 3032 3033 if ( mpWindowImpl->mpWinData ) 3034 { 3035 if ( mpWindowImpl->mbFocusVisible ) 3036 ImplInvertFocus( *(mpWindowImpl->mpWinData->mpFocusRect) ); 3037 if ( mpWindowImpl->mbTrackVisible && (mpWindowImpl->mpWinData->mnTrackFlags & SHOWTRACK_WINDOW) ) 3038 InvertTracking( *(mpWindowImpl->mpWinData->mpTrackRect), mpWindowImpl->mpWinData->mnTrackFlags ); 3039 } 3040 } 3041 3042 if ( !aInvalidateRegion.IsEmpty() ) 3043 { 3044 // --- RTL --- the invalidate region for this windows is already computed in frame coordinates 3045 // so it has to be re-mirrored before calling the Paint-handler 3046 mpWindowImpl->mnPaintFlags |= IMPL_PAINT_CHECKRTL; 3047 3048 sal_uInt16 nPaintFlags = INVALIDATE_CHILDREN; 3049 if ( !bErase ) 3050 nPaintFlags |= INVALIDATE_NOERASE; 3051 if ( !bScrollChilds ) 3052 { 3053 if ( nOrgFlags & SCROLL_NOCHILDREN ) 3054 ImplClipAllChilds( aInvalidateRegion ); 3055 else 3056 ImplClipChilds( aInvalidateRegion ); 3057 } 3058 ImplInvalidateFrameRegion( &aInvalidateRegion, nPaintFlags ); 3059 } 3060 3061 if ( bScrollChilds ) 3062 { 3063 Window* pWindow = mpWindowImpl->mpFirstChild; 3064 while ( pWindow ) 3065 { 3066 Point aPos = pWindow->GetPosPixel(); 3067 aPos += Point( nHorzScroll, nVertScroll ); 3068 pWindow->SetPosPixel( aPos ); 3069 3070 pWindow = pWindow->mpWindowImpl->mpNext; 3071 } 3072 } 3073 3074 if ( nFlags & SCROLL_UPDATE ) 3075 Update(); 3076 3077 if ( mpWindowImpl->mpCursor ) 3078 mpWindowImpl->mpCursor->ImplShow( false ); 3079 } 3080 3081 // ----------------------------------------------------------------------- 3082 3083 void Window::ImplUpdateAll( sal_Bool bOverlapWindows ) 3084 { 3085 if ( !mpWindowImpl->mbReallyVisible ) 3086 return; 3087 3088 sal_Bool bFlush = sal_False; 3089 if ( mpWindowImpl->mpFrameWindow->mpWindowImpl->mbPaintFrame ) 3090 { 3091 Point aPoint( 0, 0 ); 3092 Region aRegion( Rectangle( aPoint, Size( mnOutWidth, mnOutHeight ) ) ); 3093 ImplInvalidateOverlapFrameRegion( aRegion ); 3094 if ( mpWindowImpl->mbFrame || (mpWindowImpl->mpBorderWindow && mpWindowImpl->mpBorderWindow->mpWindowImpl->mbFrame) ) 3095 bFlush = sal_True; 3096 } 3097 3098 // Ein Update wirkt immer auf das OverlapWindow, damit bei spaeteren 3099 // Paints nicht zuviel gemalt wird, wenn dort ALLCHILDREN usw. gesetzt 3100 // ist 3101 Window* pWindow = ImplGetFirstOverlapWindow(); 3102 if ( bOverlapWindows ) 3103 pWindow->ImplCallOverlapPaint(); 3104 else 3105 { 3106 if ( pWindow->mpWindowImpl->mnPaintFlags & (IMPL_PAINT_PAINT | IMPL_PAINT_PAINTCHILDS) ) 3107 pWindow->ImplCallPaint( NULL, pWindow->mpWindowImpl->mnPaintFlags ); 3108 } 3109 3110 if ( bFlush ) 3111 Flush(); 3112 } 3113 3114 // ----------------------------------------------------------------------- 3115 3116 void Window::ImplUpdateWindowPtr( Window* pWindow ) 3117 { 3118 if ( mpWindowImpl->mpFrameWindow != pWindow->mpWindowImpl->mpFrameWindow ) 3119 { 3120 // Graphic freigeben 3121 ImplReleaseGraphics(); 3122 } 3123 3124 mpWindowImpl->mpFrameData = pWindow->mpWindowImpl->mpFrameData; 3125 mpWindowImpl->mpFrame = pWindow->mpWindowImpl->mpFrame; 3126 mpWindowImpl->mpFrameWindow = pWindow->mpWindowImpl->mpFrameWindow; 3127 if ( pWindow->ImplIsOverlapWindow() ) 3128 mpWindowImpl->mpOverlapWindow = pWindow; 3129 else 3130 mpWindowImpl->mpOverlapWindow = pWindow->mpWindowImpl->mpOverlapWindow; 3131 3132 Window* pChild = mpWindowImpl->mpFirstChild; 3133 while ( pChild ) 3134 { 3135 pChild->ImplUpdateWindowPtr( pWindow ); 3136 pChild = pChild->mpWindowImpl->mpNext; 3137 } 3138 } 3139 3140 // ----------------------------------------------------------------------- 3141 3142 void Window::ImplUpdateWindowPtr() 3143 { 3144 Window* pChild = mpWindowImpl->mpFirstChild; 3145 while ( pChild ) 3146 { 3147 pChild->ImplUpdateWindowPtr( this ); 3148 pChild = pChild->mpWindowImpl->mpNext; 3149 } 3150 } 3151 3152 // ----------------------------------------------------------------------- 3153 3154 void Window::ImplUpdateOverlapWindowPtr( sal_Bool bNewFrame ) 3155 { 3156 sal_Bool bVisible = IsVisible(); 3157 Show( sal_False ); 3158 ImplRemoveWindow( bNewFrame ); 3159 Window* pRealParent = mpWindowImpl->mpRealParent; 3160 ImplInsertWindow( ImplGetParent() ); 3161 mpWindowImpl->mpRealParent = pRealParent; 3162 ImplUpdateWindowPtr(); 3163 if ( ImplUpdatePos() ) 3164 ImplUpdateSysObjPos(); 3165 3166 if ( bNewFrame ) 3167 { 3168 Window* pOverlapWindow = mpWindowImpl->mpFirstOverlap; 3169 while ( pOverlapWindow ) 3170 { 3171 Window* pNextOverlapWindow = pOverlapWindow->mpWindowImpl->mpNext; 3172 pOverlapWindow->ImplUpdateOverlapWindowPtr( bNewFrame ); 3173 pOverlapWindow = pNextOverlapWindow; 3174 } 3175 } 3176 3177 if ( bVisible ) 3178 Show( sal_True ); 3179 } 3180 3181 // ----------------------------------------------------------------------- 3182 3183 sal_Bool Window::ImplUpdatePos() 3184 { 3185 sal_Bool bSysChild = sal_False; 3186 3187 if ( ImplIsOverlapWindow() ) 3188 { 3189 mnOutOffX = mpWindowImpl->mnX; 3190 mnOutOffY = mpWindowImpl->mnY; 3191 } 3192 else 3193 { 3194 Window* pParent = ImplGetParent(); 3195 3196 mnOutOffX = mpWindowImpl->mnX + pParent->mnOutOffX; 3197 mnOutOffY = mpWindowImpl->mnY + pParent->mnOutOffY; 3198 } 3199 3200 Window* pChild = mpWindowImpl->mpFirstChild; 3201 while ( pChild ) 3202 { 3203 if ( pChild->ImplUpdatePos() ) 3204 bSysChild = sal_True; 3205 pChild = pChild->mpWindowImpl->mpNext; 3206 } 3207 3208 if ( mpWindowImpl->mpSysObj ) 3209 bSysChild = sal_True; 3210 3211 return bSysChild; 3212 } 3213 3214 // ----------------------------------------------------------------------- 3215 3216 void Window::ImplUpdateSysObjPos() 3217 { 3218 if ( mpWindowImpl->mpSysObj ) 3219 mpWindowImpl->mpSysObj->SetPosSize( mnOutOffX, mnOutOffY, mnOutWidth, mnOutHeight ); 3220 3221 Window* pChild = mpWindowImpl->mpFirstChild; 3222 while ( pChild ) 3223 { 3224 pChild->ImplUpdateSysObjPos(); 3225 pChild = pChild->mpWindowImpl->mpNext; 3226 } 3227 } 3228 // ----------------------------------------------------------------------- 3229 3230 void Window::ImplPosSizeWindow( long nX, long nY, 3231 long nWidth, long nHeight, sal_uInt16 nFlags ) 3232 { 3233 sal_Bool bNewPos = sal_False; 3234 sal_Bool bNewSize = sal_False; 3235 sal_Bool bNewWidth = sal_False; 3236 sal_Bool bCopyBits = sal_False; 3237 long nOldOutOffX = mnOutOffX; 3238 long nOldOutOffY = mnOutOffY; 3239 long nOldOutWidth = mnOutWidth; 3240 long nOldOutHeight = mnOutHeight; 3241 Region* pOverlapRegion = NULL; 3242 Region* pOldRegion = NULL; 3243 3244 if ( IsReallyVisible() ) 3245 { 3246 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 3247 ImplInvalidateAllOverlapBackgrounds(); 3248 3249 Rectangle aOldWinRect( Point( nOldOutOffX, nOldOutOffY ), 3250 Size( nOldOutWidth, nOldOutHeight ) ); 3251 pOldRegion = new Region( aOldWinRect ); 3252 if ( mpWindowImpl->mbWinRegion ) 3253 pOldRegion->Intersect( ImplPixelToDevicePixel( mpWindowImpl->maWinRegion ) ); 3254 3255 if ( mnOutWidth && mnOutHeight && !mpWindowImpl->mbPaintTransparent && 3256 !mpWindowImpl->mbInitWinClipRegion && !mpWindowImpl->maWinClipRegion.IsEmpty() && 3257 !HasPaintEvent() ) 3258 bCopyBits = sal_True; 3259 } 3260 3261 sal_Bool bnXRecycled = sal_False; // avoid duplicate mirroring in RTL case 3262 if ( nFlags & WINDOW_POSSIZE_WIDTH ) 3263 { 3264 if(!( nFlags & WINDOW_POSSIZE_X )) 3265 { 3266 nX = mpWindowImpl->mnX; 3267 nFlags |= WINDOW_POSSIZE_X; 3268 bnXRecycled = sal_True; // we're using a mnX which was already mirrored in RTL case 3269 } 3270 3271 if ( nWidth < 0 ) 3272 nWidth = 0; 3273 if ( nWidth != mnOutWidth ) 3274 { 3275 mnOutWidth = nWidth; 3276 bNewSize = sal_True; 3277 bCopyBits = sal_False; 3278 bNewWidth = sal_True; 3279 } 3280 } 3281 if ( nFlags & WINDOW_POSSIZE_HEIGHT ) 3282 { 3283 if ( nHeight < 0 ) 3284 nHeight = 0; 3285 if ( nHeight != mnOutHeight ) 3286 { 3287 mnOutHeight = nHeight; 3288 bNewSize = sal_True; 3289 bCopyBits = sal_False; 3290 } 3291 } 3292 3293 if ( nFlags & WINDOW_POSSIZE_X ) 3294 { 3295 long nOrgX = nX; 3296 // --- RTL --- (compare the screen coordinates) 3297 Point aPtDev( Point( nX+mnOutOffX, 0 ) ); 3298 if( ImplHasMirroredGraphics() ) 3299 { 3300 mpGraphics->mirror( aPtDev.X(), this ); 3301 3302 // #106948# always mirror our pos if our parent is not mirroring, even 3303 // if we are also not mirroring 3304 // --- RTL --- check if parent is in different coordinates 3305 if( !bnXRecycled && mpWindowImpl->mpParent && !mpWindowImpl->mpParent->mpWindowImpl->mbFrame && mpWindowImpl->mpParent->ImplIsAntiparallel() ) 3306 { 3307 // --- RTL --- (re-mirror at parent window) 3308 nX = mpWindowImpl->mpParent->mnOutWidth - mnOutWidth - nX; 3309 } 3310 /* #i99166# An LTR window in RTL UI that gets sized only would be 3311 expected to not moved its upper left point 3312 */ 3313 if( bnXRecycled ) 3314 { 3315 if( ImplIsAntiparallel() ) 3316 { 3317 aPtDev.X() = mpWindowImpl->mnAbsScreenX; 3318 nOrgX = mpWindowImpl->maPos.X(); 3319 } 3320 } 3321 } 3322 else if( !bnXRecycled && mpWindowImpl->mpParent && !mpWindowImpl->mpParent->mpWindowImpl->mbFrame && mpWindowImpl->mpParent->ImplIsAntiparallel() ) 3323 { 3324 // mirrored window in LTR UI 3325 { 3326 // --- RTL --- (re-mirror at parent window) 3327 nX = mpWindowImpl->mpParent->mnOutWidth - mnOutWidth - nX; 3328 } 3329 } 3330 3331 // check maPos as well, as it could have been changed for client windows (ImplCallMove()) 3332 if ( mpWindowImpl->mnAbsScreenX != aPtDev.X() || nX != mpWindowImpl->mnX || nOrgX != mpWindowImpl->maPos.X() ) 3333 { 3334 if ( bCopyBits && !pOverlapRegion ) 3335 { 3336 pOverlapRegion = new Region(); 3337 ImplCalcOverlapRegion( Rectangle( Point( mnOutOffX, mnOutOffY ), 3338 Size( mnOutWidth, mnOutHeight ) ), 3339 *pOverlapRegion, sal_False, sal_True, sal_True ); 3340 } 3341 mpWindowImpl->mnX = nX; 3342 mpWindowImpl->maPos.X() = nOrgX; 3343 mpWindowImpl->mnAbsScreenX = aPtDev.X(); // --- RTL --- (store real screen pos) 3344 bNewPos = sal_True; 3345 } 3346 } 3347 if ( nFlags & WINDOW_POSSIZE_Y ) 3348 { 3349 // check maPos as well, as it could have been changed for client windows (ImplCallMove()) 3350 if ( nY != mpWindowImpl->mnY || nY != mpWindowImpl->maPos.Y() ) 3351 { 3352 if ( bCopyBits && !pOverlapRegion ) 3353 { 3354 pOverlapRegion = new Region(); 3355 ImplCalcOverlapRegion( Rectangle( Point( mnOutOffX, mnOutOffY ), 3356 Size( mnOutWidth, mnOutHeight ) ), 3357 *pOverlapRegion, sal_False, sal_True, sal_True ); 3358 } 3359 mpWindowImpl->mnY = nY; 3360 mpWindowImpl->maPos.Y() = nY; 3361 bNewPos = sal_True; 3362 } 3363 } 3364 3365 /* if ( nFlags & (WINDOW_POSSIZE_X|WINDOW_POSSIZE_Y) ) 3366 { 3367 POINT aPt; 3368 aPt.x = mpWindowImpl->maPos.X(); 3369 aPt.y = mpWindowImpl->maPos.Y(); 3370 ClientToScreen( mpWindowImpl->mpFrame->maFrameData.mhWnd , &aPt ); 3371 mpWindowImpl->maPos.X() = aPt.x; 3372 mpWindowImpl->maPos.Y() = aPt.y; 3373 } 3374 */ 3375 if ( bNewPos || bNewSize ) 3376 { 3377 sal_Bool bUpdateSysObjPos = sal_False; 3378 if ( bNewPos ) 3379 bUpdateSysObjPos = ImplUpdatePos(); 3380 3381 // the borderwindow always specifies the position for its client window 3382 if ( mpWindowImpl->mpBorderWindow ) 3383 mpWindowImpl->maPos = mpWindowImpl->mpBorderWindow->mpWindowImpl->maPos; 3384 3385 if ( mpWindowImpl->mpClientWindow ) 3386 { 3387 mpWindowImpl->mpClientWindow->ImplPosSizeWindow( mpWindowImpl->mpClientWindow->mpWindowImpl->mnLeftBorder, 3388 mpWindowImpl->mpClientWindow->mpWindowImpl->mnTopBorder, 3389 mnOutWidth-mpWindowImpl->mpClientWindow->mpWindowImpl->mnLeftBorder-mpWindowImpl->mpClientWindow->mpWindowImpl->mnRightBorder, 3390 mnOutHeight-mpWindowImpl->mpClientWindow->mpWindowImpl->mnTopBorder-mpWindowImpl->mpClientWindow->mpWindowImpl->mnBottomBorder, 3391 WINDOW_POSSIZE_X | WINDOW_POSSIZE_Y | 3392 WINDOW_POSSIZE_WIDTH | WINDOW_POSSIZE_HEIGHT ); 3393 // Wenn wir ein ClientWindow haben, dann hat dieses fuer die 3394 // Applikation auch die Position des FloatingWindows 3395 mpWindowImpl->mpClientWindow->mpWindowImpl->maPos = mpWindowImpl->maPos; 3396 if ( bNewPos ) 3397 { 3398 if ( mpWindowImpl->mpClientWindow->IsVisible() ) 3399 { 3400 mpWindowImpl->mpClientWindow->ImplCallMove(); 3401 } 3402 else 3403 { 3404 mpWindowImpl->mpClientWindow->mpWindowImpl->mbCallMove = sal_True; 3405 } 3406 } 3407 } 3408 // else 3409 // { 3410 // if ( mpWindowImpl->mpBorderWindow ) 3411 // mpWindowImpl->maPos = mpWindowImpl->mpBorderWindow->mpWindowImpl->maPos; 3412 // } 3413 3414 // Move()/Resize() werden erst bei Show() gerufen, damit min. eins vor 3415 // einem Show() kommt 3416 if ( IsVisible() ) 3417 { 3418 if ( bNewPos ) 3419 { 3420 ImplCallMove(); 3421 } 3422 if ( bNewSize ) 3423 { 3424 ImplCallResize(); 3425 } 3426 } 3427 else 3428 { 3429 if ( bNewPos ) 3430 mpWindowImpl->mbCallMove = sal_True; 3431 if ( bNewSize ) 3432 mpWindowImpl->mbCallResize = sal_True; 3433 } 3434 3435 sal_Bool bUpdateSysObjClip = sal_False; 3436 if ( IsReallyVisible() ) 3437 { 3438 if ( bNewPos || bNewSize ) 3439 { 3440 // Hintergrund-Sicherung zuruecksetzen 3441 if ( mpWindowImpl->mpOverlapData && mpWindowImpl->mpOverlapData->mpSaveBackDev ) 3442 ImplDeleteOverlapBackground(); 3443 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 3444 ImplInvalidateAllOverlapBackgrounds(); 3445 // Clip-Flag neu setzen 3446 bUpdateSysObjClip = !ImplSetClipFlag( sal_True ); 3447 } 3448 3449 // Fensterinhalt invalidieren ? 3450 if ( bNewPos || (mnOutWidth > nOldOutWidth) || (mnOutHeight > nOldOutHeight) ) 3451 { 3452 if ( bNewPos ) 3453 { 3454 sal_Bool bInvalidate = sal_False; 3455 sal_Bool bParentPaint = sal_True; 3456 if ( !ImplIsOverlapWindow() ) 3457 bParentPaint = mpWindowImpl->mpParent->IsPaintEnabled(); 3458 if ( bCopyBits && bParentPaint && !HasPaintEvent() ) 3459 { 3460 Point aPoint( mnOutOffX, mnOutOffY ); 3461 Region aRegion( Rectangle( aPoint, 3462 Size( mnOutWidth, mnOutHeight ) ) ); 3463 if ( mpWindowImpl->mbWinRegion ) 3464 aRegion.Intersect( ImplPixelToDevicePixel( mpWindowImpl->maWinRegion ) ); 3465 ImplClipBoundaries( aRegion, sal_False, sal_True ); 3466 if ( !pOverlapRegion->IsEmpty() ) 3467 { 3468 pOverlapRegion->Move( mnOutOffX-nOldOutOffX, mnOutOffY-nOldOutOffY ); 3469 aRegion.Exclude( *pOverlapRegion ); 3470 } 3471 if ( !aRegion.IsEmpty() ) 3472 { 3473 // Paint-Bereiche anpassen 3474 ImplMoveAllInvalidateRegions( Rectangle( Point( nOldOutOffX, nOldOutOffY ), 3475 Size( nOldOutWidth, nOldOutHeight ) ), 3476 mnOutOffX-nOldOutOffX, mnOutOffY-nOldOutOffY, 3477 sal_True ); 3478 SalGraphics* pGraphics = ImplGetFrameGraphics(); 3479 if ( pGraphics ) 3480 { 3481 const bool bSelectClipRegion = ImplSelectClipRegion( aRegion, pGraphics ); 3482 if ( bSelectClipRegion ) 3483 { 3484 pGraphics->CopyArea( mnOutOffX, mnOutOffY, 3485 nOldOutOffX, nOldOutOffY, 3486 nOldOutWidth, nOldOutHeight, 3487 SAL_COPYAREA_WINDOWINVALIDATE, this ); 3488 } 3489 else 3490 bInvalidate = sal_True; 3491 } 3492 else 3493 bInvalidate = sal_True; 3494 if ( !bInvalidate ) 3495 { 3496 if ( !pOverlapRegion->IsEmpty() ) 3497 ImplInvalidateFrameRegion( pOverlapRegion, INVALIDATE_CHILDREN ); 3498 } 3499 } 3500 else 3501 bInvalidate = sal_True; 3502 } 3503 else 3504 bInvalidate = sal_True; 3505 if ( bInvalidate ) 3506 ImplInvalidateFrameRegion( NULL, INVALIDATE_CHILDREN ); 3507 } 3508 else 3509 { 3510 Point aPoint( mnOutOffX, mnOutOffY ); 3511 Region aRegion( Rectangle( aPoint, 3512 Size( mnOutWidth, mnOutHeight ) ) ); 3513 aRegion.Exclude( *pOldRegion ); 3514 if ( mpWindowImpl->mbWinRegion ) 3515 aRegion.Intersect( ImplPixelToDevicePixel( mpWindowImpl->maWinRegion ) ); 3516 ImplClipBoundaries( aRegion, sal_False, sal_True ); 3517 if ( !aRegion.IsEmpty() ) 3518 ImplInvalidateFrameRegion( &aRegion, INVALIDATE_CHILDREN ); 3519 } 3520 } 3521 3522 // Parent oder Overlaps invalidieren 3523 if ( bNewPos || 3524 (mnOutWidth < nOldOutWidth) || (mnOutHeight < nOldOutHeight) ) 3525 { 3526 Region aRegion( *pOldRegion ); 3527 if ( !mpWindowImpl->mbPaintTransparent ) 3528 ImplExcludeWindowRegion( aRegion ); 3529 ImplClipBoundaries( aRegion, sal_False, sal_True ); 3530 if ( !aRegion.IsEmpty() && !mpWindowImpl->mpBorderWindow ) 3531 ImplInvalidateParentFrameRegion( aRegion ); 3532 } 3533 } 3534 3535 // System-Objekte anpassen 3536 if ( bUpdateSysObjClip ) 3537 ImplUpdateSysObjClip(); 3538 if ( bUpdateSysObjPos ) 3539 ImplUpdateSysObjPos(); 3540 if ( bNewSize && mpWindowImpl->mpSysObj ) 3541 mpWindowImpl->mpSysObj->SetPosSize( mnOutOffX, mnOutOffY, mnOutWidth, mnOutHeight ); 3542 } 3543 3544 if ( pOverlapRegion ) 3545 delete pOverlapRegion; 3546 if ( pOldRegion ) 3547 delete pOldRegion; 3548 } 3549 3550 // ----------------------------------------------------------------------- 3551 3552 void Window::ImplToBottomChild() 3553 { 3554 if ( !ImplIsOverlapWindow() && !mpWindowImpl->mbReallyVisible && (mpWindowImpl->mpParent->mpWindowImpl->mpLastChild != this) ) 3555 { 3556 // Fenster an das Ende der Liste setzen 3557 if ( mpWindowImpl->mpPrev ) 3558 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = mpWindowImpl->mpNext; 3559 else 3560 mpWindowImpl->mpParent->mpWindowImpl->mpFirstChild = mpWindowImpl->mpNext; 3561 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = mpWindowImpl->mpPrev; 3562 mpWindowImpl->mpPrev = mpWindowImpl->mpParent->mpWindowImpl->mpLastChild; 3563 mpWindowImpl->mpParent->mpWindowImpl->mpLastChild = this; 3564 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = this; 3565 mpWindowImpl->mpNext = NULL; 3566 } 3567 } 3568 3569 // ----------------------------------------------------------------------- 3570 3571 void Window::ImplCalcToTop( ImplCalcToTopData* pPrevData ) 3572 { 3573 DBG_ASSERT( ImplIsOverlapWindow(), "Window::ImplCalcToTop(): Is not a OverlapWindow" ); 3574 3575 if ( !mpWindowImpl->mbFrame ) 3576 { 3577 if ( IsReallyVisible() ) 3578 { 3579 // Region berechnen, wo das Fenster mit anderen Fenstern ueberlappt 3580 Point aPoint( mnOutOffX, mnOutOffY ); 3581 Region aRegion( Rectangle( aPoint, 3582 Size( mnOutWidth, mnOutHeight ) ) ); 3583 Region aInvalidateRegion; 3584 ImplCalcOverlapRegionOverlaps( aRegion, aInvalidateRegion ); 3585 3586 if ( !aInvalidateRegion.IsEmpty() ) 3587 { 3588 ImplCalcToTopData* pData = new ImplCalcToTopData; 3589 pPrevData->mpNext = pData; 3590 pData->mpNext = NULL; 3591 pData->mpWindow = this; 3592 pData->mpInvalidateRegion = new Region( aInvalidateRegion ); 3593 } 3594 } 3595 } 3596 } 3597 3598 // ----------------------------------------------------------------------- 3599 3600 void Window::ImplCalcChildOverlapToTop( ImplCalcToTopData* pPrevData ) 3601 { 3602 DBG_ASSERT( ImplIsOverlapWindow(), "Window::ImplCalcChildOverlapToTop(): Is not a OverlapWindow" ); 3603 3604 ImplCalcToTop( pPrevData ); 3605 if ( pPrevData->mpNext ) 3606 pPrevData = pPrevData->mpNext; 3607 3608 Window* pOverlap = mpWindowImpl->mpFirstOverlap; 3609 while ( pOverlap ) 3610 { 3611 pOverlap->ImplCalcToTop( pPrevData ); 3612 if ( pPrevData->mpNext ) 3613 pPrevData = pPrevData->mpNext; 3614 pOverlap = pOverlap->mpWindowImpl->mpNext; 3615 } 3616 } 3617 3618 // ----------------------------------------------------------------------- 3619 3620 void Window::ImplToTop( sal_uInt16 nFlags ) 3621 { 3622 DBG_ASSERT( ImplIsOverlapWindow(), "Window::ImplToTop(): Is not a OverlapWindow" ); 3623 3624 if ( mpWindowImpl->mbFrame ) 3625 { 3626 // Wenn in das externe Fenster geklickt wird, ist dieses 3627 // dafuer zustaendig dafuer zu sorgen, das unser Frame 3628 // nach vorne kommt 3629 if ( !mpWindowImpl->mpFrameData->mbHasFocus && 3630 !mpWindowImpl->mpFrameData->mbSysObjFocus && 3631 !mpWindowImpl->mpFrameData->mbInSysObjFocusHdl && 3632 !mpWindowImpl->mpFrameData->mbInSysObjToTopHdl ) 3633 { 3634 // do not bring floating windows on the client to top 3635 if( !ImplGetClientWindow() || !(ImplGetClientWindow()->GetStyle() & WB_SYSTEMFLOATWIN) ) 3636 { 3637 sal_uInt16 nSysFlags = 0; 3638 if ( nFlags & TOTOP_RESTOREWHENMIN ) 3639 nSysFlags |= SAL_FRAME_TOTOP_RESTOREWHENMIN; 3640 if ( nFlags & TOTOP_FOREGROUNDTASK ) 3641 nSysFlags |= SAL_FRAME_TOTOP_FOREGROUNDTASK; 3642 if ( nFlags & TOTOP_GRABFOCUSONLY ) 3643 nSysFlags |= SAL_FRAME_TOTOP_GRABFOCUS_ONLY; 3644 mpWindowImpl->mpFrame->ToTop( nSysFlags ); 3645 } 3646 } 3647 } 3648 else 3649 { 3650 if ( mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap != this ) 3651 { 3652 // Fenster aus der Liste entfernen 3653 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = mpWindowImpl->mpNext; 3654 if ( mpWindowImpl->mpNext ) 3655 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = mpWindowImpl->mpPrev; 3656 else 3657 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpLastOverlap = mpWindowImpl->mpPrev; 3658 3659 // AlwaysOnTop beruecksichtigen 3660 sal_Bool bOnTop = IsAlwaysOnTopEnabled(); 3661 Window* pNextWin = mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap; 3662 if ( !bOnTop ) 3663 { 3664 while ( pNextWin ) 3665 { 3666 if ( !pNextWin->IsAlwaysOnTopEnabled() ) 3667 break; 3668 pNextWin = pNextWin->mpWindowImpl->mpNext; 3669 } 3670 } 3671 3672 // TopLevel abpruefen 3673 sal_uInt8 nTopLevel = mpWindowImpl->mpOverlapData->mnTopLevel; 3674 while ( pNextWin ) 3675 { 3676 if ( (bOnTop != pNextWin->IsAlwaysOnTopEnabled()) || 3677 (nTopLevel <= pNextWin->mpWindowImpl->mpOverlapData->mnTopLevel) ) 3678 break; 3679 pNextWin = pNextWin->mpWindowImpl->mpNext; 3680 } 3681 3682 // Fenster in die Liste wieder eintragen 3683 mpWindowImpl->mpNext = pNextWin; 3684 if ( pNextWin ) 3685 { 3686 mpWindowImpl->mpPrev = pNextWin->mpWindowImpl->mpPrev; 3687 pNextWin->mpWindowImpl->mpPrev = this; 3688 } 3689 else 3690 { 3691 mpWindowImpl->mpPrev = mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpLastOverlap; 3692 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpLastOverlap = this; 3693 } 3694 if ( mpWindowImpl->mpPrev ) 3695 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = this; 3696 else 3697 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap = this; 3698 3699 // ClipRegion muss von diesem Fenster und allen weiteren 3700 // ueberlappenden Fenstern neu berechnet werden. 3701 if ( IsReallyVisible() ) 3702 { 3703 // Hintergrund-Sicherung zuruecksetzen 3704 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 3705 ImplInvalidateAllOverlapBackgrounds(); 3706 mpWindowImpl->mpOverlapWindow->ImplSetClipFlagOverlapWindows(); 3707 } 3708 } 3709 } 3710 } 3711 3712 // ----------------------------------------------------------------------- 3713 3714 void Window::ImplStartToTop( sal_uInt16 nFlags ) 3715 { 3716 ImplCalcToTopData aStartData; 3717 ImplCalcToTopData* pCurData; 3718 ImplCalcToTopData* pNextData; 3719 Window* pOverlapWindow; 3720 if ( ImplIsOverlapWindow() ) 3721 pOverlapWindow = this; 3722 else 3723 pOverlapWindow = mpWindowImpl->mpOverlapWindow; 3724 3725 // Zuerst die Paint-Bereiche berechnen 3726 Window* pTempOverlapWindow = pOverlapWindow; 3727 aStartData.mpNext = NULL; 3728 pCurData = &aStartData; 3729 do 3730 { 3731 pTempOverlapWindow->ImplCalcToTop( pCurData ); 3732 if ( pCurData->mpNext ) 3733 pCurData = pCurData->mpNext; 3734 pTempOverlapWindow = pTempOverlapWindow->mpWindowImpl->mpOverlapWindow; 3735 } 3736 while ( !pTempOverlapWindow->mpWindowImpl->mbFrame ); 3737 // Dann die Paint-Bereiche der ChildOverlap-Windows berechnen 3738 pTempOverlapWindow = mpWindowImpl->mpFirstOverlap; 3739 while ( pTempOverlapWindow ) 3740 { 3741 pTempOverlapWindow->ImplCalcToTop( pCurData ); 3742 if ( pCurData->mpNext ) 3743 pCurData = pCurData->mpNext; 3744 pTempOverlapWindow = pTempOverlapWindow->mpWindowImpl->mpNext; 3745 } 3746 3747 // Dann die Fenster-Verkettung aendern 3748 pTempOverlapWindow = pOverlapWindow; 3749 do 3750 { 3751 pTempOverlapWindow->ImplToTop( nFlags ); 3752 pTempOverlapWindow = pTempOverlapWindow->mpWindowImpl->mpOverlapWindow; 3753 } 3754 while ( !pTempOverlapWindow->mpWindowImpl->mbFrame ); 3755 // Und zum Schluss invalidieren wir die ungueltigen Bereiche 3756 pCurData = aStartData.mpNext; 3757 while ( pCurData ) 3758 { 3759 pCurData->mpWindow->ImplInvalidateFrameRegion( pCurData->mpInvalidateRegion, INVALIDATE_CHILDREN ); 3760 pNextData = pCurData->mpNext; 3761 delete pCurData->mpInvalidateRegion; 3762 delete pCurData; 3763 pCurData = pNextData; 3764 } 3765 } 3766 3767 // ----------------------------------------------------------------------- 3768 3769 void Window::ImplFocusToTop( sal_uInt16 nFlags, sal_Bool bReallyVisible ) 3770 { 3771 // Soll Focus auch geholt werden? 3772 if ( !(nFlags & TOTOP_NOGRABFOCUS) ) 3773 { 3774 // Erstes Fenster mit GrabFocus-Activate bekommt den Focus 3775 Window* pFocusWindow = this; 3776 while ( !pFocusWindow->ImplIsOverlapWindow() ) 3777 { 3778 // Nur wenn Fenster kein Border-Fenster hat, da wir 3779 // immer das dazugehoerende BorderFenster finden wollen 3780 if ( !pFocusWindow->mpWindowImpl->mpBorderWindow ) 3781 { 3782 if ( pFocusWindow->mpWindowImpl->mnActivateMode & ACTIVATE_MODE_GRABFOCUS ) 3783 break; 3784 } 3785 pFocusWindow = pFocusWindow->ImplGetParent(); 3786 } 3787 if ( (pFocusWindow->mpWindowImpl->mnActivateMode & ACTIVATE_MODE_GRABFOCUS) && 3788 !pFocusWindow->HasChildPathFocus( sal_True ) ) 3789 pFocusWindow->GrabFocus(); 3790 } 3791 3792 if ( bReallyVisible ) 3793 ImplGenerateMouseMove(); 3794 } 3795 3796 // ----------------------------------------------------------------------- 3797 3798 void Window::ImplShowAllOverlaps() 3799 { 3800 Window* pOverlapWindow = mpWindowImpl->mpFirstOverlap; 3801 while ( pOverlapWindow ) 3802 { 3803 if ( pOverlapWindow->mpWindowImpl->mbOverlapVisible ) 3804 { 3805 pOverlapWindow->Show( sal_True, SHOW_NOACTIVATE ); 3806 pOverlapWindow->mpWindowImpl->mbOverlapVisible = sal_False; 3807 } 3808 3809 pOverlapWindow = pOverlapWindow->mpWindowImpl->mpNext; 3810 } 3811 } 3812 3813 // ----------------------------------------------------------------------- 3814 3815 void Window::ImplHideAllOverlaps() 3816 { 3817 Window* pOverlapWindow = mpWindowImpl->mpFirstOverlap; 3818 while ( pOverlapWindow ) 3819 { 3820 if ( pOverlapWindow->IsVisible() ) 3821 { 3822 pOverlapWindow->mpWindowImpl->mbOverlapVisible = sal_True; 3823 pOverlapWindow->Show( sal_False ); 3824 } 3825 3826 pOverlapWindow = pOverlapWindow->mpWindowImpl->mpNext; 3827 } 3828 } 3829 3830 // ----------------------------------------------------------------------- 3831 3832 void Window::ImplCallMouseMove( sal_uInt16 nMouseCode, sal_Bool bModChanged ) 3833 { 3834 if ( mpWindowImpl->mpFrameData->mbMouseIn && mpWindowImpl->mpFrameWindow->mpWindowImpl->mbReallyVisible ) 3835 { 3836 sal_uLong nTime = Time::GetSystemTicks(); 3837 long nX = mpWindowImpl->mpFrameData->mnLastMouseX; 3838 long nY = mpWindowImpl->mpFrameData->mnLastMouseY; 3839 sal_uInt16 nCode = nMouseCode; 3840 sal_uInt16 nMode = mpWindowImpl->mpFrameData->mnMouseMode; 3841 sal_Bool bLeave; 3842 // Auf MouseLeave testen 3843 if ( ((nX < 0) || (nY < 0) || 3844 (nX >= mpWindowImpl->mpFrameWindow->mnOutWidth) || 3845 (nY >= mpWindowImpl->mpFrameWindow->mnOutHeight)) && 3846 !ImplGetSVData()->maWinData.mpCaptureWin ) 3847 bLeave = sal_True; 3848 else 3849 bLeave = sal_False; 3850 nMode |= MOUSE_SYNTHETIC; 3851 if ( bModChanged ) 3852 nMode |= MOUSE_MODIFIERCHANGED; 3853 ImplHandleMouseEvent( mpWindowImpl->mpFrameWindow, EVENT_MOUSEMOVE, bLeave, nX, nY, nTime, nCode, nMode ); 3854 } 3855 } 3856 3857 // ----------------------------------------------------------------------- 3858 3859 void Window::ImplGenerateMouseMove() 3860 { 3861 if ( !mpWindowImpl->mpFrameData->mnMouseMoveId ) 3862 Application::PostUserEvent( mpWindowImpl->mpFrameData->mnMouseMoveId, LINK( mpWindowImpl->mpFrameWindow, Window, ImplGenerateMouseMoveHdl ) ); 3863 } 3864 3865 // ----------------------------------------------------------------------- 3866 3867 IMPL_LINK( Window, ImplGenerateMouseMoveHdl, void*, EMPTYARG ) 3868 { 3869 mpWindowImpl->mpFrameData->mnMouseMoveId = 0; 3870 Window* pCaptureWin = ImplGetSVData()->maWinData.mpCaptureWin; 3871 if( ! pCaptureWin || 3872 (pCaptureWin->mpWindowImpl && pCaptureWin->mpWindowImpl->mpFrame == mpWindowImpl->mpFrame) 3873 ) 3874 { 3875 ImplCallMouseMove( mpWindowImpl->mpFrameData->mnMouseCode ); 3876 } 3877 return 0; 3878 } 3879 3880 // ----------------------------------------------------------------------- 3881 3882 void Window::ImplInvertFocus( const Rectangle& rRect ) 3883 { 3884 InvertTracking( rRect, SHOWTRACK_SMALL | SHOWTRACK_WINDOW ); 3885 } 3886 3887 // ----------------------------------------------------------------------- 3888 3889 void Window::ImplCallFocusChangeActivate( Window* pNewOverlapWindow, 3890 Window* pOldOverlapWindow ) 3891 { 3892 ImplSVData* pSVData = ImplGetSVData(); 3893 Window* pNewRealWindow; 3894 Window* pOldRealWindow; 3895 Window* pLastRealWindow; 3896 sal_Bool bCallActivate = sal_True; 3897 sal_Bool bCallDeactivate = sal_True; 3898 3899 pOldRealWindow = pOldOverlapWindow->ImplGetWindow(); 3900 pNewRealWindow = pNewOverlapWindow->ImplGetWindow(); 3901 if ( (pOldRealWindow->GetType() != WINDOW_FLOATINGWINDOW) || 3902 pOldRealWindow->GetActivateMode() ) 3903 { 3904 if ( (pNewRealWindow->GetType() == WINDOW_FLOATINGWINDOW) && 3905 !pNewRealWindow->GetActivateMode() ) 3906 { 3907 pSVData->maWinData.mpLastDeacWin = pOldOverlapWindow; 3908 bCallDeactivate = sal_False; 3909 } 3910 } 3911 else if ( (pNewRealWindow->GetType() != WINDOW_FLOATINGWINDOW) || 3912 pNewRealWindow->GetActivateMode() ) 3913 { 3914 if ( pSVData->maWinData.mpLastDeacWin ) 3915 { 3916 if ( pSVData->maWinData.mpLastDeacWin == pNewOverlapWindow ) 3917 bCallActivate = sal_False; 3918 else 3919 { 3920 pLastRealWindow = pSVData->maWinData.mpLastDeacWin->ImplGetWindow(); 3921 pSVData->maWinData.mpLastDeacWin->mpWindowImpl->mbActive = sal_False; 3922 pSVData->maWinData.mpLastDeacWin->Deactivate(); 3923 if ( pLastRealWindow != pSVData->maWinData.mpLastDeacWin ) 3924 { 3925 pLastRealWindow->mpWindowImpl->mbActive = sal_True; 3926 pLastRealWindow->Activate(); 3927 } 3928 } 3929 pSVData->maWinData.mpLastDeacWin = NULL; 3930 } 3931 } 3932 3933 if ( bCallDeactivate ) 3934 { 3935 if( pOldOverlapWindow->mpWindowImpl->mbActive ) 3936 { 3937 pOldOverlapWindow->mpWindowImpl->mbActive = sal_False; 3938 pOldOverlapWindow->Deactivate(); 3939 } 3940 if ( pOldRealWindow != pOldOverlapWindow ) 3941 { 3942 if( pOldRealWindow->mpWindowImpl->mbActive ) 3943 { 3944 pOldRealWindow->mpWindowImpl->mbActive = sal_False; 3945 pOldRealWindow->Deactivate(); 3946 } 3947 } 3948 } 3949 if ( bCallActivate && ! pNewOverlapWindow->mpWindowImpl->mbActive ) 3950 { 3951 if( ! pNewOverlapWindow->mpWindowImpl->mbActive ) 3952 { 3953 pNewOverlapWindow->mpWindowImpl->mbActive = sal_True; 3954 pNewOverlapWindow->Activate(); 3955 } 3956 if ( pNewRealWindow != pNewOverlapWindow ) 3957 { 3958 if( ! pNewRealWindow->mpWindowImpl->mbActive ) 3959 { 3960 pNewRealWindow->mpWindowImpl->mbActive = sal_True; 3961 pNewRealWindow->Activate(); 3962 } 3963 } 3964 } 3965 } 3966 3967 static bool IsWindowFocused(const WindowImpl& rWinImpl) 3968 { 3969 if (rWinImpl.mpSysObj) 3970 return true; 3971 3972 if (rWinImpl.mpFrameData->mbHasFocus) 3973 return true; 3974 3975 if (rWinImpl.mbFakeFocusSet) 3976 return true; 3977 3978 return false; 3979 } 3980 3981 // ----------------------------------------------------------------------- 3982 void Window::ImplGrabFocus( sal_uInt16 nFlags ) 3983 { 3984 // #143570# no focus for destructing windows 3985 if( mpWindowImpl->mbInDtor ) 3986 return; 3987 3988 // some event listeners do really bad stuff 3989 // => prepare for the worst 3990 ImplDelData aDogTag( this ); 3991 3992 // Currently the client window should always get the focus 3993 // Should the border window at some point be focusable 3994 // we need to change all GrabFocus() instances in VCL, 3995 // e.g. in ToTop() 3996 3997 if ( mpWindowImpl->mpClientWindow ) 3998 { 3999 // For a lack of design we need a little hack here to 4000 // ensure that dialogs on close pass the focus back to 4001 // the correct window 4002 if ( mpWindowImpl->mpLastFocusWindow && (mpWindowImpl->mpLastFocusWindow != this) && 4003 !(mpWindowImpl->mnDlgCtrlFlags & WINDOW_DLGCTRL_WANTFOCUS) && 4004 mpWindowImpl->mpLastFocusWindow->IsEnabled() && 4005 mpWindowImpl->mpLastFocusWindow->IsInputEnabled() && 4006 ! mpWindowImpl->mpLastFocusWindow->IsInModalMode() 4007 ) 4008 mpWindowImpl->mpLastFocusWindow->GrabFocus(); 4009 else 4010 mpWindowImpl->mpClientWindow->GrabFocus(); 4011 return; 4012 } 4013 else if ( mpWindowImpl->mbFrame ) 4014 { 4015 // For a lack of design we need a little hack here to 4016 // ensure that dialogs on close pass the focus back to 4017 // the correct window 4018 if ( mpWindowImpl->mpLastFocusWindow && (mpWindowImpl->mpLastFocusWindow != this) && 4019 !(mpWindowImpl->mnDlgCtrlFlags & WINDOW_DLGCTRL_WANTFOCUS) && 4020 mpWindowImpl->mpLastFocusWindow->IsEnabled() && 4021 mpWindowImpl->mpLastFocusWindow->IsInputEnabled() && 4022 ! mpWindowImpl->mpLastFocusWindow->IsInModalMode() 4023 ) 4024 { 4025 mpWindowImpl->mpLastFocusWindow->GrabFocus(); 4026 return; 4027 } 4028 } 4029 4030 // If the Window is disabled, then we don't change the focus 4031 if ( !IsEnabled() || !IsInputEnabled() || IsInModalMode() ) 4032 return; 4033 4034 // we only need to set the focus if it is not already set 4035 // note: if some other frame is waiting for an asynchrounous focus event 4036 // we also have to post an asynchronous focus event for this frame 4037 // which is done using ToTop 4038 ImplSVData* pSVData = ImplGetSVData(); 4039 4040 sal_Bool bAsyncFocusWaiting = sal_False; 4041 Window *pFrame = pSVData->maWinData.mpFirstFrame; 4042 while( pFrame ) 4043 { 4044 if( pFrame != mpWindowImpl->mpFrameWindow && pFrame->mpWindowImpl->mpFrameData->mnFocusId ) 4045 { 4046 bAsyncFocusWaiting = sal_True; 4047 break; 4048 } 4049 pFrame = pFrame->mpWindowImpl->mpFrameData->mpNextFrame; 4050 } 4051 4052 bool bHasFocus = IsWindowFocused(*mpWindowImpl); 4053 4054 sal_Bool bMustNotGrabFocus = sal_False; 4055 // #100242#, check parent hierarchy if some floater prohibits grab focus 4056 4057 Window *pParent = this; 4058 while( pParent ) 4059 { 4060 // #102158#, ignore grabfocus only if the floating parent grabs keyboard focus by itself (GrabsFocus()) 4061 // otherwise we cannot set the focus in a floating toolbox 4062 if( ( (pParent->mpWindowImpl->mbFloatWin && ((FloatingWindow*)pParent)->GrabsFocus()) || ( pParent->GetStyle() & WB_SYSTEMFLOATWIN ) ) && !( pParent->GetStyle() & WB_MOVEABLE ) ) 4063 { 4064 bMustNotGrabFocus = sal_True; 4065 break; 4066 } 4067 pParent = pParent->mpWindowImpl->mpParent; 4068 } 4069 4070 4071 if ( ( pSVData->maWinData.mpFocusWin != this && ! mpWindowImpl->mbInDtor ) || ( bAsyncFocusWaiting && !bHasFocus && !bMustNotGrabFocus ) ) 4072 { 4073 // EndExtTextInput if it is not the same window 4074 if ( pSVData->maWinData.mpExtTextInputWin && 4075 (pSVData->maWinData.mpExtTextInputWin != this) ) 4076 pSVData->maWinData.mpExtTextInputWin->EndExtTextInput( EXTTEXTINPUT_END_COMPLETE ); 4077 4078 // Dieses Fenster als letztes FocusWindow merken 4079 Window* pOverlapWindow = ImplGetFirstOverlapWindow(); 4080 pOverlapWindow->mpWindowImpl->mpLastFocusWindow = this; 4081 mpWindowImpl->mpFrameData->mpFocusWin = this; 4082 4083 if( !bHasFocus ) 4084 { 4085 // menue windows never get the system focus 4086 // the application will keep the focus 4087 if( bMustNotGrabFocus ) 4088 return; 4089 else 4090 { 4091 // Hier setzen wir schon den Focus um, da ToTop() den Focus 4092 // nicht auf ein anderes Fenster setzen darf 4093 //DBG_WARNING( "Window::GrabFocus() - Frame doesn't have the focus" ); 4094 mpWindowImpl->mpFrame->ToTop( SAL_FRAME_TOTOP_GRABFOCUS | SAL_FRAME_TOTOP_GRABFOCUS_ONLY ); 4095 return; 4096 } 4097 } 4098 4099 Window* pOldFocusWindow = pSVData->maWinData.mpFocusWin; 4100 ImplDelData aOldFocusDel( pOldFocusWindow ); 4101 4102 pSVData->maWinData.mpFocusWin = this; 4103 4104 if ( pOldFocusWindow ) 4105 { 4106 // Cursor hiden 4107 if ( pOldFocusWindow->mpWindowImpl->mpCursor ) 4108 pOldFocusWindow->mpWindowImpl->mpCursor->ImplHide( true ); 4109 } 4110 4111 // !!!!! Wegen altem SV-Office Activate/Deavtivate Handling 4112 // !!!!! erstmal so wie frueher 4113 if ( pOldFocusWindow ) 4114 { 4115 // Focus merken 4116 Window* pOldOverlapWindow = pOldFocusWindow->ImplGetFirstOverlapWindow(); 4117 Window* pNewOverlapWindow = ImplGetFirstOverlapWindow(); 4118 if ( pOldOverlapWindow != pNewOverlapWindow ) 4119 ImplCallFocusChangeActivate( pNewOverlapWindow, pOldOverlapWindow ); 4120 } 4121 else 4122 { 4123 Window* pNewOverlapWindow = ImplGetFirstOverlapWindow(); 4124 Window* pNewRealWindow = pNewOverlapWindow->ImplGetWindow(); 4125 pNewOverlapWindow->mpWindowImpl->mbActive = sal_True; 4126 pNewOverlapWindow->Activate(); 4127 if ( pNewRealWindow != pNewOverlapWindow ) 4128 { 4129 pNewRealWindow->mpWindowImpl->mbActive = sal_True; 4130 pNewRealWindow->Activate(); 4131 } 4132 } 4133 /* 4134 // call Deactivate and Activate 4135 Window* pDeactivateParent; 4136 Window* pActivateParent; 4137 Window* pParent; 4138 Window* pLastParent; 4139 pDeactivateParent = pOldFocusWindow; 4140 while ( pDeactivateParent ) 4141 { 4142 pParent = pDeactivateParent; 4143 if ( pParent->ImplIsChild( this ) ) 4144 break; 4145 4146 if ( pDeactivateParent->ImplIsOverlapWindow() ) 4147 { 4148 if ( !pDeactivateParent->mpWindowImpl->mbParentActive ) 4149 break; 4150 } 4151 4152 pDeactivateParent = pDeactivateParent->ImplGetParent(); 4153 } 4154 if ( pOldFocusWindow ) 4155 { 4156 pActivateParent = this; 4157 while ( pActivateParent ) 4158 { 4159 pParent = pActivateParent; 4160 if ( pParent->ImplIsChild( pOldFocusWindow ) ) 4161 break; 4162 4163 if ( pActivateParent->ImplIsOverlapWindow() ) 4164 { 4165 if ( !pActivateParent->mpWindowImpl->mbParentActive ) 4166 break; 4167 } 4168 4169 pActivateParent = pActivateParent->ImplGetParent(); 4170 } 4171 } 4172 else 4173 { 4174 if ( ImplIsOverlapWindow() ) 4175 pActivateParent = this; 4176 else 4177 pActivateParent = mpWindowImpl->mpOverlapWindow; 4178 while ( pActivateParent ) 4179 { 4180 if ( pActivateParent->ImplIsOverlapWindow() ) 4181 { 4182 if ( !pActivateParent->mpWindowImpl->mbParentActive ) 4183 break; 4184 } 4185 4186 pActivateParent = pActivateParent->ImplGetParent(); 4187 } 4188 } 4189 if ( pDeactivateParent ) 4190 { 4191 do 4192 { 4193 pLastParent = pOldFocusWindow; 4194 if ( pLastParent != pDeactivateParent ) 4195 { 4196 pParent = pLastParent->ImplGetParent(); 4197 while ( pParent ) 4198 { 4199 if ( pParent == pDeactivateParent ) 4200 break; 4201 pLastParent = pParent; 4202 pParent = pParent->ImplGetParent(); 4203 } 4204 } 4205 else 4206 pParent = pLastParent; 4207 4208 pParent->mpWindowImpl->mbActive = sal_False; 4209 pParent->Deactivate(); 4210 pDeactivateParent = pLastParent; 4211 } 4212 while ( pDeactivateParent != pOldFocusWindow ); 4213 } 4214 do 4215 { 4216 pLastParent = this; 4217 if ( pLastParent != pActivateParent ) 4218 { 4219 pParent = pLastParent->ImplGetParent(); 4220 while ( pParent ) 4221 { 4222 if ( pParent == pActivateParent ) 4223 break; 4224 pLastParent = pParent; 4225 pParent = pParent->ImplGetParent(); 4226 } 4227 } 4228 else 4229 pParent = pLastParent; 4230 4231 pParent->mpWindowImpl->mbActive = sal_True; 4232 pParent->Activate(); 4233 pActivateParent = pLastParent; 4234 } 4235 while ( pActivateParent != this ); 4236 */ 4237 // call Get- and LoseFocus 4238 if ( pOldFocusWindow && ! aOldFocusDel.IsDelete() ) 4239 { 4240 if ( pOldFocusWindow->IsTracking() && 4241 (pSVData->maWinData.mnTrackFlags & STARTTRACK_FOCUSCANCEL) ) 4242 pOldFocusWindow->EndTracking( ENDTRACK_CANCEL | ENDTRACK_FOCUS ); 4243 NotifyEvent aNEvt( EVENT_LOSEFOCUS, pOldFocusWindow ); 4244 if ( !ImplCallPreNotify( aNEvt ) ) 4245 pOldFocusWindow->LoseFocus(); 4246 pOldFocusWindow->ImplCallDeactivateListeners( this ); 4247 } 4248 4249 if ( pSVData->maWinData.mpFocusWin == this ) 4250 { 4251 if ( mpWindowImpl->mpSysObj ) 4252 { 4253 mpWindowImpl->mpFrameData->mpFocusWin = this; 4254 if ( !mpWindowImpl->mpFrameData->mbInSysObjFocusHdl ) 4255 mpWindowImpl->mpSysObj->GrabFocus(); 4256 } 4257 4258 if ( pSVData->maWinData.mpFocusWin == this ) 4259 { 4260 if ( mpWindowImpl->mpCursor ) 4261 mpWindowImpl->mpCursor->ImplShow(); 4262 mpWindowImpl->mbInFocusHdl = sal_True; 4263 mpWindowImpl->mnGetFocusFlags = nFlags; 4264 // if we're changing focus due to closing a popup floating window 4265 // notify the new focus window so it can restore the inner focus 4266 // eg, toolboxes can select their recent active item 4267 if( pOldFocusWindow && 4268 ! aOldFocusDel.IsDelete() && 4269 ( pOldFocusWindow->GetDialogControlFlags() & WINDOW_DLGCTRL_FLOATWIN_POPUPMODEEND_CANCEL ) ) 4270 mpWindowImpl->mnGetFocusFlags |= GETFOCUS_FLOATWIN_POPUPMODEEND_CANCEL; 4271 NotifyEvent aNEvt( EVENT_GETFOCUS, this ); 4272 if ( !ImplCallPreNotify( aNEvt ) && !aDogTag.IsDelete() ) 4273 GetFocus(); 4274 if( !aDogTag.IsDelete() ) 4275 ImplCallActivateListeners( (pOldFocusWindow && ! aOldFocusDel.IsDelete()) ? pOldFocusWindow : NULL ); 4276 if( !aDogTag.IsDelete() ) 4277 { 4278 mpWindowImpl->mnGetFocusFlags = 0; 4279 mpWindowImpl->mbInFocusHdl = sal_False; 4280 } 4281 } 4282 } 4283 4284 GetpApp()->FocusChanged(); 4285 ImplNewInputContext(); 4286 } 4287 } 4288 4289 // ----------------------------------------------------------------------- 4290 4291 void Window::ImplNewInputContext() 4292 { 4293 ImplSVData* pSVData = ImplGetSVData(); 4294 Window* pFocusWin = pSVData->maWinData.mpFocusWin; 4295 if ( !pFocusWin ) 4296 return; 4297 4298 // Is InputContext changed? 4299 const InputContext& rInputContext = pFocusWin->GetInputContext(); 4300 if ( rInputContext == pFocusWin->mpWindowImpl->mpFrameData->maOldInputContext ) 4301 return; 4302 4303 pFocusWin->mpWindowImpl->mpFrameData->maOldInputContext = rInputContext; 4304 4305 SalInputContext aNewContext; 4306 const Font& rFont = rInputContext.GetFont(); 4307 const XubString& rFontName = rFont.GetName(); 4308 ImplFontEntry* pFontEntry = NULL; 4309 aNewContext.mpFont = NULL; 4310 if ( rFontName.Len() ) 4311 { 4312 Size aSize = pFocusWin->ImplLogicToDevicePixel( rFont.GetSize() ); 4313 if ( !aSize.Height() ) 4314 { 4315 // Nur dann Defaultgroesse setzen, wenn Fonthoehe auch in logischen 4316 // Koordinaaten 0 ist 4317 if ( rFont.GetSize().Height() ) 4318 aSize.Height() = 1; 4319 else 4320 aSize.Height() = (12*pFocusWin->mnDPIY)/72; 4321 } 4322 // TODO: No display device uses ImplDirectFontSubstitution thingy, right? => remove it 4323 ImplDirectFontSubstitution* pFontSubst = NULL; 4324 //if( pFocusWin->mpOutDevData ) 4325 // pFontSubst = &pFocusWin->mpOutDevData->maDevFontSubst; 4326 pFontEntry = pFocusWin->mpFontCache->GetFontEntry( pFocusWin->mpFontList, 4327 rFont, aSize, static_cast<float>(aSize.Height()), pFontSubst ); 4328 if ( pFontEntry ) 4329 aNewContext.mpFont = &pFontEntry->maFontSelData; 4330 } 4331 aNewContext.meLanguage = rFont.GetLanguage(); 4332 aNewContext.mnOptions = rInputContext.GetOptions(); 4333 pFocusWin->ImplGetFrame()->SetInputContext( &aNewContext ); 4334 4335 if ( pFontEntry ) 4336 pFocusWin->mpFontCache->Release( pFontEntry ); 4337 } 4338 4339 // ----------------------------------------------------------------------- 4340 4341 Window::Window( WindowType nType ) 4342 { 4343 DBG_CTOR( Window, ImplDbgCheckWindow ); 4344 4345 ImplInitWindowData( nType ); 4346 } 4347 4348 // ----------------------------------------------------------------------- 4349 4350 Window::Window( Window* pParent, WinBits nStyle ) 4351 { 4352 DBG_CTOR( Window, ImplDbgCheckWindow ); 4353 4354 ImplInitWindowData( WINDOW_WINDOW ); 4355 ImplInit( pParent, nStyle, NULL ); 4356 } 4357 4358 // ----------------------------------------------------------------------- 4359 4360 Window::Window( Window* pParent, const ResId& rResId ) 4361 { 4362 DBG_CTOR( Window, ImplDbgCheckWindow ); 4363 4364 ImplInitWindowData( WINDOW_WINDOW ); 4365 rResId.SetRT( RSC_WINDOW ); 4366 WinBits nStyle = ImplInitRes( rResId ); 4367 ImplInit( pParent, nStyle, NULL ); 4368 ImplLoadRes( rResId ); 4369 4370 if ( !(nStyle & WB_HIDE) ) 4371 Show(); 4372 } 4373 4374 // ----------------------------------------------------------------------- 4375 #if OSL_DEBUG_LEVEL > 0 4376 namespace 4377 { 4378 void lcl_appendWindowInfo( ByteString& io_rErrorString, const Window& i_rWindow ) 4379 { 4380 // skip border windows, they don't carry information which helps diagnosing the problem 4381 const Window* pWindow( &i_rWindow ); 4382 while ( pWindow && ( pWindow->GetType() == WINDOW_BORDERWINDOW ) ) 4383 pWindow = pWindow->GetWindow( WINDOW_FIRSTCHILD ); 4384 if ( !pWindow ) 4385 pWindow = &i_rWindow; 4386 4387 io_rErrorString += char(13); 4388 io_rErrorString += typeid( *pWindow ).name(); 4389 io_rErrorString += " (window text: '"; 4390 io_rErrorString += ByteString( pWindow->GetText(), RTL_TEXTENCODING_UTF8 ); 4391 io_rErrorString += "')"; 4392 } 4393 } 4394 #endif 4395 // ----------------------------------------------------------------------- 4396 4397 Window::~Window() 4398 { 4399 ImplFreeExtWindowImpl(); 4400 4401 vcl::LazyDeletor<Window>::Undelete( this ); 4402 4403 DBG_DTOR( Window, ImplDbgCheckWindow ); 4404 DBG_ASSERT( !mpWindowImpl->mbInDtor, "~Window - already in DTOR!" ); 4405 4406 4407 // remove Key and Mouse events issued by Application::PostKey/MouseEvent 4408 Application::RemoveMouseAndKeyEvents( this ); 4409 4410 // Dispose of the canvas implementation (which, currently, has an 4411 // own wrapper window as a child to this one. 4412 uno::Reference< rendering::XCanvas > xCanvas( mpWindowImpl->mxCanvas ); 4413 if( xCanvas.is() ) 4414 { 4415 uno::Reference < lang::XComponent > xCanvasComponent( xCanvas, 4416 uno::UNO_QUERY ); 4417 if( xCanvasComponent.is() ) 4418 xCanvasComponent->dispose(); 4419 } 4420 4421 mpWindowImpl->mbInDtor = sal_True; 4422 4423 ImplCallEventListeners( VCLEVENT_OBJECT_DYING ); 4424 4425 // do not send child events for frames that were registered as native frames 4426 if( !ImplIsAccessibleNativeFrame() && mpWindowImpl->mbReallyVisible ) 4427 if ( ImplIsAccessibleCandidate() && GetAccessibleParentWindow() ) 4428 GetAccessibleParentWindow()->ImplCallEventListeners( VCLEVENT_WINDOW_CHILDDESTROYED, this ); 4429 4430 // remove associated data structures from dockingmanager 4431 ImplGetDockingManager()->RemoveWindow( this ); 4432 4433 4434 // remove ownerdraw decorated windows from list in the top-most frame window 4435 if( (GetStyle() & WB_OWNERDRAWDECORATION) && mpWindowImpl->mbFrame ) 4436 { 4437 ::std::vector< Window* >& rList = ImplGetOwnerDrawList(); 4438 ::std::vector< Window* >::iterator p; 4439 p = ::std::find( rList.begin(), rList.end(), this ); 4440 if( p != rList.end() ) 4441 rList.erase( p ); 4442 } 4443 4444 // shutdown drag and drop 4445 ::com::sun::star::uno::Reference < ::com::sun::star::lang::XComponent > xDnDComponent( mpWindowImpl->mxDNDListenerContainer, ::com::sun::star::uno::UNO_QUERY ); 4446 4447 if( xDnDComponent.is() ) 4448 xDnDComponent->dispose(); 4449 4450 if( mpWindowImpl->mbFrame && mpWindowImpl->mpFrameData ) 4451 { 4452 try 4453 { 4454 // deregister drop target listener 4455 if( mpWindowImpl->mpFrameData->mxDropTargetListener.is() ) 4456 { 4457 uno::Reference< XDragGestureRecognizer > xDragGestureRecognizer = 4458 uno::Reference< XDragGestureRecognizer > (mpWindowImpl->mpFrameData->mxDragSource, UNO_QUERY); 4459 if( xDragGestureRecognizer.is() ) 4460 { 4461 xDragGestureRecognizer->removeDragGestureListener( 4462 uno::Reference< XDragGestureListener > (mpWindowImpl->mpFrameData->mxDropTargetListener, UNO_QUERY)); 4463 } 4464 4465 mpWindowImpl->mpFrameData->mxDropTarget->removeDropTargetListener( mpWindowImpl->mpFrameData->mxDropTargetListener ); 4466 mpWindowImpl->mpFrameData->mxDropTargetListener.clear(); 4467 } 4468 4469 // shutdown drag and drop for this frame window 4470 uno::Reference< XComponent > xComponent( mpWindowImpl->mpFrameData->mxDropTarget, UNO_QUERY ); 4471 4472 // DNDEventDispatcher does not hold a reference of the DropTarget, 4473 // so it's ok if it does not support XComponent 4474 if( xComponent.is() ) 4475 xComponent->dispose(); 4476 } 4477 4478 catch ( Exception&) 4479 { 4480 // can be safely ignored here. 4481 } 4482 } 4483 4484 UnoWrapperBase* pWrapper = Application::GetUnoWrapper( sal_False ); 4485 if ( pWrapper ) 4486 pWrapper->WindowDestroyed( this ); 4487 4488 // MT: Must be called after WindowDestroyed! 4489 // Otherwise, if the accessible is a VCLXWindow, it will try to destroy this window again! 4490 // But accessibility implementations from applications need this dispose. 4491 if ( mpWindowImpl->mxAccessible.is() ) 4492 { 4493 ::com::sun::star::uno::Reference< ::com::sun::star::lang::XComponent> xC( mpWindowImpl->mxAccessible, ::com::sun::star::uno::UNO_QUERY ); 4494 if ( xC.is() ) 4495 xC->dispose(); 4496 } 4497 4498 ImplSVData* pSVData = ImplGetSVData(); 4499 4500 if ( pSVData->maHelpData.mpHelpWin && (pSVData->maHelpData.mpHelpWin->GetParent() == this) ) 4501 ImplDestroyHelpWindow( true ); 4502 4503 DBG_ASSERT( pSVData->maWinData.mpTrackWin != this, 4504 "Window::~Window(): Window is in TrackingMode" ); 4505 DBG_ASSERT( pSVData->maWinData.mpCaptureWin != this, 4506 "Window::~Window(): Window has the mouse captured" ); 4507 // #103442# DefModalDialogParent is now determined on-the-fly, so this pointer is unimportant now 4508 //DBG_ASSERT( pSVData->maWinData.mpDefDialogParent != this, 4509 // "Window::~Window(): Window is DefModalDialogParent" ); 4510 4511 // Wegen alter kompatibilitaet 4512 if ( pSVData->maWinData.mpTrackWin == this ) 4513 EndTracking(); 4514 if ( pSVData->maWinData.mpCaptureWin == this ) 4515 ReleaseMouse(); 4516 if ( pSVData->maWinData.mpDefDialogParent == this ) 4517 pSVData->maWinData.mpDefDialogParent = NULL; 4518 4519 #ifdef DBG_UTIL 4520 if ( sal_True ) // always perform these tests in non-pro versions 4521 { 4522 ByteString aErrorStr; 4523 sal_Bool bError = sal_False; 4524 Window* pTempWin = mpWindowImpl->mpFrameData->mpFirstOverlap; 4525 while ( pTempWin ) 4526 { 4527 if ( ImplIsRealParentPath( pTempWin ) ) 4528 { 4529 bError = sal_True; 4530 lcl_appendWindowInfo( aErrorStr, *pTempWin ); 4531 } 4532 pTempWin = pTempWin->mpWindowImpl->mpNextOverlap; 4533 } 4534 if ( bError ) 4535 { 4536 ByteString aTempStr( "Window (" ); 4537 aTempStr += ByteString( GetText(), RTL_TEXTENCODING_UTF8 ); 4538 aTempStr += ") with living SystemWindow(s) destroyed: "; 4539 aTempStr += aErrorStr; 4540 DBG_ERROR( aTempStr.GetBuffer() ); 4541 GetpApp()->Abort( String( aTempStr, RTL_TEXTENCODING_UTF8 ) ); // abort in non-pro version, this must be fixed! 4542 } 4543 4544 bError = sal_False; 4545 pTempWin = pSVData->maWinData.mpFirstFrame; 4546 while ( pTempWin ) 4547 { 4548 if ( ImplIsRealParentPath( pTempWin ) ) 4549 { 4550 bError = sal_True; 4551 lcl_appendWindowInfo( aErrorStr, *pTempWin ); 4552 } 4553 pTempWin = pTempWin->mpWindowImpl->mpFrameData->mpNextFrame; 4554 } 4555 if ( bError ) 4556 { 4557 ByteString aTempStr( "Window (" ); 4558 aTempStr += ByteString( GetText(), RTL_TEXTENCODING_UTF8 ); 4559 aTempStr += ") with living SystemWindow(s) destroyed: "; 4560 aTempStr += aErrorStr; 4561 DBG_ERROR( aTempStr.GetBuffer() ); 4562 GetpApp()->Abort( String( aTempStr, RTL_TEXTENCODING_UTF8 ) ); // abort in non-pro version, this must be fixed! 4563 } 4564 4565 if ( mpWindowImpl->mpFirstChild ) 4566 { 4567 ByteString aTempStr( "Window (" ); 4568 aTempStr += ByteString( GetText(), RTL_TEXTENCODING_UTF8 ); 4569 aTempStr += ") with living Child(s) destroyed: "; 4570 pTempWin = mpWindowImpl->mpFirstChild; 4571 while ( pTempWin ) 4572 { 4573 lcl_appendWindowInfo( aTempStr, *pTempWin ); 4574 pTempWin = pTempWin->mpWindowImpl->mpNext; 4575 } 4576 DBG_ERROR( aTempStr.GetBuffer() ); 4577 GetpApp()->Abort( String( aTempStr, RTL_TEXTENCODING_UTF8 ) ); // abort in non-pro version, this must be fixed! 4578 } 4579 4580 if ( mpWindowImpl->mpFirstOverlap ) 4581 { 4582 ByteString aTempStr( "Window (" ); 4583 aTempStr += ByteString( GetText(), RTL_TEXTENCODING_UTF8 ); 4584 aTempStr += ") with living SystemWindow(s) destroyed: "; 4585 pTempWin = mpWindowImpl->mpFirstOverlap; 4586 while ( pTempWin ) 4587 { 4588 lcl_appendWindowInfo( aTempStr, *pTempWin ); 4589 pTempWin = pTempWin->mpWindowImpl->mpNext; 4590 } 4591 DBG_ERROR( aTempStr.GetBuffer() ); 4592 GetpApp()->Abort( String( aTempStr, RTL_TEXTENCODING_UTF8 ) ); // abort in non-pro version, this must be fixed! 4593 } 4594 4595 Window* pMyParent = this; 4596 SystemWindow* pMySysWin = NULL; 4597 4598 while ( pMyParent ) 4599 { 4600 if ( pMyParent->IsSystemWindow() ) 4601 pMySysWin = (SystemWindow*)pMyParent; 4602 pMyParent = pMyParent->GetParent(); 4603 } 4604 if ( pMySysWin && pMySysWin->ImplIsInTaskPaneList( this ) ) 4605 { 4606 ByteString aTempStr( "Window (" ); 4607 aTempStr += ByteString( GetText(), RTL_TEXTENCODING_UTF8 ); 4608 aTempStr += ") still in TaskPanelList!"; 4609 DBG_ERROR( aTempStr.GetBuffer() ); 4610 GetpApp()->Abort( String( aTempStr, RTL_TEXTENCODING_UTF8 ) ); // abort in non-pro version, this must be fixed! 4611 } 4612 } 4613 #endif 4614 4615 if( mpWindowImpl->mbIsInTaskPaneList ) 4616 { 4617 Window* pMyParent = this; 4618 SystemWindow* pMySysWin = NULL; 4619 4620 while ( pMyParent ) 4621 { 4622 if ( pMyParent->IsSystemWindow() ) 4623 pMySysWin = (SystemWindow*)pMyParent; 4624 pMyParent = pMyParent->GetParent(); 4625 } 4626 if ( pMySysWin && pMySysWin->ImplIsInTaskPaneList( this ) ) 4627 { 4628 pMySysWin->GetTaskPaneList()->RemoveWindow( this ); 4629 } 4630 else 4631 { 4632 ByteString aTempStr( "Window (" ); 4633 aTempStr += ByteString( GetText(), RTL_TEXTENCODING_UTF8 ); 4634 aTempStr += ") not found in TaskPanelList!"; 4635 DBG_ERROR( aTempStr.GetBuffer() ); 4636 } 4637 } 4638 4639 // Fenster hiden, um das entsprechende Paint-Handling auszuloesen 4640 Hide(); 4641 4642 // Mitteilen, das Fenster zerstoert wird 4643 { 4644 NotifyEvent aNEvt( EVENT_DESTROY, this ); 4645 Notify( aNEvt ); 4646 } 4647 4648 // EndExtTextInputMode 4649 if ( pSVData->maWinData.mpExtTextInputWin == this ) 4650 { 4651 EndExtTextInput( EXTTEXTINPUT_END_COMPLETE ); 4652 if ( pSVData->maWinData.mpExtTextInputWin == this ) 4653 pSVData->maWinData.mpExtTextInputWin = NULL; 4654 } 4655 4656 // check if the focus window is our child 4657 sal_Bool bHasFocussedChild = sal_False; 4658 if( pSVData->maWinData.mpFocusWin && ImplIsRealParentPath( pSVData->maWinData.mpFocusWin ) ) 4659 { 4660 // #122232#, this must not happen and is an application bug ! but we try some cleanup to hopefully avoid crashes, see below 4661 bHasFocussedChild = sal_True; 4662 #ifdef DBG_UTIL 4663 ByteString aTempStr( "Window (" ); 4664 aTempStr += ByteString( GetText(), RTL_TEXTENCODING_UTF8 ); 4665 aTempStr += ") with focussed child window destroyed ! THIS WILL LEAD TO CRASHES AND MUST BE FIXED !"; 4666 DBG_ERROR( aTempStr.GetBuffer() ); 4667 GetpApp()->Abort( String( aTempStr, RTL_TEXTENCODING_UTF8 ) ); // abort in non-pro version, this must be fixed! 4668 #endif 4669 } 4670 4671 // Wenn wir den Focus haben, dann den Focus auf ein anderes Fenster setzen 4672 Window* pOverlapWindow = ImplGetFirstOverlapWindow(); 4673 if ( pSVData->maWinData.mpFocusWin == this 4674 || bHasFocussedChild ) // #122232#, see above, try some cleanup 4675 { 4676 if ( mpWindowImpl->mbFrame ) 4677 { 4678 pSVData->maWinData.mpFocusWin = NULL; 4679 pOverlapWindow->mpWindowImpl->mpLastFocusWindow = NULL; 4680 GetpApp()->FocusChanged(); 4681 } 4682 else 4683 { 4684 Window* pParent = GetParent(); 4685 Window* pBorderWindow = mpWindowImpl->mpBorderWindow; 4686 // Bei ueberlappenden Fenstern wird der Focus auf den 4687 // Parent vom naechsten FrameWindow gesetzt 4688 if ( pBorderWindow ) 4689 { 4690 if ( pBorderWindow->ImplIsOverlapWindow() ) 4691 pParent = pBorderWindow->mpWindowImpl->mpOverlapWindow; 4692 } 4693 else if ( ImplIsOverlapWindow() ) 4694 pParent = mpWindowImpl->mpOverlapWindow; 4695 4696 if ( pParent && pParent->IsEnabled() && pParent->IsInputEnabled() && ! pParent->IsInModalMode() ) 4697 pParent->GrabFocus(); 4698 else 4699 mpWindowImpl->mpFrameWindow->GrabFocus(); 4700 4701 // If the focus was set back to 'this' set it to nothing 4702 if ( pSVData->maWinData.mpFocusWin == this ) 4703 { 4704 pSVData->maWinData.mpFocusWin = NULL; 4705 pOverlapWindow->mpWindowImpl->mpLastFocusWindow = NULL; 4706 GetpApp()->FocusChanged(); 4707 } 4708 } 4709 } 4710 4711 4712 if ( pOverlapWindow->mpWindowImpl->mpLastFocusWindow == this ) 4713 pOverlapWindow->mpWindowImpl->mpLastFocusWindow = NULL; 4714 4715 // reset hint for DefModalDialogParent 4716 if( pSVData->maWinData.mpActiveApplicationFrame == this ) 4717 pSVData->maWinData.mpActiveApplicationFrame = NULL; 4718 4719 // gemerkte Fenster zuruecksetzen 4720 if ( mpWindowImpl->mpFrameData->mpFocusWin == this ) 4721 mpWindowImpl->mpFrameData->mpFocusWin = NULL; 4722 if ( mpWindowImpl->mpFrameData->mpMouseMoveWin == this ) 4723 mpWindowImpl->mpFrameData->mpMouseMoveWin = NULL; 4724 if ( mpWindowImpl->mpFrameData->mpMouseDownWin == this ) 4725 mpWindowImpl->mpFrameData->mpMouseDownWin = NULL; 4726 4727 // Deactivate-Window zuruecksetzen 4728 if ( pSVData->maWinData.mpLastDeacWin == this ) 4729 pSVData->maWinData.mpLastDeacWin = NULL; 4730 4731 if ( mpWindowImpl->mbFrame ) 4732 { 4733 if ( mpWindowImpl->mpFrameData->mnFocusId ) 4734 Application::RemoveUserEvent( mpWindowImpl->mpFrameData->mnFocusId ); 4735 if ( mpWindowImpl->mpFrameData->mnMouseMoveId ) 4736 Application::RemoveUserEvent( mpWindowImpl->mpFrameData->mnMouseMoveId ); 4737 } 4738 4739 // release SalGraphics 4740 ImplReleaseGraphics(); 4741 4742 // notify ImplDelData subscribers of this window about the window deletion 4743 ImplDelData* pDelData = mpWindowImpl->mpFirstDel; 4744 while ( pDelData ) 4745 { 4746 pDelData->mbDel = sal_True; 4747 pDelData->mpWindow = NULL; // #112873# pDel is not associated with a Window anymore 4748 pDelData = pDelData->mpNext; 4749 } 4750 4751 // remove window from the lists 4752 ImplRemoveWindow( sal_True ); 4753 4754 // de-register as "top window child" at our parent, if necessary 4755 if ( mpWindowImpl->mbFrame ) 4756 { 4757 sal_Bool bIsTopWindow = mpWindowImpl->mpWinData && ( mpWindowImpl->mpWinData->mnIsTopWindow == 1 ); 4758 if ( mpWindowImpl->mpRealParent && bIsTopWindow ) 4759 { 4760 ImplWinData* pParentWinData = mpWindowImpl->mpRealParent->ImplGetWinData(); 4761 4762 ::std::list< Window* >::iterator myPos = ::std::find( pParentWinData->maTopWindowChildren.begin(), 4763 pParentWinData->maTopWindowChildren.end(), this ); 4764 DBG_ASSERT( myPos != pParentWinData->maTopWindowChildren.end(), "Window::~Window: inconsistency in top window chain!" ); 4765 if ( myPos != pParentWinData->maTopWindowChildren.end() ) 4766 pParentWinData->maTopWindowChildren.erase( myPos ); 4767 } 4768 } 4769 4770 // cleanup Extra Window Data, TODO: add and use ImplWinData destructor 4771 if ( mpWindowImpl->mpWinData ) 4772 { 4773 if ( mpWindowImpl->mpWinData->mpExtOldText ) 4774 delete mpWindowImpl->mpWinData->mpExtOldText; 4775 if ( mpWindowImpl->mpWinData->mpExtOldAttrAry ) 4776 delete mpWindowImpl->mpWinData->mpExtOldAttrAry; 4777 if ( mpWindowImpl->mpWinData->mpCursorRect ) 4778 delete mpWindowImpl->mpWinData->mpCursorRect; 4779 if ( mpWindowImpl->mpWinData->mpFocusRect ) 4780 delete mpWindowImpl->mpWinData->mpFocusRect; 4781 if ( mpWindowImpl->mpWinData->mpTrackRect ) 4782 delete mpWindowImpl->mpWinData->mpTrackRect; 4783 4784 delete mpWindowImpl->mpWinData; 4785 } 4786 4787 // cleanup overlap related window data 4788 if ( mpWindowImpl->mpOverlapData ) 4789 delete mpWindowImpl->mpOverlapData; 4790 4791 // remove BorderWindow or Frame window data 4792 if ( mpWindowImpl->mpBorderWindow ) 4793 delete mpWindowImpl->mpBorderWindow; 4794 else if ( mpWindowImpl->mbFrame ) 4795 { 4796 if ( pSVData->maWinData.mpFirstFrame == this ) 4797 pSVData->maWinData.mpFirstFrame = mpWindowImpl->mpFrameData->mpNextFrame; 4798 else 4799 { 4800 Window* pSysWin = pSVData->maWinData.mpFirstFrame; 4801 while ( pSysWin->mpWindowImpl->mpFrameData->mpNextFrame != this ) 4802 pSysWin = pSysWin->mpWindowImpl->mpFrameData->mpNextFrame; 4803 pSysWin->mpWindowImpl->mpFrameData->mpNextFrame = mpWindowImpl->mpFrameData->mpNextFrame; 4804 } 4805 mpWindowImpl->mpFrame->SetCallback( NULL, NULL ); 4806 pSVData->mpDefInst->DestroyFrame( mpWindowImpl->mpFrame ); 4807 delete mpWindowImpl->mpFrameData; 4808 } 4809 4810 // should be the last statements 4811 delete mpWindowImpl; mpWindowImpl = NULL; 4812 } 4813 4814 // ----------------------------------------------------------------------- 4815 void Window::doLazyDelete() 4816 { 4817 SystemWindow* pSysWin = dynamic_cast<SystemWindow*>(this); 4818 DockingWindow* pDockWin = dynamic_cast<DockingWindow*>(this); 4819 if( pSysWin || ( pDockWin && pDockWin->IsFloatingMode() ) ) 4820 { 4821 Show( sal_False ); 4822 SetParent( ImplGetDefaultWindow() ); 4823 } 4824 vcl::LazyDeletor<Window>::Delete( this ); 4825 } 4826 4827 // ----------------------------------------------------------------------- 4828 void Window::InterceptChildWindowKeyDown( sal_Bool bIntercept ) 4829 { 4830 if( mpWindowImpl->mpSysObj ) 4831 mpWindowImpl->mpSysObj->InterceptChildWindowKeyDown( bIntercept ); 4832 } 4833 4834 // ----------------------------------------------------------------------- 4835 4836 void Window::MouseMove( const MouseEvent& rMEvt ) 4837 { 4838 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 4839 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4840 } 4841 4842 NotifyEvent aNEvt( EVENT_MOUSEMOVE, this, &rMEvt ); 4843 if ( !Notify( aNEvt ) ) 4844 mpWindowImpl->mbMouseMove = sal_True; 4845 } 4846 4847 // ----------------------------------------------------------------------- 4848 4849 void Window::MouseButtonDown( const MouseEvent& rMEvt ) 4850 { 4851 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 4852 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4853 } 4854 4855 NotifyEvent aNEvt( EVENT_MOUSEBUTTONDOWN, this, &rMEvt ); 4856 if ( !Notify( aNEvt ) ) 4857 mpWindowImpl->mbMouseButtonDown = sal_True; 4858 } 4859 4860 // ----------------------------------------------------------------------- 4861 4862 void Window::MouseButtonUp( const MouseEvent& rMEvt ) 4863 { 4864 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 4865 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4866 } 4867 4868 NotifyEvent aNEvt( EVENT_MOUSEBUTTONUP, this, &rMEvt ); 4869 if ( !Notify( aNEvt ) ) 4870 mpWindowImpl->mbMouseButtonUp = sal_True; 4871 } 4872 4873 // ----------------------------------------------------------------------- 4874 4875 void Window::KeyInput( const KeyEvent& rKEvt ) 4876 { 4877 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 4878 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4879 } 4880 4881 NotifyEvent aNEvt( EVENT_KEYINPUT, this, &rKEvt ); 4882 if ( !Notify( aNEvt ) ) 4883 mpWindowImpl->mbKeyInput = sal_True; 4884 } 4885 4886 // ----------------------------------------------------------------------- 4887 4888 void Window::KeyUp( const KeyEvent& rKEvt ) 4889 { 4890 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 4891 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4892 } 4893 4894 NotifyEvent aNEvt( EVENT_KEYUP, this, &rKEvt ); 4895 if ( !Notify( aNEvt ) ) 4896 mpWindowImpl->mbKeyUp = sal_True; 4897 } 4898 4899 // ----------------------------------------------------------------------- 4900 4901 void Window::PrePaint() 4902 { 4903 } 4904 4905 // ----------------------------------------------------------------------- 4906 4907 void Window::Paint( const Rectangle& rRect ) 4908 { 4909 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 4910 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4911 } 4912 4913 ImplCallEventListeners( VCLEVENT_WINDOW_PAINT, (void*)&rRect ); 4914 } 4915 4916 // ----------------------------------------------------------------------- 4917 4918 void Window::PostPaint() 4919 { 4920 } 4921 4922 // ----------------------------------------------------------------------- 4923 4924 void Window::Draw( OutputDevice*, const Point&, const Size&, sal_uLong ) 4925 { 4926 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4927 } 4928 4929 // ----------------------------------------------------------------------- 4930 4931 void Window::Move() 4932 { 4933 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4934 } 4935 4936 // ----------------------------------------------------------------------- 4937 4938 void Window::Resize() 4939 { 4940 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4941 } 4942 4943 // ----------------------------------------------------------------------- 4944 4945 void Window::Activate() 4946 { 4947 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4948 } 4949 4950 // ----------------------------------------------------------------------- 4951 4952 void Window::Deactivate() 4953 { 4954 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4955 } 4956 4957 // ----------------------------------------------------------------------- 4958 4959 void Window::GetFocus() 4960 { 4961 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 4962 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4963 } 4964 4965 if ( HasFocus() && mpWindowImpl->mpLastFocusWindow && !(mpWindowImpl->mnDlgCtrlFlags & WINDOW_DLGCTRL_WANTFOCUS) ) 4966 { 4967 ImplDelData aDogtag( this ); 4968 mpWindowImpl->mpLastFocusWindow->GrabFocus(); 4969 if( aDogtag.IsDelete() ) 4970 return; 4971 } 4972 4973 NotifyEvent aNEvt( EVENT_GETFOCUS, this ); 4974 Notify( aNEvt ); 4975 } 4976 4977 // ----------------------------------------------------------------------- 4978 4979 void Window::LoseFocus() 4980 { 4981 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 4982 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4983 } 4984 4985 NotifyEvent aNEvt( EVENT_LOSEFOCUS, this ); 4986 Notify( aNEvt ); 4987 } 4988 4989 // ----------------------------------------------------------------------- 4990 4991 void Window::RequestHelp( const HelpEvent& rHEvt ) 4992 { 4993 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 4994 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 4995 } 4996 4997 // Wenn Balloon-Help angefordert wird, dann den Balloon mit dem 4998 // gesetzten Hilfetext anzeigen 4999 if ( rHEvt.GetMode() & HELPMODE_BALLOON ) 5000 { 5001 const XubString* pStr = &(GetHelpText()); 5002 if ( !pStr->Len() ) 5003 pStr = &(GetQuickHelpText()); 5004 if ( !pStr->Len() && ImplGetParent() && !ImplIsOverlapWindow() ) 5005 ImplGetParent()->RequestHelp( rHEvt ); 5006 else 5007 Help::ShowBalloon( this, rHEvt.GetMousePosPixel(), *pStr ); 5008 } 5009 else if ( rHEvt.GetMode() & HELPMODE_QUICK ) 5010 { 5011 const XubString* pStr = &(GetQuickHelpText()); 5012 if ( !pStr->Len() && ImplGetParent() && !ImplIsOverlapWindow() ) 5013 ImplGetParent()->RequestHelp( rHEvt ); 5014 else 5015 { 5016 Point aPos = GetPosPixel(); 5017 if ( ImplGetParent() && !ImplIsOverlapWindow() ) 5018 aPos = ImplGetParent()->OutputToScreenPixel( aPos ); 5019 Rectangle aRect( aPos, GetSizePixel() ); 5020 String aHelpText; 5021 if ( pStr->Len() ) 5022 aHelpText = GetHelpText(); 5023 Help::ShowQuickHelp( this, aRect, *pStr, aHelpText, QUICKHELP_CTRLTEXT ); 5024 } 5025 } 5026 else 5027 { 5028 String aStrHelpId( rtl::OStringToOUString( GetHelpId(), RTL_TEXTENCODING_UTF8 ) ); 5029 if ( aStrHelpId.Len() == 0 && ImplGetParent() ) 5030 ImplGetParent()->RequestHelp( rHEvt ); 5031 else 5032 { 5033 Help* pHelp = Application::GetHelp(); 5034 if ( pHelp ) 5035 { 5036 if( aStrHelpId.Len() > 0 ) 5037 pHelp->Start( aStrHelpId, this ); 5038 else 5039 pHelp->Start( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( OOO_HELP_INDEX ) ), this ); 5040 } 5041 } 5042 } 5043 } 5044 5045 // ----------------------------------------------------------------------- 5046 5047 void Window::Command( const CommandEvent& rCEvt ) 5048 { 5049 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 5050 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5051 } 5052 5053 ImplCallEventListeners( VCLEVENT_WINDOW_COMMAND, (void*)&rCEvt ); 5054 5055 NotifyEvent aNEvt( EVENT_COMMAND, this, &rCEvt ); 5056 if ( !Notify( aNEvt ) ) 5057 mpWindowImpl->mbCommand = sal_True; 5058 } 5059 5060 // ----------------------------------------------------------------------- 5061 5062 void Window::Tracking( const TrackingEvent& rTEvt ) 5063 { 5064 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5065 5066 ImplDockingWindowWrapper *pWrapper = ImplGetDockingManager()->GetDockingWindowWrapper( this ); 5067 if( pWrapper ) 5068 pWrapper->Tracking( rTEvt ); 5069 } 5070 5071 // ----------------------------------------------------------------------- 5072 5073 void Window::UserEvent( sal_uLong, void* ) 5074 { 5075 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5076 } 5077 5078 // ----------------------------------------------------------------------- 5079 5080 void Window::StateChanged( StateChangedType ) 5081 { 5082 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5083 } 5084 5085 // ----------------------------------------------------------------------- 5086 5087 void Window::DataChanged( const DataChangedEvent& ) 5088 { 5089 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5090 } 5091 5092 // ----------------------------------------------------------------------- 5093 5094 void Window::ImplNotifyKeyMouseCommandEventListeners( NotifyEvent& rNEvt ) 5095 { 5096 if( rNEvt.GetType() == EVENT_COMMAND ) 5097 { 5098 const CommandEvent* pCEvt = rNEvt.GetCommandEvent(); 5099 if ( pCEvt->GetCommand() != COMMAND_CONTEXTMENU ) 5100 // non context menu events are not to be notified up the chain 5101 // so we return immediately 5102 return; 5103 5104 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5105 { 5106 if ( rNEvt.GetWindow() == this ) 5107 // not interested in: The event listeners are already called in ::Command, 5108 // and calling them here a second time doesn't make sense 5109 ; 5110 else 5111 { 5112 CommandEvent aCommandEvent = ImplTranslateCommandEvent( *pCEvt, rNEvt.GetWindow(), this ); 5113 ImplCallEventListeners( VCLEVENT_WINDOW_COMMAND, &aCommandEvent ); 5114 } 5115 } 5116 } 5117 5118 // #82968# notify event listeners for mouse and key events seperately and 5119 // not in PreNotify ( as for focus listeners ) 5120 // this allows for procesing those events internally first and pass it to 5121 // the toolkit later 5122 5123 ImplDelData aDelData; 5124 ImplAddDel( &aDelData ); 5125 5126 if( rNEvt.GetType() == EVENT_MOUSEMOVE ) 5127 { 5128 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5129 { 5130 if ( rNEvt.GetWindow() == this ) 5131 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEMOVE, (void*)rNEvt.GetMouseEvent() ); 5132 else 5133 { 5134 MouseEvent aMouseEvent = ImplTranslateMouseEvent( *rNEvt.GetMouseEvent(), rNEvt.GetWindow(), this ); 5135 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEMOVE, &aMouseEvent ); 5136 } 5137 } 5138 } 5139 else if( rNEvt.GetType() == EVENT_MOUSEBUTTONUP ) 5140 { 5141 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5142 { 5143 if ( rNEvt.GetWindow() == this ) 5144 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEBUTTONUP, (void*)rNEvt.GetMouseEvent() ); 5145 else 5146 { 5147 MouseEvent aMouseEvent = ImplTranslateMouseEvent( *rNEvt.GetMouseEvent(), rNEvt.GetWindow(), this ); 5148 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEBUTTONUP, &aMouseEvent ); 5149 } 5150 } 5151 } 5152 else if( rNEvt.GetType() == EVENT_MOUSEBUTTONDOWN ) 5153 { 5154 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5155 { 5156 if ( rNEvt.GetWindow() == this ) 5157 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEBUTTONDOWN, (void*)rNEvt.GetMouseEvent() ); 5158 else 5159 { 5160 MouseEvent aMouseEvent = ImplTranslateMouseEvent( *rNEvt.GetMouseEvent(), rNEvt.GetWindow(), this ); 5161 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEBUTTONDOWN, &aMouseEvent ); 5162 } 5163 } 5164 } 5165 else if( rNEvt.GetType() == EVENT_KEYINPUT ) 5166 { 5167 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5168 ImplCallEventListeners( VCLEVENT_WINDOW_KEYINPUT, (void*)rNEvt.GetKeyEvent() ); 5169 } 5170 else if( rNEvt.GetType() == EVENT_KEYUP ) 5171 { 5172 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5173 ImplCallEventListeners( VCLEVENT_WINDOW_KEYUP, (void*)rNEvt.GetKeyEvent() ); 5174 } 5175 5176 if ( aDelData.IsDelete() ) 5177 return; 5178 ImplRemoveDel( &aDelData ); 5179 5180 // #106721# check if we're part of a compound control and notify 5181 Window *pParent = ImplGetParent(); 5182 while( pParent ) 5183 { 5184 if( pParent->IsCompoundControl() ) 5185 { 5186 pParent->ImplNotifyKeyMouseCommandEventListeners( rNEvt ); 5187 break; 5188 } 5189 pParent = pParent->ImplGetParent(); 5190 } 5191 } 5192 5193 // ----------------------------------------------------------------------- 5194 5195 long Window::PreNotify( NotifyEvent& rNEvt ) 5196 { 5197 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 5198 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5199 } 5200 5201 long bDone = sal_False; 5202 if ( mpWindowImpl->mpParent && !ImplIsOverlapWindow() ) 5203 bDone = mpWindowImpl->mpParent->PreNotify( rNEvt ); 5204 5205 if ( !bDone ) 5206 { 5207 if( rNEvt.GetType() == EVENT_GETFOCUS ) 5208 { 5209 sal_Bool bCompoundFocusChanged = sal_False; 5210 if ( mpWindowImpl->mbCompoundControl && !mpWindowImpl->mbCompoundControlHasFocus && HasChildPathFocus() ) 5211 { 5212 mpWindowImpl->mbCompoundControlHasFocus = sal_True; 5213 bCompoundFocusChanged = sal_True; 5214 } 5215 5216 if ( bCompoundFocusChanged || ( rNEvt.GetWindow() == this ) ) 5217 ImplCallEventListeners( VCLEVENT_WINDOW_GETFOCUS ); 5218 } 5219 else if( rNEvt.GetType() == EVENT_LOSEFOCUS ) 5220 { 5221 sal_Bool bCompoundFocusChanged = sal_False; 5222 if ( mpWindowImpl->mbCompoundControl && mpWindowImpl->mbCompoundControlHasFocus && !HasChildPathFocus() ) 5223 { 5224 mpWindowImpl->mbCompoundControlHasFocus = sal_False ; 5225 bCompoundFocusChanged = sal_True; 5226 } 5227 5228 if ( bCompoundFocusChanged || ( rNEvt.GetWindow() == this ) ) 5229 ImplCallEventListeners( VCLEVENT_WINDOW_LOSEFOCUS ); 5230 } 5231 5232 // #82968# mouse and key events will be notified after processing ( in ImplNotifyKeyMouseCommandEventListeners() )! 5233 // see also ImplHandleMouseEvent(), ImplHandleKey() 5234 5235 /* 5236 else if( rNEvt.GetType() == EVENT_MOUSEMOVE ) 5237 { 5238 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5239 { 5240 if ( rNEvt.GetWindow() == this ) 5241 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEMOVE, (void*)rNEvt.GetMouseEvent() ); 5242 else 5243 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEMOVE, &ImplTranslateMouseEvent( *rNEvt.GetMouseEvent(), rNEvt.GetWindow(), this ) ); 5244 } 5245 } 5246 else if( rNEvt.GetType() == EVENT_MOUSEBUTTONUP ) 5247 { 5248 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5249 { 5250 if ( rNEvt.GetWindow() == this ) 5251 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEBUTTONUP, (void*)rNEvt.GetMouseEvent() ); 5252 else 5253 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEBUTTONUP, &ImplTranslateMouseEvent( *rNEvt.GetMouseEvent(), rNEvt.GetWindow(), this ) ); 5254 } 5255 } 5256 else if( rNEvt.GetType() == EVENT_MOUSEBUTTONDOWN ) 5257 { 5258 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5259 { 5260 if ( rNEvt.GetWindow() == this ) 5261 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEBUTTONDOWN, (void*)rNEvt.GetMouseEvent() ); 5262 else 5263 ImplCallEventListeners( VCLEVENT_WINDOW_MOUSEBUTTONDOWN, &ImplTranslateMouseEvent( *rNEvt.GetMouseEvent(), rNEvt.GetWindow(), this ) ); 5264 } 5265 } 5266 else if( rNEvt.GetType() == EVENT_KEYINPUT ) 5267 { 5268 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5269 ImplCallEventListeners( VCLEVENT_WINDOW_KEYINPUT, (void*)rNEvt.GetKeyEvent() ); 5270 } 5271 else if( rNEvt.GetType() == EVENT_KEYUP ) 5272 { 5273 if ( mpWindowImpl->mbCompoundControl || ( rNEvt.GetWindow() == this ) ) 5274 ImplCallEventListeners( VCLEVENT_WINDOW_KEYUP, (void*)rNEvt.GetKeyEvent() ); 5275 } 5276 */ 5277 } 5278 5279 return bDone; 5280 } 5281 5282 // ----------------------------------------------------------------------- 5283 5284 long Window::Notify( NotifyEvent& rNEvt ) 5285 { 5286 { // Klammerung, da in diesem Handler das Window zerstoert werden darf 5287 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5288 } 5289 5290 long nRet = sal_False; 5291 5292 // check for docking window 5293 // but do nothing if window is docked and locked 5294 ImplDockingWindowWrapper *pWrapper = ImplGetDockingManager()->GetDockingWindowWrapper( this ); 5295 if( pWrapper && !( !pWrapper->IsFloatingMode() && pWrapper->IsLocked() ) ) 5296 { 5297 if ( rNEvt.GetType() == EVENT_MOUSEBUTTONDOWN ) 5298 { 5299 const MouseEvent* pMEvt = rNEvt.GetMouseEvent(); 5300 sal_Bool bHit = pWrapper->GetDragArea().IsInside( pMEvt->GetPosPixel() ); 5301 if ( pMEvt->IsLeft() ) 5302 { 5303 if ( pMEvt->IsMod1() && (pMEvt->GetClicks() == 2) ) 5304 { 5305 // ctrl double click toggles floating mode 5306 pWrapper->SetFloatingMode( !pWrapper->IsFloatingMode() ); 5307 return sal_True; 5308 } 5309 else if ( pMEvt->GetClicks() == 1 && bHit) 5310 { 5311 // allow start docking during mouse move 5312 pWrapper->ImplEnableStartDocking(); 5313 return sal_True; 5314 } 5315 } 5316 } 5317 else if ( rNEvt.GetType() == EVENT_MOUSEMOVE ) 5318 { 5319 const MouseEvent* pMEvt = rNEvt.GetMouseEvent(); 5320 sal_Bool bHit = pWrapper->GetDragArea().IsInside( pMEvt->GetPosPixel() ); 5321 if ( pMEvt->IsLeft() ) 5322 { 5323 // check if a single click initiated this sequence ( ImplStartDockingEnabled() ) 5324 // check if window is docked and 5325 if( pWrapper->ImplStartDockingEnabled() && !pWrapper->IsFloatingMode() && 5326 !pWrapper->IsDocking() && bHit ) 5327 { 5328 Point aPos = pMEvt->GetPosPixel(); 5329 Window* pWindow = rNEvt.GetWindow(); 5330 if ( pWindow != this ) 5331 { 5332 aPos = pWindow->OutputToScreenPixel( aPos ); 5333 aPos = ScreenToOutputPixel( aPos ); 5334 } 5335 pWrapper->ImplStartDocking( aPos ); 5336 } 5337 return sal_True; 5338 } 5339 } 5340 else if( rNEvt.GetType() == EVENT_KEYINPUT ) 5341 { 5342 const KeyCode& rKey = rNEvt.GetKeyEvent()->GetKeyCode(); 5343 if( rKey.GetCode() == KEY_F10 && rKey.GetModifier() && 5344 rKey.IsShift() && rKey.IsMod1() ) 5345 { 5346 pWrapper->SetFloatingMode( !pWrapper->IsFloatingMode() ); 5347 /* At this point the floating toolbar frame does not have the 5348 * input focus since these frames don't get the focus per default 5349 * To enable keyboard handling of this toolbar set the input focus 5350 * to the frame. This needs to be done with ToTop since GrabFocus 5351 * would not notice any change since "this" already has the focus. 5352 */ 5353 if( pWrapper->IsFloatingMode() ) 5354 ToTop( TOTOP_GRABFOCUSONLY ); 5355 return sal_True; 5356 } 5357 } 5358 } 5359 5360 // Dialog-Steuerung 5361 if ( (GetStyle() & (WB_DIALOGCONTROL | WB_NODIALOGCONTROL)) == WB_DIALOGCONTROL ) 5362 { 5363 // Wenn Parent auch DialogSteuerung aktiviert hat, uebernimmt dieser die Steuerung 5364 if ( (rNEvt.GetType() == EVENT_KEYINPUT) || (rNEvt.GetType() == EVENT_KEYUP) ) 5365 { 5366 if ( ImplIsOverlapWindow() || 5367 ((ImplGetParent()->GetStyle() & (WB_DIALOGCONTROL | WB_NODIALOGCONTROL)) != WB_DIALOGCONTROL) ) 5368 { 5369 nRet = ImplDlgCtrl( *rNEvt.GetKeyEvent(), rNEvt.GetType() == EVENT_KEYINPUT ); 5370 } 5371 } 5372 else if ( (rNEvt.GetType() == EVENT_GETFOCUS) || (rNEvt.GetType() == EVENT_LOSEFOCUS) ) 5373 { 5374 ImplDlgCtrlFocusChanged( rNEvt.GetWindow(), rNEvt.GetType() == EVENT_GETFOCUS ); 5375 if ( (rNEvt.GetWindow() == this) && (rNEvt.GetType() == EVENT_GETFOCUS) && 5376 !(GetStyle() & WB_TABSTOP) && !(mpWindowImpl->mnDlgCtrlFlags & WINDOW_DLGCTRL_WANTFOCUS) ) 5377 { 5378 sal_uInt16 n = 0; 5379 Window* pFirstChild = ImplGetDlgWindow( n, DLGWINDOW_FIRST ); 5380 if ( pFirstChild ) 5381 pFirstChild->ImplControlFocus(); 5382 } 5383 } 5384 } 5385 5386 if ( !nRet ) 5387 { 5388 if ( mpWindowImpl->mpParent && !ImplIsOverlapWindow() ) 5389 nRet = mpWindowImpl->mpParent->Notify( rNEvt ); 5390 } 5391 5392 return nRet; 5393 } 5394 5395 // IAccessible2 implementation, 2009 5396 void Window::NotifyVCLEvent( sal_uLong nEvent ,void* pData /*= NULL*/) 5397 { 5398 ImplCallEventListeners( nEvent ,pData); 5399 } 5400 ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > > Window::GetAccFlowToSequence() 5401 { 5402 return ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > >(); 5403 } 5404 // ----------------------------------------------------------------------- 5405 5406 void Window::ImplCallEventListeners( sal_uLong nEvent, void* pData ) 5407 { 5408 // The implementation was moved to CallEventListeners(), 5409 // because derived classes in svtools must be able to 5410 // call the event listeners and ImplCallEventListeners() 5411 // is not exported. 5412 // TODO: replace ImplCallEventListeners() by CallEventListeners() in vcl 5413 5414 CallEventListeners( nEvent, pData ); 5415 } 5416 5417 // ----------------------------------------------------------------------- 5418 5419 void Window::CallEventListeners( sal_uLong nEvent, void* pData ) 5420 { 5421 VclWindowEvent aEvent( this, nEvent, pData ); 5422 5423 ImplDelData aDelData; 5424 ImplAddDel( &aDelData ); 5425 5426 ImplGetSVData()->mpApp->ImplCallEventListeners( &aEvent ); 5427 5428 if ( aDelData.IsDelete() ) 5429 return; 5430 5431 if ( !mpWindowImpl->maEventListeners.empty() ) 5432 mpWindowImpl->maEventListeners.Call( &aEvent ); 5433 5434 if ( aDelData.IsDelete() ) 5435 return; 5436 5437 ImplRemoveDel( &aDelData ); 5438 5439 Window* pWindow = this; 5440 while ( pWindow ) 5441 { 5442 pWindow->ImplAddDel( &aDelData ); 5443 5444 if ( !pWindow->mpWindowImpl->maChildEventListeners.empty() ) 5445 pWindow->mpWindowImpl->maChildEventListeners.Call( &aEvent ); 5446 5447 if ( aDelData.IsDelete() ) 5448 return; 5449 5450 pWindow->ImplRemoveDel( &aDelData ); 5451 5452 pWindow = pWindow->GetParent(); 5453 } 5454 } 5455 5456 void Window::FireVclEvent( VclSimpleEvent* pEvent ) 5457 { 5458 ImplGetSVData()->mpApp->ImplCallEventListeners(pEvent); 5459 } 5460 5461 // ----------------------------------------------------------------------- 5462 5463 void Window::AddEventListener( const Link& rEventListener ) 5464 { 5465 mpWindowImpl->maEventListeners.push_back( rEventListener ); 5466 } 5467 5468 // ----------------------------------------------------------------------- 5469 5470 void Window::RemoveEventListener( const Link& rEventListener ) 5471 { 5472 mpWindowImpl->maEventListeners.remove( rEventListener ); 5473 } 5474 5475 // ----------------------------------------------------------------------- 5476 5477 void Window::AddChildEventListener( const Link& rEventListener ) 5478 { 5479 mpWindowImpl->maChildEventListeners.push_back( rEventListener ); 5480 } 5481 5482 // ----------------------------------------------------------------------- 5483 5484 void Window::RemoveChildEventListener( const Link& rEventListener ) 5485 { 5486 mpWindowImpl->maChildEventListeners.remove( rEventListener ); 5487 } 5488 5489 // ----------------------------------------------------------------------- 5490 5491 sal_uLong Window::PostUserEvent( sal_uLong nEvent, void* pEventData ) 5492 { 5493 sal_uLong nEventId; 5494 PostUserEvent( nEventId, nEvent, pEventData ); 5495 return nEventId; 5496 } 5497 5498 // ----------------------------------------------------------------------- 5499 5500 sal_uLong Window::PostUserEvent( const Link& rLink, void* pCaller ) 5501 { 5502 sal_uLong nEventId; 5503 PostUserEvent( nEventId, rLink, pCaller ); 5504 return nEventId; 5505 } 5506 5507 // ----------------------------------------------------------------------- 5508 5509 sal_Bool Window::PostUserEvent( sal_uLong& rEventId, sal_uLong nEvent, void* pEventData ) 5510 { 5511 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5512 5513 ImplSVEvent* pSVEvent = new ImplSVEvent; 5514 pSVEvent->mnEvent = nEvent; 5515 pSVEvent->mpData = pEventData; 5516 pSVEvent->mpLink = NULL; 5517 pSVEvent->mpWindow = this; 5518 pSVEvent->mbCall = sal_True; 5519 ImplAddDel( &(pSVEvent->maDelData) ); 5520 rEventId = (sal_uLong)pSVEvent; 5521 if ( mpWindowImpl->mpFrame->PostEvent( pSVEvent ) ) 5522 return sal_True; 5523 else 5524 { 5525 rEventId = 0; 5526 ImplRemoveDel( &(pSVEvent->maDelData) ); 5527 delete pSVEvent; 5528 return sal_False; 5529 } 5530 } 5531 5532 // ----------------------------------------------------------------------- 5533 5534 sal_Bool Window::PostUserEvent( sal_uLong& rEventId, const Link& rLink, void* pCaller ) 5535 { 5536 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5537 5538 ImplSVEvent* pSVEvent = new ImplSVEvent; 5539 pSVEvent->mnEvent = 0; 5540 pSVEvent->mpData = pCaller; 5541 pSVEvent->mpLink = new Link( rLink ); 5542 pSVEvent->mpWindow = this; 5543 pSVEvent->mbCall = sal_True; 5544 ImplAddDel( &(pSVEvent->maDelData) ); 5545 rEventId = (sal_uLong)pSVEvent; 5546 if ( mpWindowImpl->mpFrame->PostEvent( pSVEvent ) ) 5547 return sal_True; 5548 else 5549 { 5550 rEventId = 0; 5551 ImplRemoveDel( &(pSVEvent->maDelData) ); 5552 delete pSVEvent; 5553 return sal_False; 5554 } 5555 } 5556 5557 // ----------------------------------------------------------------------- 5558 5559 void Window::RemoveUserEvent( sal_uLong nUserEvent ) 5560 { 5561 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5562 5563 ImplSVEvent* pSVEvent = (ImplSVEvent*)nUserEvent; 5564 5565 DBG_ASSERT( pSVEvent->mpWindow == this, 5566 "Window::RemoveUserEvent(): Event doesn't send to this window or is already removed" ); 5567 DBG_ASSERT( pSVEvent->mbCall, 5568 "Window::RemoveUserEvent(): Event is already removed" ); 5569 5570 if ( pSVEvent->mpWindow ) 5571 { 5572 pSVEvent->mpWindow->ImplRemoveDel( &(pSVEvent->maDelData) ); 5573 pSVEvent->mpWindow = NULL; 5574 } 5575 5576 pSVEvent->mbCall = sal_False; 5577 } 5578 5579 // ----------------------------------------------------------------------- 5580 5581 IMPL_LINK( Window, ImplAsyncStateChangedHdl, void*, pState ) 5582 { 5583 StateChanged( (StateChangedType)(sal_uLong)pState ); 5584 return 0; 5585 } 5586 5587 // ----------------------------------------------------------------------- 5588 5589 void Window::PostStateChanged( StateChangedType nState ) 5590 { 5591 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5592 5593 PostUserEvent( LINK( this, Window, ImplAsyncStateChangedHdl ), (void*)(sal_uLong)nState ); 5594 } 5595 5596 // ----------------------------------------------------------------------- 5597 5598 sal_Bool Window::IsLocked( sal_Bool bChilds ) const 5599 { 5600 if ( mpWindowImpl->mnLockCount != 0 ) 5601 return sal_True; 5602 5603 if ( bChilds || mpWindowImpl->mbChildNotify ) 5604 { 5605 Window* pChild = mpWindowImpl->mpFirstChild; 5606 while ( pChild ) 5607 { 5608 if ( pChild->IsLocked( sal_True ) ) 5609 return sal_True; 5610 pChild = pChild->mpWindowImpl->mpNext; 5611 } 5612 } 5613 5614 return sal_False; 5615 } 5616 5617 // ----------------------------------------------------------------------- 5618 5619 void Window::SetStyle( WinBits nStyle ) 5620 { 5621 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5622 5623 if ( mpWindowImpl->mnStyle != nStyle ) 5624 { 5625 mpWindowImpl->mnPrevStyle = mpWindowImpl->mnStyle; 5626 mpWindowImpl->mnStyle = nStyle; 5627 StateChanged( STATE_CHANGE_STYLE ); 5628 } 5629 } 5630 5631 // ----------------------------------------------------------------------- 5632 5633 void Window::SetExtendedStyle( WinBits nExtendedStyle ) 5634 { 5635 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5636 5637 if ( mpWindowImpl->mnExtendedStyle != nExtendedStyle ) 5638 { 5639 Window* pWindow = ImplGetBorderWindow(); 5640 if( ! pWindow ) 5641 pWindow = this; 5642 if( pWindow->mpWindowImpl->mbFrame ) 5643 { 5644 SalExtStyle nExt = 0; 5645 if( (nExtendedStyle & WB_EXT_DOCUMENT) ) 5646 nExt |= SAL_FRAME_EXT_STYLE_DOCUMENT; 5647 if( (nExtendedStyle & WB_EXT_DOCMODIFIED) ) 5648 nExt |= SAL_FRAME_EXT_STYLE_DOCMODIFIED; 5649 5650 pWindow->ImplGetFrame()->SetExtendedFrameStyle( nExt ); 5651 } 5652 mpWindowImpl->mnPrevExtendedStyle = mpWindowImpl->mnExtendedStyle; 5653 mpWindowImpl->mnExtendedStyle = nExtendedStyle; 5654 StateChanged( STATE_CHANGE_EXTENDEDSTYLE ); 5655 } 5656 } 5657 5658 // ----------------------------------------------------------------------- 5659 5660 SystemWindow* Window::GetSystemWindow() const 5661 { 5662 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5663 5664 const Window* pWin = this; 5665 while ( pWin && !pWin->IsSystemWindow() ) 5666 pWin = pWin->GetParent(); 5667 return (SystemWindow*)pWin; 5668 } 5669 5670 // ----------------------------------------------------------------------- 5671 5672 void Window::SetBorderStyle( sal_uInt16 nBorderStyle ) 5673 { 5674 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5675 5676 if ( mpWindowImpl->mpBorderWindow ) 5677 { 5678 if( nBorderStyle == WINDOW_BORDER_REMOVEBORDER && 5679 ! mpWindowImpl->mpBorderWindow->mpWindowImpl->mbFrame && 5680 mpWindowImpl->mpBorderWindow->mpWindowImpl->mpParent 5681 ) 5682 { 5683 // this is a little awkward: some controls (e.g. svtools ProgressBar) 5684 // cannot avoid getting constructed with WB_BORDER but want to disable 5685 // borders in case of NWF drawing. So they need a method to remove their border window 5686 Window* pBorderWin = mpWindowImpl->mpBorderWindow; 5687 // remove us as border window's client 5688 pBorderWin->mpWindowImpl->mpClientWindow = NULL; 5689 mpWindowImpl->mpBorderWindow = NULL; 5690 mpWindowImpl->mpRealParent = pBorderWin->mpWindowImpl->mpParent; 5691 // reparent us above the border window 5692 SetParent( pBorderWin->mpWindowImpl->mpParent ); 5693 // set us to the position and size of our previous border 5694 Point aBorderPos( pBorderWin->GetPosPixel() ); 5695 Size aBorderSize( pBorderWin->GetSizePixel() ); 5696 SetPosSizePixel( aBorderPos.X(), aBorderPos.Y(), aBorderSize.Width(), aBorderSize.Height() ); 5697 // release border window 5698 delete pBorderWin; 5699 5700 // set new style bits 5701 SetStyle( GetStyle() & (~WB_BORDER) ); 5702 } 5703 else 5704 { 5705 if ( mpWindowImpl->mpBorderWindow->GetType() == WINDOW_BORDERWINDOW ) 5706 ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->SetBorderStyle( nBorderStyle ); 5707 else 5708 mpWindowImpl->mpBorderWindow->SetBorderStyle( nBorderStyle ); 5709 } 5710 } 5711 } 5712 5713 // ----------------------------------------------------------------------- 5714 5715 sal_uInt16 Window::GetBorderStyle() const 5716 { 5717 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5718 5719 if ( mpWindowImpl->mpBorderWindow ) 5720 { 5721 if ( mpWindowImpl->mpBorderWindow->GetType() == WINDOW_BORDERWINDOW ) 5722 return ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->GetBorderStyle(); 5723 else 5724 return mpWindowImpl->mpBorderWindow->GetBorderStyle(); 5725 } 5726 5727 return 0; 5728 } 5729 5730 // ----------------------------------------------------------------------- 5731 5732 long Window::CalcTitleWidth() const 5733 { 5734 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5735 5736 if ( mpWindowImpl->mpBorderWindow ) 5737 { 5738 if ( mpWindowImpl->mpBorderWindow->GetType() == WINDOW_BORDERWINDOW ) 5739 return ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->CalcTitleWidth(); 5740 else 5741 return mpWindowImpl->mpBorderWindow->CalcTitleWidth(); 5742 } 5743 else if ( mpWindowImpl->mbFrame && (mpWindowImpl->mnStyle & WB_MOVEABLE) ) 5744 { 5745 // Fuer Frame-Fenster raten wir die Breite, da wir den Border fuer 5746 // externe Dialoge nicht kennen 5747 const StyleSettings& rStyleSettings = GetSettings().GetStyleSettings(); 5748 Font aFont = GetFont(); 5749 ((Window*)this)->SetPointFont( rStyleSettings.GetTitleFont() ); 5750 long nTitleWidth = GetTextWidth( GetText() ); 5751 ((Window*)this)->SetFont( aFont ); 5752 nTitleWidth += rStyleSettings.GetTitleHeight() * 3; 5753 nTitleWidth += rStyleSettings.GetBorderSize() * 2; 5754 nTitleWidth += 10; 5755 return nTitleWidth; 5756 } 5757 5758 return 0; 5759 } 5760 5761 // ----------------------------------------------------------------------- 5762 5763 void Window::EnableClipSiblings( sal_Bool bClipSiblings ) 5764 { 5765 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5766 5767 if ( mpWindowImpl->mpBorderWindow ) 5768 mpWindowImpl->mpBorderWindow->EnableClipSiblings( bClipSiblings ); 5769 5770 mpWindowImpl->mbClipSiblings = bClipSiblings; 5771 } 5772 5773 // ----------------------------------------------------------------------- 5774 5775 void Window::SetMouseTransparent( sal_Bool bTransparent ) 5776 { 5777 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5778 5779 if ( mpWindowImpl->mpBorderWindow ) 5780 mpWindowImpl->mpBorderWindow->SetMouseTransparent( bTransparent ); 5781 5782 if( mpWindowImpl->mpSysObj ) 5783 mpWindowImpl->mpSysObj->SetMouseTransparent( bTransparent ); 5784 5785 mpWindowImpl->mbMouseTransparent = bTransparent; 5786 } 5787 5788 // ----------------------------------------------------------------------- 5789 5790 void Window::SetPaintTransparent( sal_Bool bTransparent ) 5791 { 5792 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5793 5794 // transparency is not useful for frames as the background would have to be provided by a different frame 5795 if( bTransparent && mpWindowImpl->mbFrame ) 5796 return; 5797 5798 if ( mpWindowImpl->mpBorderWindow ) 5799 mpWindowImpl->mpBorderWindow->SetPaintTransparent( bTransparent ); 5800 5801 mpWindowImpl->mbPaintTransparent = bTransparent; 5802 } 5803 5804 // ----------------------------------------------------------------------- 5805 5806 void Window::SetInputContext( const InputContext& rInputContext ) 5807 { 5808 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5809 5810 mpWindowImpl->maInputContext = rInputContext; 5811 if ( !mpWindowImpl->mbInFocusHdl && HasFocus() ) 5812 ImplNewInputContext(); 5813 } 5814 5815 // ----------------------------------------------------------------------- 5816 5817 void Window::EndExtTextInput( sal_uInt16 nFlags ) 5818 { 5819 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5820 5821 if ( mpWindowImpl->mbExtTextInput ) 5822 ImplGetFrame()->EndExtTextInput( nFlags ); 5823 } 5824 5825 // ----------------------------------------------------------------------- 5826 5827 void Window::SetCursorRect( const Rectangle* pRect, long nExtTextInputWidth ) 5828 { 5829 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5830 5831 ImplWinData* pWinData = ImplGetWinData(); 5832 if ( pWinData->mpCursorRect ) 5833 { 5834 if ( pRect ) 5835 *pWinData->mpCursorRect = *pRect; 5836 else 5837 { 5838 delete pWinData->mpCursorRect; 5839 pWinData->mpCursorRect = NULL; 5840 } 5841 } 5842 else 5843 { 5844 if ( pRect ) 5845 pWinData->mpCursorRect = new Rectangle( *pRect ); 5846 } 5847 5848 pWinData->mnCursorExtWidth = nExtTextInputWidth; 5849 5850 } 5851 5852 // ----------------------------------------------------------------------- 5853 5854 const Rectangle* Window::GetCursorRect() const 5855 { 5856 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5857 5858 ImplWinData* pWinData = ImplGetWinData(); 5859 return pWinData->mpCursorRect; 5860 } 5861 5862 // ----------------------------------------------------------------------- 5863 5864 long Window::GetCursorExtTextInputWidth() const 5865 { 5866 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5867 5868 ImplWinData* pWinData = ImplGetWinData(); 5869 return pWinData->mnCursorExtWidth; 5870 } 5871 5872 // ----------------------------------------------------------------------- 5873 void Window::SetSettings( const AllSettings& rSettings ) 5874 { 5875 SetSettings( rSettings, sal_False ); 5876 } 5877 5878 void Window::SetSettings( const AllSettings& rSettings, sal_Bool bChild ) 5879 { 5880 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5881 5882 if ( mpWindowImpl->mpBorderWindow ) 5883 { 5884 mpWindowImpl->mpBorderWindow->SetSettings( rSettings, sal_False ); 5885 if ( (mpWindowImpl->mpBorderWindow->GetType() == WINDOW_BORDERWINDOW) && 5886 ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->mpMenuBarWindow ) 5887 ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->mpMenuBarWindow->SetSettings( rSettings, sal_True ); 5888 } 5889 5890 AllSettings aOldSettings = maSettings; 5891 OutputDevice::SetSettings( rSettings ); 5892 sal_uLong nChangeFlags = aOldSettings.GetChangeFlags( rSettings ); 5893 5894 // AppFont-Aufloesung und DPI-Aufloesung neu berechnen 5895 ImplInitResolutionSettings(); 5896 5897 if ( nChangeFlags ) 5898 { 5899 DataChangedEvent aDCEvt( DATACHANGED_SETTINGS, &aOldSettings, nChangeFlags ); 5900 DataChanged( aDCEvt ); 5901 } 5902 5903 if ( bChild || mpWindowImpl->mbChildNotify ) 5904 { 5905 Window* pChild = mpWindowImpl->mpFirstChild; 5906 while ( pChild ) 5907 { 5908 pChild->SetSettings( rSettings, bChild ); 5909 pChild = pChild->mpWindowImpl->mpNext; 5910 } 5911 } 5912 } 5913 5914 // ----------------------------------------------------------------------- 5915 5916 void Window::UpdateSettings( const AllSettings& rSettings, sal_Bool bChild ) 5917 { 5918 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5919 5920 if ( mpWindowImpl->mpBorderWindow ) 5921 { 5922 mpWindowImpl->mpBorderWindow->UpdateSettings( rSettings, sal_False ); 5923 if ( (mpWindowImpl->mpBorderWindow->GetType() == WINDOW_BORDERWINDOW) && 5924 ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->mpMenuBarWindow ) 5925 ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->mpMenuBarWindow->UpdateSettings( rSettings, sal_True ); 5926 } 5927 5928 AllSettings aOldSettings = maSettings; 5929 sal_uLong nChangeFlags = maSettings.Update( maSettings.GetWindowUpdate(), rSettings ); 5930 nChangeFlags |= SETTINGS_IN_UPDATE_SETTINGS; // Set this flag so the receiver of the data changed 5931 // event can distinguish between the changing of global 5932 // setting and a local change ( with SetSettings ) 5933 5934 // AppFont-Aufloesung und DPI-Aufloesung neu berechnen 5935 ImplInitResolutionSettings(); 5936 5937 /* #i73785# 5938 * do not overwrite a WheelBehavior with false 5939 * this looks kind of a hack, but WheelBehavior 5940 * is always a local change, not a system property, 5941 * so we can spare all our users the hassle of reacting on 5942 * this in their respective DataChanged. 5943 */ 5944 MouseSettings aSet( maSettings.GetMouseSettings() ); 5945 aSet.SetWheelBehavior( aOldSettings.GetMouseSettings().GetWheelBehavior() ); 5946 maSettings.SetMouseSettings( aSet ); 5947 5948 if( (nChangeFlags & SETTINGS_STYLE) && IsBackground() ) 5949 { 5950 Wallpaper aWallpaper = GetBackground(); 5951 if( !aWallpaper.IsBitmap() && !aWallpaper.IsGradient() ) 5952 { 5953 if ( mpWindowImpl->mnStyle & WB_3DLOOK ) 5954 SetBackground( Wallpaper( rSettings.GetStyleSettings().GetFaceColor() ) ); 5955 else 5956 SetBackground( Wallpaper( rSettings.GetStyleSettings().GetWindowColor() ) ); 5957 } 5958 } 5959 5960 if ( nChangeFlags ) 5961 { 5962 DataChangedEvent aDCEvt( DATACHANGED_SETTINGS, &aOldSettings, nChangeFlags ); 5963 DataChanged( aDCEvt ); 5964 // notify data change handler 5965 ImplCallEventListeners( VCLEVENT_WINDOW_DATACHANGED, &aDCEvt); 5966 } 5967 5968 if ( bChild || mpWindowImpl->mbChildNotify ) 5969 { 5970 Window* pChild = mpWindowImpl->mpFirstChild; 5971 while ( pChild ) 5972 { 5973 pChild->UpdateSettings( rSettings, bChild ); 5974 pChild = pChild->mpWindowImpl->mpNext; 5975 } 5976 } 5977 } 5978 5979 // ----------------------------------------------------------------------- 5980 5981 void Window::NotifyAllChilds( DataChangedEvent& rDCEvt ) 5982 { 5983 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 5984 5985 DataChanged( rDCEvt ); 5986 5987 Window* pChild = mpWindowImpl->mpFirstChild; 5988 while ( pChild ) 5989 { 5990 pChild->NotifyAllChilds( rDCEvt ); 5991 pChild = pChild->mpWindowImpl->mpNext; 5992 } 5993 } 5994 5995 // ----------------------------------------------------------------------- 5996 5997 void Window::SetPointFont( const Font& rFont ) 5998 { 5999 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6000 6001 Font aFont = rFont; 6002 ImplPointToLogic( aFont ); 6003 SetFont( aFont ); 6004 } 6005 6006 // ----------------------------------------------------------------------- 6007 6008 Font Window::GetPointFont() const 6009 { 6010 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6011 6012 Font aFont = GetFont(); 6013 ImplLogicToPoint( aFont ); 6014 return aFont; 6015 } 6016 6017 // ----------------------------------------------------------------------- 6018 6019 // TODO: remove in next incompatible build 6020 void Window::GetFontResolution( sal_Int32& nDPIX, sal_Int32& nDPIY ) const 6021 { 6022 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6023 6024 nDPIX = mpWindowImpl->mpFrameData->mnDPIX; 6025 nDPIY = mpWindowImpl->mpFrameData->mnDPIY; 6026 } 6027 6028 // ----------------------------------------------------------------------- 6029 6030 void Window::SetParentClipMode( sal_uInt16 nMode ) 6031 { 6032 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6033 6034 if ( mpWindowImpl->mpBorderWindow ) 6035 mpWindowImpl->mpBorderWindow->SetParentClipMode( nMode ); 6036 else 6037 { 6038 if ( !ImplIsOverlapWindow() ) 6039 { 6040 mpWindowImpl->mnParentClipMode = nMode; 6041 if ( nMode & PARENTCLIPMODE_CLIP ) 6042 mpWindowImpl->mpParent->mpWindowImpl->mbClipChildren = sal_True; 6043 } 6044 } 6045 } 6046 6047 // ----------------------------------------------------------------------- 6048 6049 sal_uInt16 Window::GetParentClipMode() const 6050 { 6051 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6052 6053 if ( mpWindowImpl->mpBorderWindow ) 6054 return mpWindowImpl->mpBorderWindow->GetParentClipMode(); 6055 else 6056 return mpWindowImpl->mnParentClipMode; 6057 } 6058 6059 // ----------------------------------------------------------------------- 6060 6061 void Window::SetWindowRegionPixel() 6062 { 6063 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6064 6065 if ( mpWindowImpl->mpBorderWindow ) 6066 mpWindowImpl->mpBorderWindow->SetWindowRegionPixel(); 6067 else if( mpWindowImpl->mbFrame ) 6068 { 6069 mpWindowImpl->maWinRegion = Region(true); 6070 mpWindowImpl->mbWinRegion = sal_False; 6071 mpWindowImpl->mpFrame->ResetClipRegion(); 6072 } 6073 else 6074 { 6075 if ( mpWindowImpl->mbWinRegion ) 6076 { 6077 mpWindowImpl->maWinRegion = Region(true); 6078 mpWindowImpl->mbWinRegion = sal_False; 6079 ImplSetClipFlag(); 6080 6081 if ( IsReallyVisible() ) 6082 { 6083 // Hintergrund-Sicherung zuruecksetzen 6084 if ( mpWindowImpl->mpOverlapData && mpWindowImpl->mpOverlapData->mpSaveBackDev ) 6085 ImplDeleteOverlapBackground(); 6086 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 6087 ImplInvalidateAllOverlapBackgrounds(); 6088 Rectangle aRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 6089 Region aRegion( aRect ); 6090 ImplInvalidateParentFrameRegion( aRegion ); 6091 } 6092 } 6093 } 6094 } 6095 6096 // ----------------------------------------------------------------------- 6097 6098 void Window::SetWindowRegionPixel( const Region& rRegion ) 6099 { 6100 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6101 6102 if ( mpWindowImpl->mpBorderWindow ) 6103 mpWindowImpl->mpBorderWindow->SetWindowRegionPixel( rRegion ); 6104 else if( mpWindowImpl->mbFrame ) 6105 { 6106 if( !rRegion.IsNull() ) 6107 { 6108 mpWindowImpl->maWinRegion = rRegion; 6109 mpWindowImpl->mbWinRegion = ! rRegion.IsEmpty(); 6110 6111 if( mpWindowImpl->mbWinRegion ) 6112 { 6113 // ClipRegion setzen/updaten 6114 RectangleVector aRectangles; 6115 mpWindowImpl->maWinRegion.GetRegionRectangles(aRectangles); 6116 mpWindowImpl->mpFrame->BeginSetClipRegion(aRectangles.size()); 6117 6118 for(RectangleVector::const_iterator aRectIter(aRectangles.begin()); aRectIter != aRectangles.end(); aRectIter++) 6119 { 6120 mpWindowImpl->mpFrame->UnionClipRegion( 6121 aRectIter->Left(), 6122 aRectIter->Top(), 6123 aRectIter->GetWidth(), // orig nWidth was ((R - L) + 1), same as GetWidth does 6124 aRectIter->GetHeight()); // same for height 6125 } 6126 6127 mpWindowImpl->mpFrame->EndSetClipRegion(); 6128 6129 //long nX; 6130 //long nY; 6131 //long nWidth; 6132 //long nHeight; 6133 //sal_uLong nRectCount; 6134 //ImplRegionInfo aInfo; 6135 //sal_Bool bRegionRect; 6136 // 6137 //nRectCount = mpWindowImpl->maWinRegion.GetRectCount(); 6138 //mpWindowImpl->mpFrame->BeginSetClipRegion( nRectCount ); 6139 //bRegionRect = mpWindowImpl->maWinRegion.ImplGetFirstRect( aInfo, nX, nY, nWidth, nHeight ); 6140 //while ( bRegionRect ) 6141 //{ 6142 // mpWindowImpl->mpFrame->UnionClipRegion( nX, nY, nWidth, nHeight ); 6143 // bRegionRect = mpWindowImpl->maWinRegion.ImplGetNextRect( aInfo, nX, nY, nWidth, nHeight ); 6144 //} 6145 //mpWindowImpl->mpFrame->EndSetClipRegion(); 6146 } 6147 else 6148 SetWindowRegionPixel(); 6149 } 6150 else 6151 SetWindowRegionPixel(); 6152 } 6153 else 6154 { 6155 sal_Bool bInvalidate = sal_False; 6156 6157 if ( rRegion.IsNull() ) 6158 { 6159 if ( mpWindowImpl->mbWinRegion ) 6160 { 6161 mpWindowImpl->maWinRegion = Region(true); 6162 mpWindowImpl->mbWinRegion = sal_False; 6163 ImplSetClipFlag(); 6164 bInvalidate = sal_True; 6165 } 6166 } 6167 else 6168 { 6169 mpWindowImpl->maWinRegion = rRegion; 6170 mpWindowImpl->mbWinRegion = sal_True; 6171 ImplSetClipFlag(); 6172 bInvalidate = sal_True; 6173 } 6174 6175 if ( IsReallyVisible() ) 6176 { 6177 // Hintergrund-Sicherung zuruecksetzen 6178 if ( mpWindowImpl->mpOverlapData && mpWindowImpl->mpOverlapData->mpSaveBackDev ) 6179 ImplDeleteOverlapBackground(); 6180 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 6181 ImplInvalidateAllOverlapBackgrounds(); 6182 Rectangle aRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 6183 Region aRegion( aRect ); 6184 ImplInvalidateParentFrameRegion( aRegion ); 6185 } 6186 } 6187 } 6188 6189 // ----------------------------------------------------------------------- 6190 6191 const Region& Window::GetWindowRegionPixel() const 6192 { 6193 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6194 6195 if ( mpWindowImpl->mpBorderWindow ) 6196 return mpWindowImpl->mpBorderWindow->GetWindowRegionPixel(); 6197 else 6198 return mpWindowImpl->maWinRegion; 6199 } 6200 6201 // ----------------------------------------------------------------------- 6202 6203 sal_Bool Window::IsWindowRegionPixel() const 6204 { 6205 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6206 6207 if ( mpWindowImpl->mpBorderWindow ) 6208 return mpWindowImpl->mpBorderWindow->IsWindowRegionPixel(); 6209 else 6210 return mpWindowImpl->mbWinRegion; 6211 } 6212 6213 // ----------------------------------------------------------------------- 6214 6215 Region Window::GetWindowClipRegionPixel( sal_uInt16 nFlags ) const 6216 { 6217 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6218 6219 Region aWinClipRegion; 6220 6221 if ( nFlags & WINDOW_GETCLIPREGION_NOCHILDREN ) 6222 { 6223 if ( mpWindowImpl->mbInitWinClipRegion ) 6224 ((Window*)this)->ImplInitWinClipRegion(); 6225 aWinClipRegion = mpWindowImpl->maWinClipRegion; 6226 } 6227 else 6228 { 6229 Region* pWinChildClipRegion = ((Window*)this)->ImplGetWinChildClipRegion(); 6230 aWinClipRegion = *pWinChildClipRegion; 6231 // --- RTL --- remirror clip region before passing it to somebody 6232 if( ImplIsAntiparallel() ) 6233 ImplReMirror( aWinClipRegion ); 6234 } 6235 6236 if ( nFlags & WINDOW_GETCLIPREGION_NULL ) 6237 { 6238 Rectangle aWinRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 6239 Region aWinRegion( aWinRect ); 6240 6241 if ( aWinRegion == aWinClipRegion ) 6242 aWinClipRegion.SetNull(); 6243 } 6244 6245 aWinClipRegion.Move( -mnOutOffX, -mnOutOffY ); 6246 6247 return aWinClipRegion; 6248 } 6249 6250 // ----------------------------------------------------------------------- 6251 6252 Region Window::GetPaintRegion() const 6253 { 6254 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6255 6256 if ( mpWindowImpl->mpPaintRegion ) 6257 { 6258 Region aRegion = *mpWindowImpl->mpPaintRegion; 6259 aRegion.Move( -mnOutOffX, -mnOutOffY ); 6260 return PixelToLogic( aRegion ); 6261 } 6262 else 6263 { 6264 Region aPaintRegion(true); 6265 return aPaintRegion; 6266 } 6267 } 6268 6269 // ----------------------------------------------------------------------- 6270 6271 void Window::ExpandPaintClipRegion( const Region& rRegion ) 6272 { 6273 if( mpWindowImpl->mpPaintRegion ) 6274 { 6275 Region aPixRegion = LogicToPixel( rRegion ); 6276 Region aDevPixRegion = ImplPixelToDevicePixel( aPixRegion ); 6277 6278 Region aWinChildRegion = *ImplGetWinChildClipRegion(); 6279 // --- RTL -- only this region is in frame coordinates, so re-mirror it 6280 if( ImplIsAntiparallel() ) 6281 ImplReMirror( aWinChildRegion ); 6282 aDevPixRegion.Intersect( aWinChildRegion ); 6283 if( ! aDevPixRegion.IsEmpty() ) 6284 { 6285 mpWindowImpl->mpPaintRegion->Union( aDevPixRegion ); 6286 mbInitClipRegion = sal_True; 6287 } 6288 } 6289 } 6290 6291 // ----------------------------------------------------------------------- 6292 6293 static SystemWindow *ImplGetLastSystemWindow( Window *pWin ) 6294 { 6295 // get the most top-level system window, the one that contains the taskpanelist 6296 SystemWindow *pSysWin = NULL; 6297 if( !pWin ) 6298 return pSysWin; 6299 Window *pMyParent = pWin; 6300 while ( pMyParent ) 6301 { 6302 if ( pMyParent->IsSystemWindow() ) 6303 pSysWin = (SystemWindow*)pMyParent; 6304 pMyParent = pMyParent->GetParent(); 6305 } 6306 return pSysWin; 6307 } 6308 6309 void Window::SetParent( Window* pNewParent ) 6310 { 6311 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6312 DBG_ASSERT( pNewParent, "Window::SetParent(): pParent == NULL" ); 6313 DBG_ASSERT( pNewParent != this, "someone tried to reparent a window to itself" ); 6314 6315 if( pNewParent == this ) 6316 return; 6317 6318 // check if the taskpanelist would change and move the window pointer accordingly 6319 SystemWindow *pSysWin = ImplGetLastSystemWindow(this); 6320 SystemWindow *pNewSysWin = NULL; 6321 sal_Bool bChangeTaskPaneList = sal_False; 6322 if( pSysWin && pSysWin->ImplIsInTaskPaneList( this ) ) 6323 { 6324 pNewSysWin = ImplGetLastSystemWindow( pNewParent ); 6325 if( pNewSysWin && pNewSysWin != pSysWin ) 6326 { 6327 bChangeTaskPaneList = sal_True; 6328 pSysWin->GetTaskPaneList()->RemoveWindow( this ); 6329 } 6330 } 6331 // remove ownerdraw decorated windows from list in the top-most frame window 6332 if( (GetStyle() & WB_OWNERDRAWDECORATION) && mpWindowImpl->mbFrame ) 6333 { 6334 ::std::vector< Window* >& rList = ImplGetOwnerDrawList(); 6335 ::std::vector< Window* >::iterator p; 6336 p = ::std::find( rList.begin(), rList.end(), this ); 6337 if( p != rList.end() ) 6338 rList.erase( p ); 6339 } 6340 6341 ImplSetFrameParent( pNewParent ); 6342 6343 if ( mpWindowImpl->mpBorderWindow ) 6344 { 6345 mpWindowImpl->mpRealParent = pNewParent; 6346 mpWindowImpl->mpBorderWindow->SetParent( pNewParent ); 6347 return; 6348 } 6349 6350 if ( mpWindowImpl->mpParent == pNewParent ) 6351 return; 6352 6353 if ( mpWindowImpl->mbFrame ) 6354 mpWindowImpl->mpFrame->SetParent( pNewParent->mpWindowImpl->mpFrame ); 6355 6356 sal_Bool bVisible = IsVisible(); 6357 Show( sal_False, SHOW_NOFOCUSCHANGE ); 6358 6359 // Testen, ob sich das Overlap-Window aendert 6360 Window* pOldOverlapWindow; 6361 Window* pNewOverlapWindow = NULL; 6362 if ( ImplIsOverlapWindow() ) 6363 pOldOverlapWindow = NULL; 6364 else 6365 { 6366 pNewOverlapWindow = pNewParent->ImplGetFirstOverlapWindow(); 6367 if ( mpWindowImpl->mpOverlapWindow != pNewOverlapWindow ) 6368 pOldOverlapWindow = mpWindowImpl->mpOverlapWindow; 6369 else 6370 pOldOverlapWindow = NULL; 6371 } 6372 6373 // Fenster in der Hirachie umsetzen 6374 sal_Bool bFocusOverlapWin = HasChildPathFocus( sal_True ); 6375 sal_Bool bFocusWin = HasChildPathFocus(); 6376 sal_Bool bNewFrame = pNewParent->mpWindowImpl->mpFrameWindow != mpWindowImpl->mpFrameWindow; 6377 if ( bNewFrame ) 6378 { 6379 if ( mpWindowImpl->mpFrameData->mpFocusWin ) 6380 { 6381 if ( IsWindowOrChild( mpWindowImpl->mpFrameData->mpFocusWin ) ) 6382 mpWindowImpl->mpFrameData->mpFocusWin = NULL; 6383 } 6384 if ( mpWindowImpl->mpFrameData->mpMouseMoveWin ) 6385 { 6386 if ( IsWindowOrChild( mpWindowImpl->mpFrameData->mpMouseMoveWin ) ) 6387 mpWindowImpl->mpFrameData->mpMouseMoveWin = NULL; 6388 } 6389 if ( mpWindowImpl->mpFrameData->mpMouseDownWin ) 6390 { 6391 if ( IsWindowOrChild( mpWindowImpl->mpFrameData->mpMouseDownWin ) ) 6392 mpWindowImpl->mpFrameData->mpMouseDownWin = NULL; 6393 } 6394 } 6395 ImplRemoveWindow( bNewFrame ); 6396 ImplInsertWindow( pNewParent ); 6397 if ( mpWindowImpl->mnParentClipMode & PARENTCLIPMODE_CLIP ) 6398 pNewParent->mpWindowImpl->mbClipChildren = sal_True; 6399 ImplUpdateWindowPtr(); 6400 if ( ImplUpdatePos() ) 6401 ImplUpdateSysObjPos(); 6402 6403 // Wenn sich das Overlap-Window geaendert hat, dann muss getestet werden, 6404 // ob auch OverlapWindow die das Child-Fenster als Parent gehabt haben 6405 // in der Window-Hirachie umgesetzt werden muessen 6406 if ( ImplIsOverlapWindow() ) 6407 { 6408 if ( bNewFrame ) 6409 { 6410 Window* pOverlapWindow = mpWindowImpl->mpFirstOverlap; 6411 while ( pOverlapWindow ) 6412 { 6413 Window* pNextOverlapWindow = pOverlapWindow->mpWindowImpl->mpNext; 6414 pOverlapWindow->ImplUpdateOverlapWindowPtr( bNewFrame ); 6415 pOverlapWindow = pNextOverlapWindow; 6416 } 6417 } 6418 } 6419 else if ( pOldOverlapWindow ) 6420 { 6421 // Focus-Save zuruecksetzen 6422 if ( bFocusWin || 6423 (pOldOverlapWindow->mpWindowImpl->mpLastFocusWindow && 6424 IsWindowOrChild( pOldOverlapWindow->mpWindowImpl->mpLastFocusWindow )) ) 6425 pOldOverlapWindow->mpWindowImpl->mpLastFocusWindow = NULL; 6426 6427 Window* pOverlapWindow = pOldOverlapWindow->mpWindowImpl->mpFirstOverlap; 6428 while ( pOverlapWindow ) 6429 { 6430 Window* pNextOverlapWindow = pOverlapWindow->mpWindowImpl->mpNext; 6431 if ( ImplIsRealParentPath( pOverlapWindow->ImplGetWindow() ) ) 6432 pOverlapWindow->ImplUpdateOverlapWindowPtr( bNewFrame ); 6433 pOverlapWindow = pNextOverlapWindow; 6434 } 6435 6436 // Activate-Status beim naechsten Overlap-Window updaten 6437 if ( HasChildPathFocus( sal_True ) ) 6438 ImplCallFocusChangeActivate( pNewOverlapWindow, pOldOverlapWindow ); 6439 } 6440 6441 // Activate-Status mit umsetzen 6442 if ( bNewFrame ) 6443 { 6444 if ( (GetType() == WINDOW_BORDERWINDOW) && 6445 (ImplGetWindow()->GetType() == WINDOW_FLOATINGWINDOW) ) 6446 ((ImplBorderWindow*)this)->SetDisplayActive( mpWindowImpl->mpFrameData->mbHasFocus ); 6447 } 6448 6449 // Focus evtl. auf den neuen Frame umsetzen, wenn FocusWindow mit 6450 // SetParent() umgesetzt wird 6451 if ( bFocusOverlapWin ) 6452 { 6453 mpWindowImpl->mpFrameData->mpFocusWin = Application::GetFocusWindow(); 6454 if ( !mpWindowImpl->mpFrameData->mbHasFocus ) 6455 { 6456 mpWindowImpl->mpFrame->ToTop( 0 ); 6457 } 6458 } 6459 6460 // Assure DragSource and DropTarget members are created 6461 if ( bNewFrame ) 6462 { 6463 GetDropTarget(); 6464 } 6465 6466 if( bChangeTaskPaneList ) 6467 pNewSysWin->GetTaskPaneList()->AddWindow( this ); 6468 6469 if( (GetStyle() & WB_OWNERDRAWDECORATION) && mpWindowImpl->mbFrame ) 6470 ImplGetOwnerDrawList().push_back( this ); 6471 6472 if ( bVisible ) 6473 Show( sal_True, SHOW_NOFOCUSCHANGE | SHOW_NOACTIVATE ); 6474 } 6475 6476 // ----------------------------------------------------------------------- 6477 6478 void Window::Show( sal_Bool bVisible, sal_uInt16 nFlags ) 6479 { 6480 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6481 6482 if ( mpWindowImpl->mbVisible == bVisible ) 6483 return; 6484 6485 ImplDelData aDogTag( this ); 6486 6487 sal_Bool bRealVisibilityChanged = sal_False; 6488 mpWindowImpl->mbVisible = (bVisible != 0); 6489 6490 if ( !bVisible ) 6491 { 6492 ImplHideAllOverlaps(); 6493 if( aDogTag.IsDelete() ) 6494 return; 6495 6496 if ( mpWindowImpl->mpBorderWindow ) 6497 { 6498 sal_Bool bOldUpdate = mpWindowImpl->mpBorderWindow->mpWindowImpl->mbNoParentUpdate; 6499 if ( mpWindowImpl->mbNoParentUpdate ) 6500 mpWindowImpl->mpBorderWindow->mpWindowImpl->mbNoParentUpdate = sal_True; 6501 mpWindowImpl->mpBorderWindow->Show( sal_False, nFlags ); 6502 mpWindowImpl->mpBorderWindow->mpWindowImpl->mbNoParentUpdate = bOldUpdate; 6503 } 6504 else if ( mpWindowImpl->mbFrame ) 6505 { 6506 mpWindowImpl->mbSuppressAccessibilityEvents = sal_True; 6507 mpWindowImpl->mpFrame->Show( sal_False, sal_False ); 6508 } 6509 6510 StateChanged( STATE_CHANGE_VISIBLE ); 6511 6512 if ( mpWindowImpl->mbReallyVisible ) 6513 { 6514 Region aInvRegion; 6515 sal_Bool bSaveBack = sal_False; 6516 6517 if ( ImplIsOverlapWindow() && !mpWindowImpl->mbFrame ) 6518 { 6519 if ( ImplRestoreOverlapBackground( aInvRegion ) ) 6520 bSaveBack = sal_True; 6521 } 6522 6523 if ( !bSaveBack ) 6524 { 6525 if ( mpWindowImpl->mbInitWinClipRegion ) 6526 ImplInitWinClipRegion(); 6527 aInvRegion = mpWindowImpl->maWinClipRegion; 6528 } 6529 6530 if( aDogTag.IsDelete() ) 6531 return; 6532 6533 bRealVisibilityChanged = mpWindowImpl->mbReallyVisible; 6534 ImplResetReallyVisible(); 6535 ImplSetClipFlag(); 6536 6537 if ( ImplIsOverlapWindow() && !mpWindowImpl->mbFrame ) 6538 { 6539 // Focus umsetzen 6540 if ( !(nFlags & SHOW_NOFOCUSCHANGE) && HasChildPathFocus() ) 6541 { 6542 if ( mpWindowImpl->mpOverlapWindow->IsEnabled() && 6543 mpWindowImpl->mpOverlapWindow->IsInputEnabled() && 6544 ! mpWindowImpl->mpOverlapWindow->IsInModalMode() 6545 ) 6546 mpWindowImpl->mpOverlapWindow->GrabFocus(); 6547 } 6548 } 6549 6550 if ( !mpWindowImpl->mbFrame ) 6551 { 6552 if( mpWindowImpl->mpWinData && mpWindowImpl->mpWinData->mbEnableNativeWidget ) 6553 { 6554 /* 6555 * #i48371# native theming: some themes draw outside the control 6556 * area we tell them to (bad thing, but we cannot do much about it ). 6557 * On hiding these controls they get invalidated with their window rectangle 6558 * which leads to the parts outside the control area being left and not 6559 * invalidated. Workaround: invalidate an area on the parent, too 6560 */ 6561 const int workaround_border = 5; 6562 Rectangle aBounds( aInvRegion.GetBoundRect() ); 6563 aBounds.Left() -= workaround_border; 6564 aBounds.Top() -= workaround_border; 6565 aBounds.Right() += workaround_border; 6566 aBounds.Bottom() += workaround_border; 6567 aInvRegion = aBounds; 6568 } 6569 if ( !mpWindowImpl->mbNoParentUpdate && !(nFlags & SHOW_NOPARENTUPDATE) ) 6570 { 6571 if ( !aInvRegion.IsEmpty() ) 6572 ImplInvalidateParentFrameRegion( aInvRegion ); 6573 } 6574 ImplGenerateMouseMove(); 6575 } 6576 } 6577 } 6578 else 6579 { 6580 // inherit native widget flag for form controls 6581 // required here, because frames never show up in the child hierarchy - which should be fixed.... 6582 // eg, the drop down of a combobox which is a system floating window 6583 if( mpWindowImpl->mbFrame && GetParent() && GetParent()->IsCompoundControl() && 6584 GetParent()->IsNativeWidgetEnabled() != IsNativeWidgetEnabled() ) 6585 EnableNativeWidget( GetParent()->IsNativeWidgetEnabled() ); 6586 6587 if ( mpWindowImpl->mbCallMove ) 6588 { 6589 ImplCallMove(); 6590 } 6591 if ( mpWindowImpl->mbCallResize ) 6592 { 6593 ImplCallResize(); 6594 } 6595 6596 StateChanged( STATE_CHANGE_VISIBLE ); 6597 6598 Window* pTestParent; 6599 if ( ImplIsOverlapWindow() ) 6600 pTestParent = mpWindowImpl->mpOverlapWindow; 6601 else 6602 pTestParent = ImplGetParent(); 6603 if ( mpWindowImpl->mbFrame || pTestParent->mpWindowImpl->mbReallyVisible ) 6604 { 6605 // Wenn ein Window gerade sichtbar wird, schicken wir allen 6606 // Child-Fenstern ein StateChanged, damit diese sich 6607 // initialisieren koennen 6608 ImplCallInitShow(); 6609 6610 // Wenn es ein SystemWindow ist, dann kommt es auch automatisch 6611 // nach vorne, wenn es gewuenscht ist 6612 if ( ImplIsOverlapWindow() && !(nFlags & SHOW_NOACTIVATE) ) 6613 { 6614 ImplStartToTop(( nFlags & SHOW_FOREGROUNDTASK ) ? TOTOP_FOREGROUNDTASK : 0 ); 6615 ImplFocusToTop( 0, sal_False ); 6616 } 6617 6618 // Hintergrund sichern 6619 if ( mpWindowImpl->mpOverlapData && mpWindowImpl->mpOverlapData->mbSaveBack ) 6620 ImplSaveOverlapBackground(); 6621 // adjust mpWindowImpl->mbReallyVisible 6622 bRealVisibilityChanged = !mpWindowImpl->mbReallyVisible; 6623 ImplSetReallyVisible(); 6624 6625 // Dafuer sorgen, das Clip-Rechtecke neu berechnet werden 6626 ImplSetClipFlag(); 6627 6628 if ( !mpWindowImpl->mbFrame ) 6629 { 6630 sal_uInt16 nInvalidateFlags = INVALIDATE_CHILDREN; 6631 if( ! IsPaintTransparent() ) 6632 nInvalidateFlags |= INVALIDATE_NOTRANSPARENT; 6633 ImplInvalidate( NULL, nInvalidateFlags ); 6634 ImplGenerateMouseMove(); 6635 } 6636 } 6637 6638 if ( mpWindowImpl->mpBorderWindow ) 6639 mpWindowImpl->mpBorderWindow->Show( sal_True, nFlags ); 6640 else if ( mpWindowImpl->mbFrame ) 6641 { 6642 ImplSVData* pSVData = ImplGetSVData(); 6643 // #106431#, hide SplashScreen 6644 if( pSVData->mpIntroWindow && !ImplIsWindowOrChild( pSVData->mpIntroWindow ) ) 6645 pSVData->mpIntroWindow->Hide(); 6646 6647 //DBG_ASSERT( !mpWindowImpl->mbSuppressAccessibilityEvents, "Window::Show() - Frame reactivated"); 6648 mpWindowImpl->mbSuppressAccessibilityEvents = sal_False; 6649 6650 mpWindowImpl->mbPaintFrame = sal_True; 6651 sal_Bool bNoActivate = (nFlags & (SHOW_NOACTIVATE|SHOW_NOFOCUSCHANGE)) ? sal_True : sal_False; 6652 mpWindowImpl->mpFrame->Show( sal_True, bNoActivate ); 6653 if( aDogTag.IsDelete() ) 6654 return; 6655 6656 // Query the correct size of the window, if we are waiting for 6657 // a system resize 6658 if ( mpWindowImpl->mbWaitSystemResize ) 6659 { 6660 long nOutWidth; 6661 long nOutHeight; 6662 mpWindowImpl->mpFrame->GetClientSize( nOutWidth, nOutHeight ); 6663 ImplHandleResize( this, nOutWidth, nOutHeight ); 6664 } 6665 } 6666 6667 if( aDogTag.IsDelete() ) 6668 return; 6669 6670 #ifdef DBG_UTIL 6671 if ( IsDialog() || (GetType() == WINDOW_TABPAGE) || (GetType() == WINDOW_DOCKINGWINDOW) ) 6672 { 6673 DBG_DIALOGTEST( this ); 6674 } 6675 #endif 6676 6677 ImplShowAllOverlaps(); 6678 } 6679 6680 if( aDogTag.IsDelete() ) 6681 return; 6682 // invalidate all saved backgrounds 6683 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 6684 ImplInvalidateAllOverlapBackgrounds(); 6685 6686 // the SHOW/HIDE events also serve as indicators to send child creation/destroy events to the access bridge 6687 // However, the access bridge only uses this event if the data member is not NULL (it's kind of a hack that 6688 // we re-use the SHOW/HIDE events this way, with this particular semantics). 6689 // Since #104887#, the notifications for the access bridge are done in Impl(Set|Reset)ReallyVisible. Here, we 6690 // now only notify with a NULL data pointer, for all other clients except the access bridge. 6691 if ( !bRealVisibilityChanged ) 6692 ImplCallEventListeners( mpWindowImpl->mbVisible ? VCLEVENT_WINDOW_SHOW : VCLEVENT_WINDOW_HIDE, NULL ); 6693 if( aDogTag.IsDelete() ) 6694 return; 6695 6696 // #107575#, if a floating windows is shown that grabs the focus, we have to notify the toolkit about it 6697 // ImplGrabFocus() is not called in this case 6698 // Because this might lead to problems the task will be shifted to 6.y 6699 // Note: top-level context menues are registered at the access bridge after being shown, 6700 // so this will probably not help here.... 6701 /* 6702 if( mpWindowImpl->mbFloatWin && ((FloatingWindow*) this )->GrabsFocus() ) 6703 { 6704 ImplSVData* pSVData = ImplGetSVData(); 6705 if( !mpWindowImpl->mbVisible ) 6706 { 6707 ImplCallEventListeners( VCLEVENT_WINDOW_LOSEFOCUS ); 6708 if( pSVData->maWinData.mpFocusWin ) 6709 pSVData->maWinData.mpFocusWin->ImplCallEventListeners( VCLEVENT_WINDOW_GETFOCUS ); 6710 } 6711 else 6712 { 6713 if( pSVData->maWinData.mpFocusWin ) 6714 pSVData->maWinData.mpFocusWin->ImplCallEventListeners( VCLEVENT_WINDOW_LOSEFOCUS ); 6715 ImplCallEventListeners( VCLEVENT_WINDOW_GETFOCUS ); 6716 } 6717 } 6718 */ 6719 } 6720 6721 // ----------------------------------------------------------------------- 6722 6723 Size Window::GetSizePixel() const 6724 { 6725 // #i43257# trigger pending resize handler to assure correct window sizes 6726 if( mpWindowImpl->mpFrameData->maResizeTimer.IsActive() ) 6727 { 6728 ImplDelData aDogtag( this ); 6729 mpWindowImpl->mpFrameData->maResizeTimer.Stop(); 6730 mpWindowImpl->mpFrameData->maResizeTimer.GetTimeoutHdl().Call( NULL ); 6731 if( aDogtag.IsDelete() ) 6732 return Size(0,0); 6733 } 6734 6735 return Size( mnOutWidth+mpWindowImpl->mnLeftBorder+mpWindowImpl->mnRightBorder, 6736 mnOutHeight+mpWindowImpl->mnTopBorder+mpWindowImpl->mnBottomBorder ); 6737 } 6738 6739 void Window::GetBorder( sal_Int32& rLeftBorder, sal_Int32& rTopBorder, 6740 sal_Int32& rRightBorder, sal_Int32& rBottomBorder ) const 6741 { 6742 rLeftBorder = mpWindowImpl->mnLeftBorder; 6743 rTopBorder = mpWindowImpl->mnTopBorder; 6744 rRightBorder = mpWindowImpl->mnRightBorder; 6745 rBottomBorder = mpWindowImpl->mnBottomBorder; 6746 } 6747 6748 6749 // ----------------------------------------------------------------------- 6750 6751 void Window::Enable( bool bEnable, bool bChild ) 6752 { 6753 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6754 6755 if ( !bEnable ) 6756 { 6757 // Wenn ein Fenster disablte wird, wird automatisch der Tracking-Modus 6758 // beendet oder der Capture geklaut 6759 if ( IsTracking() ) 6760 EndTracking( ENDTRACK_CANCEL ); 6761 if ( IsMouseCaptured() ) 6762 ReleaseMouse(); 6763 // Wenn Fenster den Focus hat und in der Dialog-Steuerung enthalten, 6764 // wird versucht, den Focus auf das naechste Control weiterzuschalten 6765 // mpWindowImpl->mbDisabled darf erst nach Aufruf von ImplDlgCtrlNextWindow() gesetzt 6766 // werden. Ansonsten muss ImplDlgCtrlNextWindow() umgestellt werden 6767 if ( HasFocus() ) 6768 ImplDlgCtrlNextWindow(); 6769 } 6770 6771 if ( mpWindowImpl->mpBorderWindow ) 6772 { 6773 mpWindowImpl->mpBorderWindow->Enable( bEnable, sal_False ); 6774 if ( (mpWindowImpl->mpBorderWindow->GetType() == WINDOW_BORDERWINDOW) && 6775 ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->mpMenuBarWindow ) 6776 ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->mpMenuBarWindow->Enable( bEnable, sal_True ); 6777 } 6778 6779 // #i56102# restore app focus win in case the 6780 // window was disabled when the frame focus changed 6781 ImplSVData* pSVData = ImplGetSVData(); 6782 if( bEnable && 6783 pSVData->maWinData.mpFocusWin == NULL && 6784 mpWindowImpl->mpFrameData->mbHasFocus && 6785 mpWindowImpl->mpFrameData->mpFocusWin == this ) 6786 pSVData->maWinData.mpFocusWin = this; 6787 6788 if ( mpWindowImpl->mbDisabled != !bEnable ) 6789 { 6790 mpWindowImpl->mbDisabled = !bEnable; 6791 if ( mpWindowImpl->mpSysObj ) 6792 mpWindowImpl->mpSysObj->Enable( bEnable && !mpWindowImpl->mbInputDisabled ); 6793 // if ( mpWindowImpl->mbFrame ) 6794 // mpWindowImpl->mpFrame->Enable( bEnable && !mpWindowImpl->mbInputDisabled ); 6795 StateChanged( STATE_CHANGE_ENABLE ); 6796 6797 ImplCallEventListeners( bEnable ? VCLEVENT_WINDOW_ENABLED : VCLEVENT_WINDOW_DISABLED ); 6798 } 6799 6800 if ( bChild || mpWindowImpl->mbChildNotify ) 6801 { 6802 Window* pChild = mpWindowImpl->mpFirstChild; 6803 while ( pChild ) 6804 { 6805 pChild->Enable( bEnable, bChild ); 6806 pChild = pChild->mpWindowImpl->mpNext; 6807 } 6808 } 6809 6810 if ( IsReallyVisible() ) 6811 ImplGenerateMouseMove(); 6812 } 6813 6814 // ----------------------------------------------------------------------- 6815 6816 void Window::SetCallHandlersOnInputDisabled( bool bCall ) 6817 { 6818 mpWindowImpl->mbCallHandlersDuringInputDisabled = bCall ? sal_True : sal_False; 6819 6820 Window* pChild = mpWindowImpl->mpFirstChild; 6821 while ( pChild ) 6822 { 6823 pChild->SetCallHandlersOnInputDisabled( bCall ); 6824 pChild = pChild->mpWindowImpl->mpNext; 6825 } 6826 } 6827 6828 // ----------------------------------------------------------------------- 6829 6830 bool Window::IsCallHandlersOnInputDisabled() const 6831 { 6832 return mpWindowImpl->mbCallHandlersDuringInputDisabled ? true : false; 6833 } 6834 6835 // ----------------------------------------------------------------------- 6836 6837 void Window::EnableInput( sal_Bool bEnable, sal_Bool bChild ) 6838 { 6839 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6840 6841 sal_Bool bNotify = (bEnable != mpWindowImpl->mbInputDisabled); 6842 if ( mpWindowImpl->mpBorderWindow ) 6843 { 6844 mpWindowImpl->mpBorderWindow->EnableInput( bEnable, sal_False ); 6845 if ( (mpWindowImpl->mpBorderWindow->GetType() == WINDOW_BORDERWINDOW) && 6846 ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->mpMenuBarWindow ) 6847 ((ImplBorderWindow*)mpWindowImpl->mpBorderWindow)->mpMenuBarWindow->EnableInput( bEnable, sal_True ); 6848 } 6849 6850 if ( (! bEnable && mpWindowImpl->meAlwaysInputMode != AlwaysInputEnabled) || 6851 ( bEnable && mpWindowImpl->meAlwaysInputMode != AlwaysInputDisabled) ) 6852 { 6853 // Wenn ein Fenster disablte wird, wird automatisch der 6854 // Tracking-Modus beendet oder der Capture geklaut 6855 if ( !bEnable ) 6856 { 6857 if ( IsTracking() ) 6858 EndTracking( ENDTRACK_CANCEL ); 6859 if ( IsMouseCaptured() ) 6860 ReleaseMouse(); 6861 } 6862 6863 if ( mpWindowImpl->mbInputDisabled != !bEnable ) 6864 { 6865 mpWindowImpl->mbInputDisabled = !bEnable; 6866 if ( mpWindowImpl->mpSysObj ) 6867 mpWindowImpl->mpSysObj->Enable( !mpWindowImpl->mbDisabled && bEnable ); 6868 // if ( mpWindowImpl->mbFrame ) 6869 // mpWindowImpl->mpFrame->Enable( !mpWindowImpl->mbDisabled && bEnable ); 6870 } 6871 } 6872 6873 // #i56102# restore app focus win in case the 6874 // window was disabled when the frame focus changed 6875 ImplSVData* pSVData = ImplGetSVData(); 6876 if( bEnable && 6877 pSVData->maWinData.mpFocusWin == NULL && 6878 mpWindowImpl->mpFrameData->mbHasFocus && 6879 mpWindowImpl->mpFrameData->mpFocusWin == this ) 6880 pSVData->maWinData.mpFocusWin = this; 6881 6882 if ( bChild || mpWindowImpl->mbChildNotify ) 6883 { 6884 Window* pChild = mpWindowImpl->mpFirstChild; 6885 while ( pChild ) 6886 { 6887 pChild->EnableInput( bEnable, bChild ); 6888 pChild = pChild->mpWindowImpl->mpNext; 6889 } 6890 } 6891 6892 if ( IsReallyVisible() ) 6893 ImplGenerateMouseMove(); 6894 6895 // #104827# notify parent 6896 if ( bNotify ) 6897 { 6898 NotifyEvent aNEvt( bEnable ? EVENT_INPUTENABLE : EVENT_INPUTDISABLE, this ); 6899 Notify( aNEvt ); 6900 } 6901 } 6902 6903 // ----------------------------------------------------------------------- 6904 6905 void Window::EnableInput( sal_Bool bEnable, sal_Bool bChild, sal_Bool bSysWin, 6906 const Window* pExcludeWindow ) 6907 { 6908 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6909 6910 EnableInput( bEnable, bChild ); 6911 if ( bSysWin ) 6912 { 6913 // pExculeWindow is the first Overlap-Frame --> if this 6914 // shouldn't be the case, than this must be changed in dialog.cxx 6915 if( pExcludeWindow ) 6916 pExcludeWindow = pExcludeWindow->ImplGetFirstOverlapWindow(); 6917 Window* pSysWin = mpWindowImpl->mpFrameWindow->mpWindowImpl->mpFrameData->mpFirstOverlap; 6918 while ( pSysWin ) 6919 { 6920 // Is Window in the path from this window 6921 if ( ImplGetFirstOverlapWindow()->ImplIsWindowOrChild( pSysWin, sal_True ) ) 6922 { 6923 // Is Window not in the exclude window path or not the 6924 // exclude window, than change the status 6925 if ( !pExcludeWindow || !pExcludeWindow->ImplIsWindowOrChild( pSysWin, sal_True ) ) 6926 pSysWin->EnableInput( bEnable, bChild ); 6927 } 6928 pSysWin = pSysWin->mpWindowImpl->mpNextOverlap; 6929 } 6930 6931 // enable/disable floating system windows as well 6932 Window* pFrameWin = ImplGetSVData()->maWinData.mpFirstFrame; 6933 while ( pFrameWin ) 6934 { 6935 if( pFrameWin->ImplIsFloatingWindow() ) 6936 { 6937 // Is Window in the path from this window 6938 if ( ImplGetFirstOverlapWindow()->ImplIsWindowOrChild( pFrameWin, sal_True ) ) 6939 { 6940 // Is Window not in the exclude window path or not the 6941 // exclude window, than change the status 6942 if ( !pExcludeWindow || !pExcludeWindow->ImplIsWindowOrChild( pFrameWin, sal_True ) ) 6943 pFrameWin->EnableInput( bEnable, bChild ); 6944 } 6945 } 6946 pFrameWin = pFrameWin->mpWindowImpl->mpFrameData->mpNextFrame; 6947 } 6948 6949 // the same for ownerdraw floating windows 6950 if( mpWindowImpl->mbFrame ) 6951 { 6952 ::std::vector< Window* >& rList = mpWindowImpl->mpFrameData->maOwnerDrawList; 6953 ::std::vector< Window* >::iterator p = rList.begin(); 6954 while( p != rList.end() ) 6955 { 6956 // Is Window in the path from this window 6957 if ( ImplGetFirstOverlapWindow()->ImplIsWindowOrChild( (*p), sal_True ) ) 6958 { 6959 // Is Window not in the exclude window path or not the 6960 // exclude window, than change the status 6961 if ( !pExcludeWindow || !pExcludeWindow->ImplIsWindowOrChild( (*p), sal_True ) ) 6962 (*p)->EnableInput( bEnable, bChild ); 6963 } 6964 p++; 6965 } 6966 } 6967 } 6968 } 6969 6970 // ----------------------------------------------------------------------- 6971 6972 void Window::AlwaysEnableInput( sal_Bool bAlways, sal_Bool bChild ) 6973 { 6974 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 6975 6976 if ( mpWindowImpl->mpBorderWindow ) 6977 mpWindowImpl->mpBorderWindow->AlwaysEnableInput( bAlways, sal_False ); 6978 6979 if( bAlways && mpWindowImpl->meAlwaysInputMode != AlwaysInputEnabled ) 6980 { 6981 mpWindowImpl->meAlwaysInputMode = AlwaysInputEnabled; 6982 6983 if ( bAlways ) 6984 EnableInput( sal_True, sal_False ); 6985 } 6986 else if( ! bAlways && mpWindowImpl->meAlwaysInputMode == AlwaysInputEnabled ) 6987 { 6988 mpWindowImpl->meAlwaysInputMode = AlwaysInputNone; 6989 } 6990 6991 if ( bChild || mpWindowImpl->mbChildNotify ) 6992 { 6993 Window* pChild = mpWindowImpl->mpFirstChild; 6994 while ( pChild ) 6995 { 6996 pChild->AlwaysEnableInput( bAlways, bChild ); 6997 pChild = pChild->mpWindowImpl->mpNext; 6998 } 6999 } 7000 } 7001 7002 // ----------------------------------------------------------------------- 7003 7004 void Window::AlwaysDisableInput( sal_Bool bAlways, sal_Bool bChild ) 7005 { 7006 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7007 7008 if ( mpWindowImpl->mpBorderWindow ) 7009 mpWindowImpl->mpBorderWindow->AlwaysDisableInput( bAlways, sal_False ); 7010 7011 if( bAlways && mpWindowImpl->meAlwaysInputMode != AlwaysInputDisabled ) 7012 { 7013 mpWindowImpl->meAlwaysInputMode = AlwaysInputDisabled; 7014 7015 if ( bAlways ) 7016 EnableInput( sal_False, sal_False ); 7017 } 7018 else if( ! bAlways && mpWindowImpl->meAlwaysInputMode == AlwaysInputDisabled ) 7019 { 7020 mpWindowImpl->meAlwaysInputMode = AlwaysInputNone; 7021 } 7022 7023 if ( bChild || mpWindowImpl->mbChildNotify ) 7024 { 7025 Window* pChild = mpWindowImpl->mpFirstChild; 7026 while ( pChild ) 7027 { 7028 pChild->AlwaysDisableInput( bAlways, bChild ); 7029 pChild = pChild->mpWindowImpl->mpNext; 7030 } 7031 } 7032 } 7033 7034 // ----------------------------------------------------------------------- 7035 7036 void Window::SetActivateMode( sal_uInt16 nMode ) 7037 { 7038 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7039 7040 if ( mpWindowImpl->mpBorderWindow ) 7041 mpWindowImpl->mpBorderWindow->SetActivateMode( nMode ); 7042 7043 if ( mpWindowImpl->mnActivateMode != nMode ) 7044 { 7045 mpWindowImpl->mnActivateMode = nMode; 7046 7047 // Evtl. ein Decativate/Activate ausloesen 7048 if ( mpWindowImpl->mnActivateMode ) 7049 { 7050 if ( (mpWindowImpl->mbActive || (GetType() == WINDOW_BORDERWINDOW)) && 7051 !HasChildPathFocus( sal_True ) ) 7052 { 7053 mpWindowImpl->mbActive = sal_False; 7054 Deactivate(); 7055 } 7056 } 7057 else 7058 { 7059 if ( !mpWindowImpl->mbActive || (GetType() == WINDOW_BORDERWINDOW) ) 7060 { 7061 mpWindowImpl->mbActive = sal_True; 7062 Activate(); 7063 } 7064 } 7065 } 7066 } 7067 7068 // ----------------------------------------------------------------------- 7069 7070 void Window::ToTop( sal_uInt16 nFlags ) 7071 { 7072 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7073 7074 ImplStartToTop( nFlags ); 7075 ImplFocusToTop( nFlags, IsReallyVisible() ); 7076 } 7077 7078 // ----------------------------------------------------------------------- 7079 7080 void Window::SetZOrder( Window* pRefWindow, sal_uInt16 nFlags ) 7081 { 7082 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7083 7084 if ( mpWindowImpl->mpBorderWindow ) 7085 { 7086 mpWindowImpl->mpBorderWindow->SetZOrder( pRefWindow, nFlags ); 7087 return; 7088 } 7089 7090 if ( nFlags & WINDOW_ZORDER_FIRST ) 7091 { 7092 if ( ImplIsOverlapWindow() ) 7093 pRefWindow = mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap; 7094 else 7095 pRefWindow = mpWindowImpl->mpParent->mpWindowImpl->mpFirstChild; 7096 nFlags |= WINDOW_ZORDER_BEFOR; 7097 } 7098 else if ( nFlags & WINDOW_ZORDER_LAST ) 7099 { 7100 if ( ImplIsOverlapWindow() ) 7101 pRefWindow = mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpLastOverlap; 7102 else 7103 pRefWindow = mpWindowImpl->mpParent->mpWindowImpl->mpLastChild; 7104 nFlags |= WINDOW_ZORDER_BEHIND; 7105 } 7106 7107 while ( pRefWindow->mpWindowImpl->mpBorderWindow ) 7108 pRefWindow = pRefWindow->mpWindowImpl->mpBorderWindow; 7109 if ( (pRefWindow == this) || mpWindowImpl->mbFrame ) 7110 return; 7111 7112 DBG_ASSERT( pRefWindow->mpWindowImpl->mpParent == mpWindowImpl->mpParent, "Window::SetZOrder() - pRefWindow has other parent" ); 7113 if ( nFlags & WINDOW_ZORDER_BEFOR ) 7114 { 7115 if ( pRefWindow->mpWindowImpl->mpPrev == this ) 7116 return; 7117 7118 if ( ImplIsOverlapWindow() ) 7119 { 7120 if ( mpWindowImpl->mpPrev ) 7121 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = mpWindowImpl->mpNext; 7122 else 7123 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap = mpWindowImpl->mpNext; 7124 if ( mpWindowImpl->mpNext ) 7125 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = mpWindowImpl->mpPrev; 7126 else 7127 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpLastOverlap = mpWindowImpl->mpPrev; 7128 if ( !pRefWindow->mpWindowImpl->mpPrev ) 7129 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap = this; 7130 } 7131 else 7132 { 7133 if ( mpWindowImpl->mpPrev ) 7134 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = mpWindowImpl->mpNext; 7135 else 7136 mpWindowImpl->mpParent->mpWindowImpl->mpFirstChild = mpWindowImpl->mpNext; 7137 if ( mpWindowImpl->mpNext ) 7138 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = mpWindowImpl->mpPrev; 7139 else 7140 mpWindowImpl->mpParent->mpWindowImpl->mpLastChild = mpWindowImpl->mpPrev; 7141 if ( !pRefWindow->mpWindowImpl->mpPrev ) 7142 mpWindowImpl->mpParent->mpWindowImpl->mpFirstChild = this; 7143 } 7144 7145 mpWindowImpl->mpPrev = pRefWindow->mpWindowImpl->mpPrev; 7146 mpWindowImpl->mpNext = pRefWindow; 7147 if ( mpWindowImpl->mpPrev ) 7148 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = this; 7149 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = this; 7150 } 7151 else if ( nFlags & WINDOW_ZORDER_BEHIND ) 7152 { 7153 if ( pRefWindow->mpWindowImpl->mpNext == this ) 7154 return; 7155 7156 if ( ImplIsOverlapWindow() ) 7157 { 7158 if ( mpWindowImpl->mpPrev ) 7159 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = mpWindowImpl->mpNext; 7160 else 7161 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap = mpWindowImpl->mpNext; 7162 if ( mpWindowImpl->mpNext ) 7163 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = mpWindowImpl->mpPrev; 7164 else 7165 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpLastOverlap = mpWindowImpl->mpPrev; 7166 if ( !pRefWindow->mpWindowImpl->mpNext ) 7167 mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpLastOverlap = this; 7168 } 7169 else 7170 { 7171 if ( mpWindowImpl->mpPrev ) 7172 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = mpWindowImpl->mpNext; 7173 else 7174 mpWindowImpl->mpParent->mpWindowImpl->mpFirstChild = mpWindowImpl->mpNext; 7175 if ( mpWindowImpl->mpNext ) 7176 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = mpWindowImpl->mpPrev; 7177 else 7178 mpWindowImpl->mpParent->mpWindowImpl->mpLastChild = mpWindowImpl->mpPrev; 7179 if ( !pRefWindow->mpWindowImpl->mpNext ) 7180 mpWindowImpl->mpParent->mpWindowImpl->mpLastChild = this; 7181 } 7182 7183 mpWindowImpl->mpPrev = pRefWindow; 7184 mpWindowImpl->mpNext = pRefWindow->mpWindowImpl->mpNext; 7185 if ( mpWindowImpl->mpNext ) 7186 mpWindowImpl->mpNext->mpWindowImpl->mpPrev = this; 7187 mpWindowImpl->mpPrev->mpWindowImpl->mpNext = this; 7188 } 7189 7190 if ( IsReallyVisible() ) 7191 { 7192 // Hintergrund-Sicherung zuruecksetzen 7193 if ( mpWindowImpl->mpFrameData->mpFirstBackWin ) 7194 ImplInvalidateAllOverlapBackgrounds(); 7195 7196 if ( mpWindowImpl->mbInitWinClipRegion || !mpWindowImpl->maWinClipRegion.IsEmpty() ) 7197 { 7198 sal_Bool bInitWinClipRegion = mpWindowImpl->mbInitWinClipRegion; 7199 ImplSetClipFlag(); 7200 7201 // Wenn ClipRegion noch nicht initalisiert wurde, dann 7202 // gehen wir davon aus, das das Fenster noch nicht 7203 // ausgegeben wurde und loesen somit auch keine 7204 // Invalidates aus. Dies ist eine Optimierung fuer 7205 // HTML-Dokumenten mit vielen Controls. Wenn es mal 7206 // Probleme mit dieser Abfrage gibt, sollte man ein 7207 // Flag einfuehren, ob das Fenster nach Show schon 7208 // einmal ausgegeben wurde. 7209 if ( !bInitWinClipRegion ) 7210 { 7211 // Alle nebeneinanderliegen Fenster invalidieren 7212 // Noch nicht komplett implementiert !!! 7213 Rectangle aWinRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 7214 Window* pWindow = NULL; 7215 if ( ImplIsOverlapWindow() ) 7216 { 7217 if ( mpWindowImpl->mpOverlapWindow ) 7218 pWindow = mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpFirstOverlap; 7219 } 7220 else 7221 pWindow = ImplGetParent()->mpWindowImpl->mpFirstChild; 7222 // Alle Fenster, die vor uns liegen und von uns verdeckt wurden, 7223 // invalidieren 7224 while ( pWindow ) 7225 { 7226 if ( pWindow == this ) 7227 break; 7228 Rectangle aCompRect( Point( pWindow->mnOutOffX, pWindow->mnOutOffY ), 7229 Size( pWindow->mnOutWidth, pWindow->mnOutHeight ) ); 7230 if ( aWinRect.IsOver( aCompRect ) ) 7231 pWindow->Invalidate( INVALIDATE_CHILDREN | INVALIDATE_NOTRANSPARENT ); 7232 pWindow = pWindow->mpWindowImpl->mpNext; 7233 } 7234 // Wenn uns ein Fenster welches im Hinterund liegt verdeckt hat, 7235 // dann muessen wir uns neu ausgeben 7236 while ( pWindow ) 7237 { 7238 if ( pWindow != this ) 7239 { 7240 Rectangle aCompRect( Point( pWindow->mnOutOffX, pWindow->mnOutOffY ), 7241 Size( pWindow->mnOutWidth, pWindow->mnOutHeight ) ); 7242 if ( aWinRect.IsOver( aCompRect ) ) 7243 { 7244 Invalidate( INVALIDATE_CHILDREN | INVALIDATE_NOTRANSPARENT ); 7245 break; 7246 } 7247 } 7248 pWindow = pWindow->mpWindowImpl->mpNext; 7249 } 7250 } 7251 } 7252 } 7253 } 7254 7255 // ----------------------------------------------------------------------- 7256 7257 void Window::EnableAlwaysOnTop( sal_Bool bEnable ) 7258 { 7259 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7260 7261 mpWindowImpl->mbAlwaysOnTop = bEnable; 7262 7263 if ( mpWindowImpl->mpBorderWindow ) 7264 mpWindowImpl->mpBorderWindow->EnableAlwaysOnTop( bEnable ); 7265 else if ( bEnable && IsReallyVisible() ) 7266 ToTop(); 7267 7268 if ( mpWindowImpl->mbFrame ) 7269 mpWindowImpl->mpFrame->SetAlwaysOnTop( bEnable ); 7270 } 7271 7272 // ----------------------------------------------------------------------- 7273 7274 void Window::SetPosSizePixel( long nX, long nY, 7275 long nWidth, long nHeight, sal_uInt16 nFlags ) 7276 { 7277 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7278 7279 sal_Bool bHasValidSize = !mpWindowImpl->mbDefSize; 7280 7281 if ( nFlags & WINDOW_POSSIZE_POS ) 7282 mpWindowImpl->mbDefPos = sal_False; 7283 if ( nFlags & WINDOW_POSSIZE_SIZE ) 7284 mpWindowImpl->mbDefSize = sal_False; 7285 7286 // Oberstes BorderWindow ist das Window, welches positioniert werden soll 7287 Window* pWindow = this; 7288 while ( pWindow->mpWindowImpl->mpBorderWindow ) 7289 pWindow = pWindow->mpWindowImpl->mpBorderWindow; 7290 7291 if ( pWindow->mpWindowImpl->mbFrame ) 7292 { 7293 // Note: if we're positioning a frame, the coordinates are interpreted 7294 // as being the top-left corner of the window's client area and NOT 7295 // as the position of the border ! (due to limitations of several UNIX window managers) 7296 long nOldWidth = pWindow->mnOutWidth; 7297 7298 if ( !(nFlags & WINDOW_POSSIZE_WIDTH) ) 7299 nWidth = pWindow->mnOutWidth; 7300 if ( !(nFlags & WINDOW_POSSIZE_HEIGHT) ) 7301 nHeight = pWindow->mnOutHeight; 7302 7303 7304 sal_uInt16 nSysFlags=0; 7305 if( nFlags & WINDOW_POSSIZE_WIDTH ) 7306 nSysFlags |= SAL_FRAME_POSSIZE_WIDTH; 7307 if( nFlags & WINDOW_POSSIZE_HEIGHT ) 7308 nSysFlags |= SAL_FRAME_POSSIZE_HEIGHT; 7309 if( nFlags & WINDOW_POSSIZE_X ) 7310 { 7311 nSysFlags |= SAL_FRAME_POSSIZE_X; 7312 if( pWindow->GetParent() && (pWindow->GetStyle() & WB_SYSTEMCHILDWINDOW) ) 7313 { 7314 Window* pParent = pWindow->GetParent(); 7315 nX += pParent->mnOutOffX; 7316 } 7317 if( GetParent() && GetParent()->ImplIsAntiparallel() ) 7318 { 7319 // --- RTL --- (re-mirror at parent window) 7320 Rectangle aRect( Point ( nX, nY ), Size( nWidth, nHeight ) ); 7321 GetParent()->ImplReMirror( aRect ); 7322 nX = aRect.nLeft; 7323 } 7324 } 7325 if( !(nFlags & WINDOW_POSSIZE_X) && bHasValidSize && pWindow->mpWindowImpl->mpFrame->maGeometry.nWidth ) 7326 { 7327 // --- RTL --- make sure the old right aligned position is not changed 7328 // system windows will always grow to the right 7329 if( pWindow->GetParent() && pWindow->GetParent()->ImplHasMirroredGraphics() ) 7330 { 7331 long myWidth = nOldWidth; 7332 if( !myWidth ) 7333 myWidth = mpWindowImpl->mpFrame->GetUnmirroredGeometry().nWidth; 7334 if( !myWidth ) 7335 myWidth = nWidth; 7336 nFlags |= WINDOW_POSSIZE_X; 7337 nSysFlags |= SAL_FRAME_POSSIZE_X; 7338 nX = mpWindowImpl->mpFrame->GetUnmirroredGeometry().nX - pWindow->GetParent()->mpWindowImpl->mpFrame->GetUnmirroredGeometry().nX - 7339 mpWindowImpl->mpFrame->GetUnmirroredGeometry().nLeftDecoration; 7340 nX = pWindow->GetParent()->mpWindowImpl->mpFrame->GetUnmirroredGeometry().nX - mpWindowImpl->mpFrame->GetUnmirroredGeometry().nLeftDecoration + 7341 pWindow->GetParent()->mpWindowImpl->mpFrame->GetUnmirroredGeometry().nWidth - myWidth - 1 - mpWindowImpl->mpFrame->GetUnmirroredGeometry().nX; 7342 if(!(nFlags & WINDOW_POSSIZE_Y)) 7343 { 7344 nFlags |= WINDOW_POSSIZE_Y; 7345 nSysFlags |= SAL_FRAME_POSSIZE_Y; 7346 nY = mpWindowImpl->mpFrame->GetUnmirroredGeometry().nY - pWindow->GetParent()->mpWindowImpl->mpFrame->GetUnmirroredGeometry().nY - 7347 mpWindowImpl->mpFrame->GetUnmirroredGeometry().nTopDecoration; 7348 } 7349 } 7350 } 7351 if( nFlags & WINDOW_POSSIZE_Y ) 7352 { 7353 nSysFlags |= SAL_FRAME_POSSIZE_Y; 7354 if( pWindow->GetParent() && (pWindow->GetStyle() & WB_SYSTEMCHILDWINDOW) ) 7355 { 7356 Window* pParent = pWindow->GetParent(); 7357 nY += pParent->mnOutOffY; 7358 } 7359 } 7360 7361 if( nSysFlags & (SAL_FRAME_POSSIZE_WIDTH|SAL_FRAME_POSSIZE_HEIGHT) ) 7362 { 7363 // check for min/max client size and adjust size accordingly 7364 // otherwise it may happen that the resize event is ignored, i.e. the old size remains 7365 // unchanged but ImplHandleResize() is called with the wrong size 7366 SystemWindow *pSystemWindow = dynamic_cast< SystemWindow* >( pWindow ); 7367 if( pSystemWindow ) 7368 { 7369 Size aMinSize = pSystemWindow->GetMinOutputSizePixel(); 7370 Size aMaxSize = pSystemWindow->GetMaxOutputSizePixel(); 7371 if( nWidth < aMinSize.Width() ) 7372 nWidth = aMinSize.Width(); 7373 if( nHeight < aMinSize.Height() ) 7374 nHeight = aMinSize.Height(); 7375 7376 if( nWidth > aMaxSize.Width() ) 7377 nWidth = aMaxSize.Width(); 7378 if( nHeight > aMaxSize.Height() ) 7379 nHeight = aMaxSize.Height(); 7380 } 7381 } 7382 7383 pWindow->mpWindowImpl->mpFrame->SetPosSize( nX, nY, nWidth, nHeight, nSysFlags ); 7384 7385 // Resize should be called directly. If we havn't 7386 // set the correct size, we get a second resize from 7387 // the system with the correct size. This can be happend 7388 // if the size is to small or to large. 7389 ImplHandleResize( pWindow, nWidth, nHeight ); 7390 } 7391 else 7392 { 7393 pWindow->ImplPosSizeWindow( nX, nY, nWidth, nHeight, nFlags ); 7394 if ( IsReallyVisible() ) 7395 ImplGenerateMouseMove(); 7396 } 7397 } 7398 7399 // ----------------------------------------------------------------------- 7400 7401 Point Window::GetPosPixel() const 7402 { 7403 return mpWindowImpl->maPos; 7404 } 7405 7406 // ----------------------------------------------------------------------- 7407 7408 Rectangle Window::GetDesktopRectPixel() const 7409 { 7410 Rectangle rRect; 7411 mpWindowImpl->mpFrameWindow->mpWindowImpl->mpFrame->GetWorkArea( rRect ); 7412 return rRect; 7413 } 7414 7415 // ----------------------------------------------------------------------- 7416 7417 Point Window::OutputToScreenPixel( const Point& rPos ) const 7418 { 7419 // relative to top level parent 7420 return Point( rPos.X()+mnOutOffX, rPos.Y()+mnOutOffY ); 7421 } 7422 7423 // ----------------------------------------------------------------------- 7424 7425 Point Window::ScreenToOutputPixel( const Point& rPos ) const 7426 { 7427 // relative to top level parent 7428 return Point( rPos.X()-mnOutOffX, rPos.Y()-mnOutOffY ); 7429 } 7430 7431 // ----------------------------------------------------------------------- 7432 7433 long Window::ImplGetUnmirroredOutOffX() 7434 { 7435 // revert mnOutOffX changes that were potentially made in ImplPosSizeWindow 7436 long offx = mnOutOffX; 7437 if( ImplHasMirroredGraphics() ) 7438 { 7439 if( mpWindowImpl->mpParent && !mpWindowImpl->mpParent->mpWindowImpl->mbFrame && mpWindowImpl->mpParent->ImplIsAntiparallel() ) 7440 { 7441 if ( !ImplIsOverlapWindow() ) 7442 offx -= mpWindowImpl->mpParent->mnOutOffX; 7443 7444 offx = mpWindowImpl->mpParent->mnOutWidth - mnOutWidth - offx; 7445 7446 if ( !ImplIsOverlapWindow() ) 7447 offx += mpWindowImpl->mpParent->mnOutOffX; 7448 7449 } 7450 } 7451 return offx; 7452 } 7453 7454 // normalized screen pixel are independent of mirroring 7455 Point Window::OutputToNormalizedScreenPixel( const Point& rPos ) const 7456 { 7457 // relative to top level parent 7458 long offx = ((Window*) this)->ImplGetUnmirroredOutOffX(); 7459 return Point( rPos.X()+offx, rPos.Y()+mnOutOffY ); 7460 } 7461 7462 Point Window::NormalizedScreenToOutputPixel( const Point& rPos ) const 7463 { 7464 // relative to top level parent 7465 long offx = ((Window*) this)->ImplGetUnmirroredOutOffX(); 7466 return Point( rPos.X()-offx, rPos.Y()-mnOutOffY ); 7467 } 7468 7469 // ----------------------------------------------------------------------- 7470 7471 Point Window::OutputToAbsoluteScreenPixel( const Point& rPos ) const 7472 { 7473 // relative to the screen 7474 Point p = OutputToScreenPixel( rPos ); 7475 SalFrameGeometry g = mpWindowImpl->mpFrame->GetGeometry(); 7476 p.X() += g.nX; 7477 p.Y() += g.nY; 7478 return p; 7479 } 7480 7481 // ----------------------------------------------------------------------- 7482 7483 Point Window::AbsoluteScreenToOutputPixel( const Point& rPos ) const 7484 { 7485 // relative to the screen 7486 Point p = ScreenToOutputPixel( rPos ); 7487 SalFrameGeometry g = mpWindowImpl->mpFrame->GetGeometry(); 7488 p.X() -= g.nX; 7489 p.Y() -= g.nY; 7490 return p; 7491 } 7492 7493 // ----------------------------------------------------------------------- 7494 7495 Rectangle Window::ImplOutputToUnmirroredAbsoluteScreenPixel( const Rectangle &rRect ) const 7496 { 7497 // this method creates unmirrored screen coordinates to be compared with the desktop 7498 // and is used for positioning of RTL popup windows correctly on the screen 7499 SalFrameGeometry g = mpWindowImpl->mpFrame->GetUnmirroredGeometry(); 7500 7501 Point p1 = OutputToScreenPixel( rRect.TopRight() ); 7502 p1.X() = g.nX+g.nWidth-p1.X(); 7503 p1.Y() += g.nY; 7504 7505 Point p2 = OutputToScreenPixel( rRect.BottomLeft() ); 7506 p2.X() = g.nX+g.nWidth-p2.X(); 7507 p2.Y() += g.nY; 7508 7509 return Rectangle( p1, p2 ); 7510 } 7511 7512 7513 // ----------------------------------------------------------------------- 7514 7515 Rectangle Window::GetWindowExtentsRelative( Window *pRelativeWindow ) const 7516 { 7517 // with decoration 7518 return ImplGetWindowExtentsRelative( pRelativeWindow, sal_False ); 7519 } 7520 7521 Rectangle Window::GetClientWindowExtentsRelative( Window *pRelativeWindow ) const 7522 { 7523 // without decoration 7524 return ImplGetWindowExtentsRelative( pRelativeWindow, sal_True ); 7525 } 7526 7527 // ----------------------------------------------------------------------- 7528 7529 Rectangle Window::ImplGetWindowExtentsRelative( Window *pRelativeWindow, sal_Bool bClientOnly ) const 7530 { 7531 SalFrameGeometry g = mpWindowImpl->mpFrame->GetGeometry(); 7532 // make sure we use the extent of our border window, 7533 // otherwise we miss a few pixels 7534 const Window *pWin = (!bClientOnly && mpWindowImpl->mpBorderWindow) ? mpWindowImpl->mpBorderWindow : this; 7535 7536 Point aPos( pWin->OutputToScreenPixel( Point(0,0) ) ); 7537 aPos.X() += g.nX; 7538 aPos.Y() += g.nY; 7539 Size aSize ( pWin->GetSizePixel() ); 7540 // #104088# do not add decoration to the workwindow to be compatible to java accessibility api 7541 if( !bClientOnly && (mpWindowImpl->mbFrame || (mpWindowImpl->mpBorderWindow && mpWindowImpl->mpBorderWindow->mpWindowImpl->mbFrame && GetType() != WINDOW_WORKWINDOW)) ) 7542 { 7543 aPos.X() -= g.nLeftDecoration; 7544 aPos.Y() -= g.nTopDecoration; 7545 aSize.Width() += g.nLeftDecoration + g.nRightDecoration; 7546 aSize.Height() += g.nTopDecoration + g.nBottomDecoration; 7547 } 7548 if( pRelativeWindow ) 7549 { 7550 // #106399# express coordinates relative to borderwindow 7551 Window *pRelWin = (!bClientOnly && pRelativeWindow->mpWindowImpl->mpBorderWindow) ? pRelativeWindow->mpWindowImpl->mpBorderWindow : pRelativeWindow; 7552 aPos = pRelWin->AbsoluteScreenToOutputPixel( aPos ); 7553 } 7554 return Rectangle( aPos, aSize ); 7555 } 7556 7557 // ----------------------------------------------------------------------- 7558 7559 void Window::Scroll( long nHorzScroll, long nVertScroll, sal_uInt16 nFlags ) 7560 { 7561 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7562 7563 ImplScroll( Rectangle( Point( mnOutOffX, mnOutOffY ), 7564 Size( mnOutWidth, mnOutHeight ) ), 7565 nHorzScroll, nVertScroll, nFlags & ~SCROLL_CLIP ); 7566 } 7567 7568 // ----------------------------------------------------------------------- 7569 7570 void Window::Scroll( long nHorzScroll, long nVertScroll, 7571 const Rectangle& rRect, sal_uInt16 nFlags ) 7572 { 7573 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7574 7575 Rectangle aRect = ImplLogicToDevicePixel( rRect ); 7576 aRect.Intersection( Rectangle( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ) ); 7577 if ( !aRect.IsEmpty() ) 7578 ImplScroll( aRect, nHorzScroll, nVertScroll, nFlags ); 7579 } 7580 7581 // ----------------------------------------------------------------------- 7582 7583 void Window::Invalidate( sal_uInt16 nFlags ) 7584 { 7585 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7586 7587 if ( !IsDeviceOutputNecessary() || !mnOutWidth || !mnOutHeight ) 7588 return; 7589 7590 ImplInvalidate( NULL, nFlags ); 7591 } 7592 7593 // ----------------------------------------------------------------------- 7594 7595 void Window::Invalidate( const Rectangle& rRect, sal_uInt16 nFlags ) 7596 { 7597 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7598 7599 if ( !IsDeviceOutputNecessary() || !mnOutWidth || !mnOutHeight ) 7600 return; 7601 7602 Rectangle aRect = ImplLogicToDevicePixel( rRect ); 7603 if ( !aRect.IsEmpty() ) 7604 { 7605 Region aRegion( aRect ); 7606 ImplInvalidate( &aRegion, nFlags ); 7607 } 7608 } 7609 7610 // ----------------------------------------------------------------------- 7611 7612 void Window::Invalidate( const Region& rRegion, sal_uInt16 nFlags ) 7613 { 7614 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7615 7616 if ( !IsDeviceOutputNecessary() || !mnOutWidth || !mnOutHeight ) 7617 return; 7618 7619 if ( rRegion.IsNull() ) 7620 ImplInvalidate( NULL, nFlags ); 7621 else 7622 { 7623 Region aRegion = ImplPixelToDevicePixel( LogicToPixel( rRegion ) ); 7624 if ( !aRegion.IsEmpty() ) 7625 ImplInvalidate( &aRegion, nFlags ); 7626 } 7627 } 7628 7629 // ----------------------------------------------------------------------- 7630 7631 void Window::Validate( sal_uInt16 nFlags ) 7632 { 7633 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7634 7635 if ( !IsDeviceOutputNecessary() || !mnOutWidth || !mnOutHeight ) 7636 return; 7637 7638 ImplValidate( NULL, nFlags ); 7639 } 7640 7641 // ----------------------------------------------------------------------- 7642 7643 void Window::Validate( const Rectangle& rRect, sal_uInt16 nFlags ) 7644 { 7645 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7646 7647 if ( !IsDeviceOutputNecessary() || !mnOutWidth || !mnOutHeight ) 7648 return; 7649 7650 Rectangle aRect = ImplLogicToDevicePixel( rRect ); 7651 if ( !aRect.IsEmpty() ) 7652 { 7653 Region aRegion( aRect ); 7654 ImplValidate( &aRegion, nFlags ); 7655 } 7656 } 7657 7658 // ----------------------------------------------------------------------- 7659 7660 void Window::Validate( const Region& rRegion, sal_uInt16 nFlags ) 7661 { 7662 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7663 7664 if ( !IsDeviceOutputNecessary() || !mnOutWidth || !mnOutHeight ) 7665 return; 7666 7667 if ( rRegion.IsNull() ) 7668 ImplValidate( NULL, nFlags ); 7669 else 7670 { 7671 Region aRegion = ImplPixelToDevicePixel( LogicToPixel( rRegion ) ); 7672 if ( !aRegion.IsEmpty() ) 7673 ImplValidate( &aRegion, nFlags ); 7674 } 7675 } 7676 7677 // ----------------------------------------------------------------------- 7678 7679 sal_Bool Window::HasPaintEvent() const 7680 { 7681 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7682 7683 if ( !mpWindowImpl->mbReallyVisible ) 7684 return sal_False; 7685 7686 if ( mpWindowImpl->mpFrameWindow->mpWindowImpl->mbPaintFrame ) 7687 return sal_True; 7688 7689 if ( mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINT ) 7690 return sal_True; 7691 7692 if ( !ImplIsOverlapWindow() ) 7693 { 7694 const Window* pTempWindow = this; 7695 do 7696 { 7697 pTempWindow = pTempWindow->ImplGetParent(); 7698 if ( pTempWindow->mpWindowImpl->mnPaintFlags & (IMPL_PAINT_PAINTCHILDS | IMPL_PAINT_PAINTALLCHILDS) ) 7699 return sal_True; 7700 } 7701 while ( !pTempWindow->ImplIsOverlapWindow() ); 7702 } 7703 7704 return sal_False; 7705 } 7706 7707 // ----------------------------------------------------------------------- 7708 7709 void Window::Update() 7710 { 7711 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7712 7713 if ( mpWindowImpl->mpBorderWindow ) 7714 { 7715 mpWindowImpl->mpBorderWindow->Update(); 7716 return; 7717 } 7718 7719 if ( !mpWindowImpl->mbReallyVisible ) 7720 return; 7721 7722 sal_Bool bFlush = sal_False; 7723 if ( mpWindowImpl->mpFrameWindow->mpWindowImpl->mbPaintFrame ) 7724 { 7725 Point aPoint( 0, 0 ); 7726 Region aRegion( Rectangle( aPoint, Size( mnOutWidth, mnOutHeight ) ) ); 7727 ImplInvalidateOverlapFrameRegion( aRegion ); 7728 if ( mpWindowImpl->mbFrame || (mpWindowImpl->mpBorderWindow && mpWindowImpl->mpBorderWindow->mpWindowImpl->mbFrame) ) 7729 bFlush = sal_True; 7730 } 7731 7732 // Zuerst muessen wir alle Fenster ueberspringen, die Paint-Transparent 7733 // sind 7734 Window* pUpdateWindow = this; 7735 Window* pWindow = pUpdateWindow; 7736 while ( !pWindow->ImplIsOverlapWindow() ) 7737 { 7738 if ( !pWindow->mpWindowImpl->mbPaintTransparent ) 7739 { 7740 pUpdateWindow = pWindow; 7741 break; 7742 } 7743 pWindow = pWindow->ImplGetParent(); 7744 } 7745 // Ein Update wirkt immer auf das Window, wo PAINTALLCHILDS gesetzt 7746 // ist, damit nicht zuviel gemalt wird 7747 pWindow = pUpdateWindow; 7748 do 7749 { 7750 if ( pWindow->mpWindowImpl->mnPaintFlags & IMPL_PAINT_PAINTALLCHILDS ) 7751 pUpdateWindow = pWindow; 7752 if ( pWindow->ImplIsOverlapWindow() ) 7753 break; 7754 pWindow = pWindow->ImplGetParent(); 7755 } 7756 while ( pWindow ); 7757 7758 // Wenn es etwas zu malen gibt, dann ein Paint ausloesen 7759 if ( pUpdateWindow->mpWindowImpl->mnPaintFlags & (IMPL_PAINT_PAINT | IMPL_PAINT_PAINTCHILDS) ) 7760 { 7761 // und fuer alle ueber uns stehende System-Fenster auch ein Update 7762 // ausloesen, damit nicht die ganze Zeit luecken stehen bleiben 7763 Window* pUpdateOverlapWindow = ImplGetFirstOverlapWindow()->mpWindowImpl->mpFirstOverlap; 7764 while ( pUpdateOverlapWindow ) 7765 { 7766 pUpdateOverlapWindow->Update(); 7767 pUpdateOverlapWindow = pUpdateOverlapWindow->mpWindowImpl->mpNext; 7768 } 7769 7770 pUpdateWindow->ImplCallPaint( NULL, pUpdateWindow->mpWindowImpl->mnPaintFlags ); 7771 } 7772 7773 if ( bFlush ) 7774 Flush(); 7775 } 7776 7777 // ----------------------------------------------------------------------- 7778 7779 void Window::Flush() 7780 { 7781 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7782 7783 const Rectangle aWinRect( Point( mnOutOffX, mnOutOffY ), Size( mnOutWidth, mnOutHeight ) ); 7784 mpWindowImpl->mpFrame->Flush( aWinRect ); 7785 } 7786 7787 // ----------------------------------------------------------------------- 7788 7789 void Window::Sync() 7790 { 7791 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7792 7793 mpWindowImpl->mpFrame->Sync(); 7794 } 7795 7796 // ----------------------------------------------------------------------- 7797 7798 void Window::SetUpdateMode( sal_Bool bUpdate ) 7799 { 7800 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7801 7802 mpWindowImpl->mbNoUpdate = !bUpdate; 7803 StateChanged( STATE_CHANGE_UPDATEMODE ); 7804 } 7805 7806 // ----------------------------------------------------------------------- 7807 7808 void Window::GrabFocus() 7809 { 7810 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7811 7812 ImplGrabFocus( 0 ); 7813 } 7814 7815 // ----------------------------------------------------------------------- 7816 7817 sal_Bool Window::HasFocus() const 7818 { 7819 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7820 7821 // #107575# the first floating window always has the keyboard focus, see also winproc.cxx: ImplGetKeyInputWindow() 7822 // task was shifted to 6.y, so its commented out 7823 /* 7824 Window* pFocusWin = ImplGetSVData()->maWinData.mpFirstFloat; 7825 if( pFocusWin && pFocusWin->mpWindowImpl->mbFloatWin && ((FloatingWindow *)pFocusWin)->GrabsFocus() ) 7826 pFocusWin = pFocusWin->GetPreferredKeyInputWindow(); 7827 else 7828 pFocusWin = ImplGetSVData()->maWinData.mpFocusWin; 7829 7830 return (this == pFocusWin); 7831 */ 7832 7833 return (this == ImplGetSVData()->maWinData.mpFocusWin); 7834 } 7835 7836 // ----------------------------------------------------------------------- 7837 7838 void Window::GrabFocusToDocument() 7839 { 7840 Window *pWin = this; 7841 while( pWin ) 7842 { 7843 if( !pWin->GetParent() ) 7844 { 7845 pWin->ImplGetFrameWindow()->GetWindow( WINDOW_CLIENT )->GrabFocus(); 7846 return; 7847 } 7848 pWin = pWin->GetParent(); 7849 } 7850 } 7851 7852 void Window::SetFakeFocus( bool bFocus ) 7853 { 7854 ImplGetWindowImpl()->mbFakeFocusSet = bFocus; 7855 } 7856 7857 // ----------------------------------------------------------------------- 7858 7859 sal_Bool Window::HasChildPathFocus( sal_Bool bSystemWindow ) const 7860 { 7861 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7862 7863 // #107575#, the first floating window always has the keyboard focus, see also winproc.cxx: ImplGetKeyInputWindow() 7864 // task was shifted to 6.y, so its commented out 7865 /* 7866 Window* pFocusWin = ImplGetSVData()->maWinData.mpFirstFloat; 7867 if( pFocusWin && pFocusWin->mpWindowImpl->mbFloatWin && ((FloatingWindow *)pFocusWin)->GrabsFocus() ) 7868 pFocusWin = pFocusWin->GetPreferredKeyInputWindow(); 7869 else 7870 pFocusWin = ImplGetSVData()->maWinData.mpFocusWin; 7871 */ 7872 Window* pFocusWin = ImplGetSVData()->maWinData.mpFocusWin; 7873 if ( pFocusWin ) 7874 return ImplIsWindowOrChild( pFocusWin, bSystemWindow ); 7875 return sal_False; 7876 } 7877 7878 // ----------------------------------------------------------------------- 7879 7880 void Window::CaptureMouse() 7881 { 7882 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7883 7884 ImplSVData* pSVData = ImplGetSVData(); 7885 7886 // Tracking evt. beenden 7887 if ( pSVData->maWinData.mpTrackWin != this ) 7888 { 7889 if ( pSVData->maWinData.mpTrackWin ) 7890 pSVData->maWinData.mpTrackWin->EndTracking( ENDTRACK_CANCEL ); 7891 } 7892 7893 if ( pSVData->maWinData.mpCaptureWin != this ) 7894 { 7895 pSVData->maWinData.mpCaptureWin = this; 7896 mpWindowImpl->mpFrame->CaptureMouse( sal_True ); 7897 } 7898 } 7899 7900 // ----------------------------------------------------------------------- 7901 7902 void Window::ReleaseMouse() 7903 { 7904 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7905 7906 ImplSVData* pSVData = ImplGetSVData(); 7907 7908 DBG_ASSERTWARNING( pSVData->maWinData.mpCaptureWin == this, 7909 "Window::ReleaseMouse(): window doesn't have the mouse capture" ); 7910 7911 if ( pSVData->maWinData.mpCaptureWin == this ) 7912 { 7913 pSVData->maWinData.mpCaptureWin = NULL; 7914 mpWindowImpl->mpFrame->CaptureMouse( sal_False ); 7915 ImplGenerateMouseMove(); 7916 } 7917 } 7918 7919 // ----------------------------------------------------------------------- 7920 7921 sal_Bool Window::IsMouseCaptured() const 7922 { 7923 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7924 7925 return (this == ImplGetSVData()->maWinData.mpCaptureWin); 7926 } 7927 7928 // ----------------------------------------------------------------------- 7929 7930 void Window::SetPointer( const Pointer& rPointer ) 7931 { 7932 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7933 7934 if ( mpWindowImpl->maPointer == rPointer ) 7935 return; 7936 7937 mpWindowImpl->maPointer = rPointer; 7938 7939 // Pointer evt. direkt umsetzen 7940 if ( !mpWindowImpl->mpFrameData->mbInMouseMove && ImplTestMousePointerSet() ) 7941 mpWindowImpl->mpFrame->SetPointer( ImplGetMousePointer() ); 7942 } 7943 7944 // ----------------------------------------------------------------------- 7945 7946 void Window::EnableChildPointerOverwrite( sal_Bool bOverwrite ) 7947 { 7948 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7949 7950 if ( mpWindowImpl->mbChildPtrOverwrite == bOverwrite ) 7951 return; 7952 7953 mpWindowImpl->mbChildPtrOverwrite = bOverwrite; 7954 7955 // Pointer evt. direkt umsetzen 7956 if ( !mpWindowImpl->mpFrameData->mbInMouseMove && ImplTestMousePointerSet() ) 7957 mpWindowImpl->mpFrame->SetPointer( ImplGetMousePointer() ); 7958 } 7959 7960 // ----------------------------------------------------------------------- 7961 7962 void Window::SetPointerPosPixel( const Point& rPos ) 7963 { 7964 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7965 7966 Point aPos = ImplOutputToFrame( rPos ); 7967 if( ImplHasMirroredGraphics() ) 7968 { 7969 if( !IsRTLEnabled() ) 7970 { 7971 // --- RTL --- (re-mirror mouse pos at this window) 7972 ImplReMirror( aPos ); 7973 } 7974 // mirroring is required here, SetPointerPos bypasses SalGraphics 7975 mpGraphics->mirror( aPos.X(), this ); 7976 } 7977 else if( ImplIsAntiparallel() ) 7978 { 7979 ImplReMirror( aPos ); 7980 } 7981 mpWindowImpl->mpFrame->SetPointerPos( aPos.X(), aPos.Y() ); 7982 } 7983 7984 // ----------------------------------------------------------------------- 7985 7986 Point Window::GetPointerPosPixel() 7987 { 7988 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 7989 7990 Point aPos( mpWindowImpl->mpFrameData->mnLastMouseX, mpWindowImpl->mpFrameData->mnLastMouseY ); 7991 if( ImplIsAntiparallel() ) 7992 { 7993 // --- RTL --- (re-mirror mouse pos at this window) 7994 ImplReMirror( aPos ); 7995 } 7996 return ImplFrameToOutput( aPos ); 7997 } 7998 7999 // ----------------------------------------------------------------------- 8000 8001 Point Window::GetLastPointerPosPixel() 8002 { 8003 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8004 8005 Point aPos( mpWindowImpl->mpFrameData->mnBeforeLastMouseX, mpWindowImpl->mpFrameData->mnBeforeLastMouseY ); 8006 if( ImplIsAntiparallel() ) 8007 { 8008 // --- RTL --- (re-mirror mouse pos at this window) 8009 ImplReMirror( aPos ); 8010 } 8011 return ImplFrameToOutput( aPos ); 8012 } 8013 8014 // ----------------------------------------------------------------------- 8015 8016 void Window::ShowPointer( sal_Bool bVisible ) 8017 { 8018 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8019 8020 if ( mpWindowImpl->mbNoPtrVisible != !bVisible ) 8021 { 8022 mpWindowImpl->mbNoPtrVisible = !bVisible; 8023 8024 // Pointer evt. direkt umsetzen 8025 if ( !mpWindowImpl->mpFrameData->mbInMouseMove && ImplTestMousePointerSet() ) 8026 mpWindowImpl->mpFrame->SetPointer( ImplGetMousePointer() ); 8027 } 8028 } 8029 8030 // ----------------------------------------------------------------------- 8031 8032 Window::PointerState Window::GetPointerState() 8033 { 8034 PointerState aState; 8035 aState.mnState = 0; 8036 8037 if (mpWindowImpl->mpFrame) 8038 { 8039 SalFrame::SalPointerState aSalPointerState; 8040 8041 aSalPointerState = mpWindowImpl->mpFrame->GetPointerState(); 8042 if( ImplIsAntiparallel() ) 8043 { 8044 // --- RTL --- (re-mirror mouse pos at this window) 8045 ImplReMirror( aSalPointerState.maPos ); 8046 } 8047 aState.maPos = ImplFrameToOutput( aSalPointerState.maPos ); 8048 aState.mnState = aSalPointerState.mnState; 8049 } 8050 return aState; 8051 } 8052 8053 // ----------------------------------------------------------------------- 8054 8055 sal_Bool Window::IsMouseOver() 8056 { 8057 return ImplGetWinData()->mbMouseOver; 8058 } 8059 8060 // ----------------------------------------------------------------------- 8061 8062 void Window::EnterWait() 8063 { 8064 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8065 8066 mpWindowImpl->mnWaitCount++; 8067 8068 if ( mpWindowImpl->mnWaitCount == 1 ) 8069 { 8070 // Pointer evt. direkt umsetzen 8071 if ( !mpWindowImpl->mpFrameData->mbInMouseMove && ImplTestMousePointerSet() ) 8072 mpWindowImpl->mpFrame->SetPointer( ImplGetMousePointer() ); 8073 } 8074 } 8075 8076 // ----------------------------------------------------------------------- 8077 8078 void Window::LeaveWait() 8079 { 8080 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8081 8082 if ( mpWindowImpl->mnWaitCount ) 8083 { 8084 mpWindowImpl->mnWaitCount--; 8085 8086 if ( !mpWindowImpl->mnWaitCount ) 8087 { 8088 // Pointer evt. direkt umsetzen 8089 if ( !mpWindowImpl->mpFrameData->mbInMouseMove && ImplTestMousePointerSet() ) 8090 mpWindowImpl->mpFrame->SetPointer( ImplGetMousePointer() ); 8091 } 8092 } 8093 } 8094 8095 // ----------------------------------------------------------------------- 8096 8097 void Window::SetCursor( Cursor* pCursor ) 8098 { 8099 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8100 8101 if ( mpWindowImpl->mpCursor != pCursor ) 8102 { 8103 if ( mpWindowImpl->mpCursor ) 8104 mpWindowImpl->mpCursor->ImplHide( true ); 8105 mpWindowImpl->mpCursor = pCursor; 8106 if ( pCursor ) 8107 pCursor->ImplShow(); 8108 } 8109 } 8110 8111 // ----------------------------------------------------------------------- 8112 8113 void Window::SetText( const XubString& rStr ) 8114 { 8115 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8116 8117 String oldTitle( mpWindowImpl->maText ); 8118 mpWindowImpl->maText = rStr; 8119 8120 if ( mpWindowImpl->mpBorderWindow ) 8121 mpWindowImpl->mpBorderWindow->SetText( rStr ); 8122 else if ( mpWindowImpl->mbFrame ) 8123 mpWindowImpl->mpFrame->SetTitle( rStr ); 8124 8125 ImplCallEventListeners( VCLEVENT_WINDOW_FRAMETITLECHANGED, &oldTitle ); 8126 8127 // #107247# needed for accessibility 8128 // The VCLEVENT_WINDOW_FRAMETITLECHANGED is (mis)used to notify accessible name changes. 8129 // Therefore a window, which is labeled by this window, must also notify an accessible 8130 // name change. 8131 if ( IsReallyVisible() ) 8132 { 8133 Window* pWindow = GetAccessibleRelationLabelFor(); 8134 if ( pWindow && pWindow != this ) 8135 pWindow->ImplCallEventListeners( VCLEVENT_WINDOW_FRAMETITLECHANGED, &oldTitle ); 8136 } 8137 8138 StateChanged( STATE_CHANGE_TEXT ); 8139 } 8140 8141 // ----------------------------------------------------------------------- 8142 8143 String Window::GetText() const 8144 { 8145 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8146 8147 return mpWindowImpl->maText; 8148 } 8149 8150 // ----------------------------------------------------------------------- 8151 8152 String Window::GetDisplayText() const 8153 { 8154 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8155 8156 return GetText(); 8157 } 8158 8159 // ----------------------------------------------------------------------- 8160 8161 const Wallpaper& Window::GetDisplayBackground() const 8162 { 8163 // FIXME: fix issue 52349, need to fix this really in 8164 // all NWF enabled controls 8165 const ToolBox* pTB = dynamic_cast<const ToolBox*>(this); 8166 if( pTB ) 8167 { 8168 if( IsNativeWidgetEnabled() ) 8169 return pTB->ImplGetToolBoxPrivateData()->maDisplayBackground; 8170 } 8171 8172 if( !IsBackground() ) 8173 { 8174 if( mpWindowImpl->mpParent ) 8175 return mpWindowImpl->mpParent->GetDisplayBackground(); 8176 } 8177 8178 const Wallpaper& rBack = GetBackground(); 8179 if( ! rBack.IsBitmap() && 8180 ! rBack.IsGradient() && 8181 rBack.GetColor().GetColor() == COL_TRANSPARENT && 8182 mpWindowImpl->mpParent ) 8183 return mpWindowImpl->mpParent->GetDisplayBackground(); 8184 return rBack; 8185 } 8186 8187 // ----------------------------------------------------------------------- 8188 8189 const XubString& Window::GetHelpText() const 8190 { 8191 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8192 8193 String aStrHelpId( rtl::OStringToOUString( GetHelpId(), RTL_TEXTENCODING_UTF8 ) ); 8194 bool bStrHelpId = (aStrHelpId.Len() > 0); 8195 8196 if ( !mpWindowImpl->maHelpText.Len() && bStrHelpId ) 8197 { 8198 if ( !IsDialog() && (mpWindowImpl->mnType != WINDOW_TABPAGE) && (mpWindowImpl->mnType != WINDOW_FLOATINGWINDOW) ) 8199 { 8200 Help* pHelp = Application::GetHelp(); 8201 if ( pHelp ) 8202 { 8203 ((Window*)this)->mpWindowImpl->maHelpText = pHelp->GetHelpText( aStrHelpId, this ); 8204 mpWindowImpl->mbHelpTextDynamic = sal_False; 8205 } 8206 } 8207 } 8208 else if( mpWindowImpl->mbHelpTextDynamic && bStrHelpId ) 8209 { 8210 static const char* pEnv = getenv( "HELP_DEBUG" ); 8211 if( pEnv && *pEnv ) 8212 { 8213 rtl::OUStringBuffer aTxt( 64+mpWindowImpl->maHelpText.Len() ); 8214 aTxt.append( mpWindowImpl->maHelpText ); 8215 aTxt.appendAscii( "\n------------------\n" ); 8216 aTxt.append( rtl::OUString( aStrHelpId ) ); 8217 mpWindowImpl->maHelpText = aTxt.makeStringAndClear(); 8218 } 8219 mpWindowImpl->mbHelpTextDynamic = sal_False; 8220 } 8221 8222 return mpWindowImpl->maHelpText; 8223 } 8224 8225 // ----------------------------------------------------------------------- 8226 8227 Window* Window::FindWindow( const Point& rPos ) const 8228 { 8229 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8230 8231 Point aPos = OutputToScreenPixel( rPos ); 8232 return ((Window*)this)->ImplFindWindow( aPos ); 8233 } 8234 8235 // ----------------------------------------------------------------------- 8236 8237 sal_uInt16 Window::GetChildCount() const 8238 { 8239 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8240 8241 sal_uInt16 nChildCount = 0; 8242 Window* pChild = mpWindowImpl->mpFirstChild; 8243 while ( pChild ) 8244 { 8245 nChildCount++; 8246 pChild = pChild->mpWindowImpl->mpNext; 8247 } 8248 8249 return nChildCount; 8250 } 8251 8252 // ----------------------------------------------------------------------- 8253 8254 Window* Window::GetChild( sal_uInt16 nChild ) const 8255 { 8256 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8257 8258 sal_uInt16 nChildCount = 0; 8259 Window* pChild = mpWindowImpl->mpFirstChild; 8260 while ( pChild ) 8261 { 8262 if ( nChild == nChildCount ) 8263 return pChild; 8264 pChild = pChild->mpWindowImpl->mpNext; 8265 nChildCount++; 8266 } 8267 8268 return NULL; 8269 } 8270 8271 // ----------------------------------------------------------------------- 8272 8273 Window* Window::GetWindow( sal_uInt16 nType ) const 8274 { 8275 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8276 8277 switch ( nType ) 8278 { 8279 case WINDOW_PARENT: 8280 return mpWindowImpl->mpRealParent; 8281 8282 case WINDOW_FIRSTCHILD: 8283 return mpWindowImpl->mpFirstChild; 8284 8285 case WINDOW_LASTCHILD: 8286 return mpWindowImpl->mpLastChild; 8287 8288 case WINDOW_PREV: 8289 return mpWindowImpl->mpPrev; 8290 8291 case WINDOW_NEXT: 8292 return mpWindowImpl->mpNext; 8293 8294 case WINDOW_FIRSTOVERLAP: 8295 return mpWindowImpl->mpFirstOverlap; 8296 8297 case WINDOW_LASTOVERLAP: 8298 return mpWindowImpl->mpLastOverlap; 8299 8300 case WINDOW_OVERLAP: 8301 if ( ImplIsOverlapWindow() ) 8302 return (Window*)this; 8303 else 8304 return mpWindowImpl->mpOverlapWindow; 8305 8306 case WINDOW_PARENTOVERLAP: 8307 if ( ImplIsOverlapWindow() ) 8308 return mpWindowImpl->mpOverlapWindow; 8309 else 8310 return mpWindowImpl->mpOverlapWindow->mpWindowImpl->mpOverlapWindow; 8311 8312 case WINDOW_CLIENT: 8313 return ((Window*)this)->ImplGetWindow(); 8314 8315 case WINDOW_REALPARENT: 8316 return ImplGetParent(); 8317 8318 case WINDOW_FRAME: 8319 return mpWindowImpl->mpFrameWindow; 8320 8321 case WINDOW_BORDER: 8322 if ( mpWindowImpl->mpBorderWindow ) 8323 return mpWindowImpl->mpBorderWindow->GetWindow( WINDOW_BORDER ); 8324 return (Window*)this; 8325 8326 case WINDOW_FIRSTTOPWINDOWCHILD: 8327 return ImplGetWinData()->maTopWindowChildren.empty() ? NULL : *ImplGetWinData()->maTopWindowChildren.begin(); 8328 8329 case WINDOW_LASTTOPWINDOWCHILD: 8330 return ImplGetWinData()->maTopWindowChildren.empty() ? NULL : *ImplGetWinData()->maTopWindowChildren.rbegin(); 8331 8332 case WINDOW_PREVTOPWINDOWSIBLING: 8333 { 8334 if ( !mpWindowImpl->mpRealParent ) 8335 return NULL; 8336 const ::std::list< Window* >& rTopWindows( mpWindowImpl->mpRealParent->ImplGetWinData()->maTopWindowChildren ); 8337 ::std::list< Window* >::const_iterator myPos = 8338 ::std::find( rTopWindows.begin(), rTopWindows.end(), this ); 8339 if ( myPos == rTopWindows.end() ) 8340 return NULL; 8341 if ( myPos == rTopWindows.begin() ) 8342 return NULL; 8343 return *--myPos; 8344 } 8345 8346 case WINDOW_NEXTTOPWINDOWSIBLING: 8347 { 8348 if ( !mpWindowImpl->mpRealParent ) 8349 return NULL; 8350 const ::std::list< Window* >& rTopWindows( mpWindowImpl->mpRealParent->ImplGetWinData()->maTopWindowChildren ); 8351 ::std::list< Window* >::const_iterator myPos = 8352 ::std::find( rTopWindows.begin(), rTopWindows.end(), this ); 8353 if ( ( myPos == rTopWindows.end() ) || ( ++myPos == rTopWindows.end() ) ) 8354 return NULL; 8355 return *myPos; 8356 } 8357 8358 } 8359 8360 return NULL; 8361 } 8362 8363 // ----------------------------------------------------------------------- 8364 8365 sal_Bool Window::IsChild( const Window* pWindow, sal_Bool bSystemWindow ) const 8366 { 8367 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8368 DBG_CHKOBJ( pWindow, Window, ImplDbgCheckWindow ); 8369 8370 do 8371 { 8372 if ( !bSystemWindow && pWindow->ImplIsOverlapWindow() ) 8373 break; 8374 8375 pWindow = pWindow->ImplGetParent(); 8376 8377 if ( pWindow == this ) 8378 return sal_True; 8379 } 8380 while ( pWindow ); 8381 8382 return sal_False; 8383 } 8384 8385 // ----------------------------------------------------------------------- 8386 8387 sal_Bool Window::IsWindowOrChild( const Window* pWindow, sal_Bool bSystemWindow ) const 8388 { 8389 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8390 DBG_CHKOBJ( pWindow, Window, ImplDbgCheckWindow ); 8391 8392 if ( this == pWindow ) 8393 return sal_True; 8394 return ImplIsChild( pWindow, bSystemWindow ); 8395 } 8396 8397 // ----------------------------------------------------------------------- 8398 8399 const SystemEnvData* Window::GetSystemData() const 8400 { 8401 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8402 8403 return mpWindowImpl->mpFrame ? mpWindowImpl->mpFrame->GetSystemData() : NULL; 8404 } 8405 8406 ::com::sun::star::uno::Any Window::GetSystemDataAny() const 8407 { 8408 ::com::sun::star::uno::Any aRet; 8409 const SystemEnvData* pSysData = GetSystemData(); 8410 if( pSysData ) 8411 { 8412 ::com::sun::star::uno::Sequence< sal_Int8 > aSeq( (sal_Int8*)pSysData, pSysData->nSize ); 8413 aRet <<= aSeq; 8414 } 8415 return aRet; 8416 } 8417 8418 // ----------------------------------------------------------------------- 8419 8420 void Window::SetWindowPeer( ::com::sun::star::uno::Reference< ::com::sun::star::awt::XWindowPeer > xPeer, VCLXWindow* pVCLXWindow ) 8421 { 8422 // be safe against re-entrance: first clear the old ref, then assign the new one 8423 // #133706# / 2006-03-30 / frank.schoenheit@sun.com 8424 mpWindowImpl->mxWindowPeer.clear(); 8425 mpWindowImpl->mxWindowPeer = xPeer; 8426 8427 mpWindowImpl->mpVCLXWindow = pVCLXWindow; 8428 } 8429 8430 // ----------------------------------------------------------------------- 8431 8432 ::com::sun::star::uno::Reference< ::com::sun::star::awt::XWindowPeer > Window::GetComponentInterface( sal_Bool bCreate ) 8433 { 8434 if ( !mpWindowImpl->mxWindowPeer.is() && bCreate ) 8435 { 8436 UnoWrapperBase* pWrapper = Application::GetUnoWrapper(); 8437 if ( pWrapper ) 8438 mpWindowImpl->mxWindowPeer = pWrapper->GetWindowInterface( this, sal_True ); 8439 } 8440 return mpWindowImpl->mxWindowPeer; 8441 } 8442 8443 // ----------------------------------------------------------------------- 8444 8445 void Window::SetComponentInterface( ::com::sun::star::uno::Reference< ::com::sun::star::awt::XWindowPeer > xIFace ) 8446 { 8447 UnoWrapperBase* pWrapper = Application::GetUnoWrapper(); 8448 DBG_ASSERT( pWrapper, "SetComponentInterface: No Wrapper!" ); 8449 if ( pWrapper ) 8450 pWrapper->SetWindowInterface( this, xIFace ); 8451 } 8452 8453 // ----------------------------------------------------------------------- 8454 8455 void Window::ImplCallDeactivateListeners( Window *pNew ) 8456 { 8457 // no deactivation if the the newly activated window is my child 8458 if ( !pNew || !ImplIsChild( pNew ) ) 8459 { 8460 ImplDelData aDogtag( this ); 8461 ImplCallEventListeners( VCLEVENT_WINDOW_DEACTIVATE ); 8462 if( aDogtag.IsDelete() ) 8463 return; 8464 8465 // #100759#, avoid walking the wrong frame's hierarchy 8466 // eg, undocked docking windows (ImplDockFloatWin) 8467 if ( ImplGetParent() && mpWindowImpl->mpFrameWindow == ImplGetParent()->mpWindowImpl->mpFrameWindow ) 8468 ImplGetParent()->ImplCallDeactivateListeners( pNew ); 8469 } 8470 } 8471 8472 // ----------------------------------------------------------------------- 8473 8474 void Window::ImplCallActivateListeners( Window *pOld ) 8475 { 8476 // no activation if the the old active window is my child 8477 if ( !pOld || !ImplIsChild( pOld ) ) 8478 { 8479 ImplDelData aDogtag( this ); 8480 ImplCallEventListeners( VCLEVENT_WINDOW_ACTIVATE, pOld ); 8481 if( aDogtag.IsDelete() ) 8482 return; 8483 8484 // #106298# revoke the change for 105369, because this change 8485 // disabled the activate event for the parent, 8486 // if the parent is a compound control 8487 //if( !GetParent() || !GetParent()->IsCompoundControl() ) 8488 //{ 8489 // #100759#, avoid walking the wrong frame's hierarchy 8490 // eg, undocked docking windows (ImplDockFloatWin) 8491 // #104714#, revert the changes for 100759 because it has a side effect when pOld is a dialog 8492 // additionally the gallery is not dockable anymore, so 100759 canot occur 8493 if ( ImplGetParent() ) /* && mpWindowImpl->mpFrameWindow == ImplGetParent()->mpWindowImpl->mpFrameWindow ) */ 8494 ImplGetParent()->ImplCallActivateListeners( pOld ); 8495 else if( (mpWindowImpl->mnStyle & WB_INTROWIN) == 0 ) 8496 { 8497 // top level frame reached: store hint for DefModalDialogParent 8498 ImplGetSVData()->maWinData.mpActiveApplicationFrame = mpWindowImpl->mpFrameWindow; 8499 } 8500 //} 8501 } 8502 } 8503 8504 // ----------------------------------------------------------------------- 8505 8506 bool Window::ImplStopDnd() 8507 { 8508 bool bRet = false; 8509 if( mpWindowImpl->mpFrameData && mpWindowImpl->mpFrameData->mxDropTargetListener.is() ) 8510 { 8511 bRet = true; 8512 mpWindowImpl->mpFrameData->mxDropTarget.clear(); 8513 mpWindowImpl->mpFrameData->mxDragSource.clear(); 8514 mpWindowImpl->mpFrameData->mxDropTargetListener.clear(); 8515 } 8516 8517 return bRet; 8518 } 8519 8520 // ----------------------------------------------------------------------- 8521 8522 void Window::ImplStartDnd() 8523 { 8524 GetDropTarget(); 8525 } 8526 8527 // ----------------------------------------------------------------------- 8528 8529 uno::Reference< XDropTarget > Window::GetDropTarget() 8530 { 8531 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8532 8533 if( ! mpWindowImpl->mxDNDListenerContainer.is() ) 8534 { 8535 sal_Int8 nDefaultActions = 0; 8536 8537 if( mpWindowImpl->mpFrameData ) 8538 { 8539 if( ! mpWindowImpl->mpFrameData->mxDropTarget.is() ) 8540 { 8541 // initialization is done in GetDragSource 8542 uno::Reference< XDragSource > xDragSource = GetDragSource(); 8543 } 8544 8545 if( mpWindowImpl->mpFrameData->mxDropTarget.is() ) 8546 { 8547 nDefaultActions = mpWindowImpl->mpFrameData->mxDropTarget->getDefaultActions(); 8548 8549 if( ! mpWindowImpl->mpFrameData->mxDropTargetListener.is() ) 8550 { 8551 mpWindowImpl->mpFrameData->mxDropTargetListener = new DNDEventDispatcher( mpWindowImpl->mpFrameWindow ); 8552 8553 try 8554 { 8555 mpWindowImpl->mpFrameData->mxDropTarget->addDropTargetListener( mpWindowImpl->mpFrameData->mxDropTargetListener ); 8556 8557 // register also as drag gesture listener if directly supported by drag source 8558 uno::Reference< XDragGestureRecognizer > xDragGestureRecognizer = 8559 uno::Reference< XDragGestureRecognizer > (mpWindowImpl->mpFrameData->mxDragSource, UNO_QUERY); 8560 8561 if( xDragGestureRecognizer.is() ) 8562 { 8563 xDragGestureRecognizer->addDragGestureListener( 8564 uno::Reference< XDragGestureListener > (mpWindowImpl->mpFrameData->mxDropTargetListener, UNO_QUERY)); 8565 } 8566 else 8567 mpWindowImpl->mpFrameData->mbInternalDragGestureRecognizer = sal_True; 8568 8569 } 8570 8571 catch( RuntimeException&) 8572 { 8573 // release all instances 8574 mpWindowImpl->mpFrameData->mxDropTarget.clear(); 8575 mpWindowImpl->mpFrameData->mxDragSource.clear(); 8576 } 8577 } 8578 } 8579 8580 } 8581 8582 mpWindowImpl->mxDNDListenerContainer = static_cast < XDropTarget * > ( new DNDListenerContainer( nDefaultActions ) ); 8583 } 8584 8585 // this object is located in the same process, so there will be no runtime exception 8586 return uno::Reference< XDropTarget > ( mpWindowImpl->mxDNDListenerContainer, UNO_QUERY ); 8587 } 8588 8589 // ----------------------------------------------------------------------- 8590 8591 uno::Reference< XDragSource > Window::GetDragSource() 8592 { 8593 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8594 8595 if( mpWindowImpl->mpFrameData ) 8596 { 8597 if( ! mpWindowImpl->mpFrameData->mxDragSource.is() ) 8598 { 8599 try 8600 { 8601 uno::Reference< XMultiServiceFactory > xFactory = vcl::unohelper::GetMultiServiceFactory(); 8602 if ( xFactory.is() ) 8603 { 8604 const SystemEnvData * pEnvData = GetSystemData(); 8605 8606 if( pEnvData ) 8607 { 8608 Sequence< Any > aDragSourceAL( 2 ), aDropTargetAL( 2 ); 8609 OUString aDragSourceSN, aDropTargetSN; 8610 #if defined WNT 8611 aDragSourceSN = OUString::createFromAscii( "com.sun.star.datatransfer.dnd.OleDragSource" ); 8612 aDropTargetSN = OUString::createFromAscii( "com.sun.star.datatransfer.dnd.OleDropTarget" ); 8613 aDragSourceAL[ 1 ] = makeAny( (sal_uInt32) pEnvData->hWnd ); 8614 aDropTargetAL[ 0 ] = makeAny( (sal_uInt32) pEnvData->hWnd ); 8615 #elif defined QUARTZ 8616 /* FIXME: Mac OS X specific dnd interface does not exist! * 8617 * Using Windows based dnd as a temporary solution */ 8618 aDragSourceSN = OUString::createFromAscii( "com.sun.star.datatransfer.dnd.OleDragSource" ); 8619 aDropTargetSN = OUString::createFromAscii( "com.sun.star.datatransfer.dnd.OleDropTarget" ); 8620 aDragSourceAL[ 1 ] = makeAny( static_cast<sal_uInt64>( reinterpret_cast<sal_IntPtr>(pEnvData->pView) ) ); 8621 aDropTargetAL[ 0 ] = makeAny( static_cast<sal_uInt64>( reinterpret_cast<sal_IntPtr>(pEnvData->pView) ) ); 8622 #elif defined UNX 8623 aDropTargetAL.realloc( 3 ); 8624 aDragSourceAL.realloc( 3 ); 8625 aDragSourceSN = OUString::createFromAscii( "com.sun.star.datatransfer.dnd.X11DragSource" ); 8626 aDropTargetSN = OUString::createFromAscii( "com.sun.star.datatransfer.dnd.X11DropTarget" ); 8627 8628 aDragSourceAL[ 0 ] = makeAny( Application::GetDisplayConnection() ); 8629 aDragSourceAL[ 2 ] = makeAny( vcl::createBmpConverter() ); 8630 aDropTargetAL[ 0 ] = makeAny( Application::GetDisplayConnection() ); 8631 aDropTargetAL[ 1 ] = makeAny( (sal_Size)(pEnvData->aShellWindow) ); 8632 aDropTargetAL[ 2 ] = makeAny( vcl::createBmpConverter() ); 8633 #endif 8634 if( aDragSourceSN.getLength() ) 8635 mpWindowImpl->mpFrameData->mxDragSource = uno::Reference< XDragSource > ( xFactory->createInstanceWithArguments( aDragSourceSN, aDragSourceAL ), UNO_QUERY ); 8636 8637 if( aDropTargetSN.getLength() ) 8638 mpWindowImpl->mpFrameData->mxDropTarget = uno::Reference< XDropTarget > ( xFactory->createInstanceWithArguments( aDropTargetSN, aDropTargetAL ), UNO_QUERY ); 8639 } 8640 } 8641 } 8642 8643 // createInstance can throw any exception 8644 catch( Exception&) 8645 { 8646 // release all instances 8647 mpWindowImpl->mpFrameData->mxDropTarget.clear(); 8648 mpWindowImpl->mpFrameData->mxDragSource.clear(); 8649 } 8650 } 8651 8652 return mpWindowImpl->mpFrameData->mxDragSource; 8653 } 8654 8655 return uno::Reference< XDragSource > (); 8656 } 8657 8658 // ----------------------------------------------------------------------- 8659 8660 void Window::GetDragSourceDropTarget(uno::Reference< XDragSource >& xDragSource, uno::Reference< XDropTarget > &xDropTarget ) 8661 // only for RVP transmission 8662 { 8663 if( mpWindowImpl->mpFrameData ) 8664 { 8665 // initialization is done in GetDragSource 8666 xDragSource = GetDragSource(); 8667 xDropTarget = mpWindowImpl->mpFrameData->mxDropTarget; 8668 } 8669 else 8670 { 8671 xDragSource.clear(); 8672 xDropTarget.clear(); 8673 } 8674 } 8675 8676 // ----------------------------------------------------------------------- 8677 8678 uno::Reference< XDragGestureRecognizer > Window::GetDragGestureRecognizer() 8679 { 8680 return uno::Reference< XDragGestureRecognizer > ( GetDropTarget(), UNO_QUERY ); 8681 } 8682 8683 // ----------------------------------------------------------------------- 8684 8685 uno::Reference< XClipboard > Window::GetClipboard() 8686 { 8687 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8688 8689 if( mpWindowImpl->mpFrameData ) 8690 { 8691 if( ! mpWindowImpl->mpFrameData->mxClipboard.is() ) 8692 { 8693 try 8694 { 8695 uno::Reference< XMultiServiceFactory > xFactory( vcl::unohelper::GetMultiServiceFactory() ); 8696 8697 if( xFactory.is() ) 8698 { 8699 mpWindowImpl->mpFrameData->mxClipboard = uno::Reference< XClipboard >( xFactory->createInstance( OUString::createFromAscii( "com.sun.star.datatransfer.clipboard.SystemClipboardExt" ) ), UNO_QUERY ); 8700 8701 if( !mpWindowImpl->mpFrameData->mxClipboard.is() ) 8702 mpWindowImpl->mpFrameData->mxClipboard = uno::Reference< XClipboard >( xFactory->createInstance( OUString::createFromAscii( "com.sun.star.datatransfer.clipboard.SystemClipboard" ) ), UNO_QUERY ); 8703 8704 #if defined(UNX) && !defined(QUARTZ) // unix clipboard needs to be initialized 8705 if( mpWindowImpl->mpFrameData->mxClipboard.is() ) 8706 { 8707 uno::Reference< XInitialization > xInit = uno::Reference< XInitialization >( mpWindowImpl->mpFrameData->mxClipboard, UNO_QUERY ); 8708 8709 if( xInit.is() ) 8710 { 8711 Sequence< Any > aArgumentList( 3 ); 8712 aArgumentList[ 0 ] = makeAny( Application::GetDisplayConnection() ); 8713 aArgumentList[ 1 ] = makeAny( OUString::createFromAscii( "CLIPBOARD" ) ); 8714 aArgumentList[ 2 ] = makeAny( vcl::createBmpConverter() ); 8715 8716 xInit->initialize( aArgumentList ); 8717 } 8718 } 8719 #endif 8720 } 8721 } 8722 8723 // createInstance can throw any exception 8724 catch( Exception&) 8725 { 8726 // release all instances 8727 mpWindowImpl->mpFrameData->mxClipboard.clear(); 8728 } 8729 } 8730 8731 return mpWindowImpl->mpFrameData->mxClipboard; 8732 } 8733 8734 return static_cast < XClipboard * > (0); 8735 } 8736 8737 // ----------------------------------------------------------------------- 8738 8739 uno::Reference< XClipboard > Window::GetPrimarySelection() 8740 { 8741 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8742 8743 if( mpWindowImpl->mpFrameData ) 8744 { 8745 if( ! mpWindowImpl->mpFrameData->mxSelection.is() ) 8746 { 8747 try 8748 { 8749 uno::Reference< XMultiServiceFactory > xFactory( vcl::unohelper::GetMultiServiceFactory() ); 8750 8751 if( xFactory.is() ) 8752 { 8753 #if defined(UNX) && !defined(QUARTZ) 8754 Sequence< Any > aArgumentList( 3 ); 8755 aArgumentList[ 0 ] = makeAny( Application::GetDisplayConnection() ); 8756 aArgumentList[ 1 ] = makeAny( OUString::createFromAscii( "PRIMARY" ) ); 8757 aArgumentList[ 2 ] = makeAny( vcl::createBmpConverter() ); 8758 8759 mpWindowImpl->mpFrameData->mxSelection = uno::Reference< XClipboard >( xFactory->createInstanceWithArguments( 8760 OUString::createFromAscii( "com.sun.star.datatransfer.clipboard.SystemClipboard" ), aArgumentList ), UNO_QUERY ); 8761 # else 8762 static uno::Reference< XClipboard > s_xSelection; 8763 8764 if ( !s_xSelection.is() ) 8765 s_xSelection = uno::Reference< XClipboard >( xFactory->createInstance( OUString::createFromAscii( "com.sun.star.datatransfer.clipboard.GenericClipboardExt" ) ), UNO_QUERY ); 8766 8767 if ( !s_xSelection.is() ) 8768 s_xSelection = uno::Reference< XClipboard >( xFactory->createInstance( OUString::createFromAscii( "com.sun.star.datatransfer.clipboard.GenericClipboard" ) ), UNO_QUERY ); 8769 8770 mpWindowImpl->mpFrameData->mxSelection = s_xSelection; 8771 # endif 8772 } 8773 } 8774 8775 // createInstance can throw any exception 8776 catch( Exception&) 8777 { 8778 // release all instances 8779 mpWindowImpl->mpFrameData->mxSelection.clear(); 8780 } 8781 } 8782 8783 return mpWindowImpl->mpFrameData->mxSelection; 8784 } 8785 8786 return static_cast < XClipboard * > (0); 8787 } 8788 8789 // ----------------------------------------------------------------------- 8790 // Accessibility 8791 // ----------------------------------------------------------------------- 8792 8793 ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible > Window::GetAccessible( sal_Bool bCreate ) 8794 { 8795 // do not optimize hierarchy for the top level border win (ie, when there is no parent) 8796 /* // do not optimize accessible hierarchy at all to better reflect real VCL hierarchy 8797 if ( GetParent() && ( GetType() == WINDOW_BORDERWINDOW ) && ( GetChildCount() == 1 ) ) 8798 //if( !ImplIsAccessibleCandidate() ) 8799 { 8800 Window* pChild = GetAccessibleChildWindow( 0 ); 8801 if ( pChild ) 8802 return pChild->GetAccessible(); 8803 } 8804 */ 8805 if ( !mpWindowImpl->mxAccessible.is() && bCreate ) 8806 mpWindowImpl->mxAccessible = CreateAccessible(); 8807 8808 return mpWindowImpl->mxAccessible; 8809 } 8810 8811 ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible > Window::CreateAccessible() 8812 { 8813 ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible > xAcc( GetComponentInterface( sal_True ), ::com::sun::star::uno::UNO_QUERY ); 8814 return xAcc; 8815 } 8816 8817 void Window::SetAccessible( ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible > x ) 8818 { 8819 mpWindowImpl->mxAccessible = x; 8820 } 8821 8822 // skip all border windows that are no top level frames 8823 sal_Bool Window::ImplIsAccessibleCandidate() const 8824 { 8825 if( !mpWindowImpl->mbBorderWin ) 8826 return sal_True; 8827 else 8828 // #101741 do not check for WB_CLOSEABLE because undecorated floaters (like menues!) are closeable 8829 if( mpWindowImpl->mbFrame && mpWindowImpl->mnStyle & (WB_MOVEABLE | WB_SIZEABLE) ) 8830 return sal_True; 8831 else 8832 return sal_False; 8833 } 8834 8835 sal_Bool Window::ImplIsAccessibleNativeFrame() const 8836 { 8837 if( mpWindowImpl->mbFrame ) 8838 // #101741 do not check for WB_CLOSEABLE because undecorated floaters (like menues!) are closeable 8839 if( (mpWindowImpl->mnStyle & (WB_MOVEABLE | WB_SIZEABLE)) ) 8840 return sal_True; 8841 else 8842 return sal_False; 8843 else 8844 return sal_False; 8845 } 8846 8847 sal_uInt16 Window::ImplGetAccessibleCandidateChildWindowCount( sal_uInt16 nFirstWindowType ) const 8848 { 8849 sal_uInt16 nChildren = 0; 8850 Window* pChild = GetWindow( nFirstWindowType ); 8851 while ( pChild ) 8852 { 8853 if( pChild->ImplIsAccessibleCandidate() ) 8854 nChildren++; 8855 else 8856 nChildren = sal::static_int_cast<sal_uInt16>(nChildren + pChild->ImplGetAccessibleCandidateChildWindowCount( WINDOW_FIRSTCHILD )); 8857 pChild = pChild->mpWindowImpl->mpNext; 8858 } 8859 return nChildren; 8860 } 8861 8862 Window* Window::ImplGetAccessibleCandidateChild( sal_uInt16 nChild, sal_uInt16& rChildCount, sal_uInt16 nFirstWindowType, sal_Bool bTopLevel ) const 8863 { 8864 DBG_CHKTHIS( Window, ImplDbgCheckWindow ); 8865 8866 if( bTopLevel ) 8867 rChildCount = 0; 8868 8869 Window* pChild = GetWindow( nFirstWindowType ); 8870 while ( pChild ) 8871 { 8872 Window *pTmpChild = pChild; 8873 8874 if( !pChild->ImplIsAccessibleCandidate() ) 8875 pTmpChild = pChild->ImplGetAccessibleCandidateChild( nChild, rChildCount, WINDOW_FIRSTCHILD, sal_False ); 8876 8877 if ( nChild == rChildCount ) 8878 return pTmpChild; 8879 pChild = pChild->mpWindowImpl->mpNext; 8880 rChildCount++; 8881 } 8882 8883 return NULL; 8884 } 8885 8886 /* 8887 Window* Window::GetAccessibleParentWindow() const 8888 { 8889 Window* pParent = GetParent(); 8890 while ( pParent ) 8891 if( pParent->ImplIsAccessibleCandidate() ) 8892 break; 8893 else 8894 pParent = pParent->GetParent(); 8895 return pParent; 8896 } 8897 */ 8898 8899 Window* Window::GetAccessibleParentWindow() const 8900 { 8901 if ( ImplIsAccessibleNativeFrame() ) 8902 return NULL; 8903 8904 Window* pParent = mpWindowImpl->mpParent; 8905 if( GetType() == WINDOW_MENUBARWINDOW ) 8906 { 8907 // report the menubar as a child of THE workwindow 8908 Window *pWorkWin = GetParent()->mpWindowImpl->mpFirstChild; 8909 while( pWorkWin && (pWorkWin == this) ) 8910 pWorkWin = pWorkWin->mpWindowImpl->mpNext; 8911 pParent = pWorkWin; 8912 } 8913 // If this a floating window which has a native boarder window, this one should be reported as 8914 // accessible parent 8915 else if( GetType() == WINDOW_FLOATINGWINDOW && 8916 mpWindowImpl->mpBorderWindow && mpWindowImpl->mpBorderWindow->mpWindowImpl->mbFrame) 8917 { 8918 pParent = mpWindowImpl->mpBorderWindow; 8919 } 8920 else if( pParent && !pParent->ImplIsAccessibleCandidate() ) 8921 { 8922 pParent = pParent->mpWindowImpl->mpParent; 8923 } 8924 return pParent; 8925 } 8926 8927 /* 8928 sal_uInt16 Window::GetAccessibleChildWindowCount() 8929 { 8930 sal_uInt16 nChildren = ImplGetAccessibleCandidateChildWindowCount( WINDOW_FIRSTCHILD ); 8931 8932 // Search also for SystemWindows. 8933 Window* pOverlap = GetWindow( WINDOW_OVERLAP ); 8934 nChildren += pOverlap->ImplGetAccessibleCandidateChildWindowCount( WINDOW_FIRSTOVERLAP ); 8935 8936 return nChildren; 8937 } 8938 */ 8939 8940 sal_uInt16 Window::GetAccessibleChildWindowCount() 8941 { 8942 sal_uInt16 nChildren = 0; 8943 Window* pChild = mpWindowImpl->mpFirstChild; 8944 while( pChild ) 8945 { 8946 if( pChild->IsVisible() ) 8947 nChildren++; 8948 pChild = pChild->mpWindowImpl->mpNext; 8949 } 8950 8951 // #107176# ignore overlapwindows 8952 // this only affects non-system floating windows 8953 // which are either not accessible (like the HelpAgent) or should be changed to system windows anyway 8954 /* 8955 if( ImplIsOverlapWindow() ) 8956 { 8957 Window* pOverlap = GetWindow( WINDOW_FIRSTOVERLAP ); 8958 while ( pOverlap ) 8959 { 8960 if( pOverlap->IsVisible() ) 8961 nChildren++; 8962 pOverlap = pOverlap->GetWindow( WINDOW_NEXT ); 8963 } 8964 } 8965 */ 8966 8967 // report the menubarwindow as a child of THE workwindow 8968 if( GetType() == WINDOW_BORDERWINDOW ) 8969 { 8970 if( ((ImplBorderWindow *) this)->mpMenuBarWindow && 8971 ((ImplBorderWindow *) this)->mpMenuBarWindow->IsVisible() 8972 ) 8973 --nChildren; 8974 } 8975 else if( GetType() == WINDOW_WORKWINDOW ) 8976 { 8977 if( ((WorkWindow *) this)->GetMenuBar() && 8978 ((WorkWindow *) this)->GetMenuBar()->GetWindow() && 8979 ((WorkWindow *) this)->GetMenuBar()->GetWindow()->IsVisible() 8980 ) 8981 ++nChildren; 8982 } 8983 8984 return nChildren; 8985 } 8986 8987 /* 8988 Window* Window::GetAccessibleChildWindow( sal_uInt16 n ) 8989 { 8990 sal_uInt16 nChildCount; // will be set in ImplGetAccessibleCandidateChild(...) 8991 Window* pChild = ImplGetAccessibleCandidateChild( n, nChildCount, WINDOW_FIRSTCHILD, sal_True ); 8992 if ( !pChild && ( n >= nChildCount ) ) 8993 { 8994 Window* pOverlap = GetWindow( WINDOW_OVERLAP ); 8995 pChild = pOverlap->ImplGetAccessibleCandidateChild( n, nChildCount, WINDOW_FIRSTOVERLAP, sal_False ); 8996 } 8997 8998 return pChild; 8999 } 9000 */ 9001 9002 Window* Window::GetAccessibleChildWindow( sal_uInt16 n ) 9003 { 9004 // report the menubarwindow as a the first child of THE workwindow 9005 if( GetType() == WINDOW_WORKWINDOW && ((WorkWindow *) this)->GetMenuBar() ) 9006 { 9007 if( n == 0 ) 9008 { 9009 MenuBar *pMenuBar = ((WorkWindow *) this)->GetMenuBar(); 9010 if( pMenuBar->GetWindow() && pMenuBar->GetWindow()->IsVisible() ) 9011 return pMenuBar->GetWindow(); 9012 } 9013 else 9014 --n; 9015 } 9016 9017 // transform n to child number including invisible children 9018 sal_uInt16 nChildren = n; 9019 Window* pChild = mpWindowImpl->mpFirstChild; 9020 while( pChild ) 9021 { 9022 if( pChild->IsVisible() ) 9023 { 9024 if( ! nChildren ) 9025 break; 9026 nChildren--; 9027 } 9028 pChild = pChild->mpWindowImpl->mpNext; 9029 } 9030 9031 if( GetType() == WINDOW_BORDERWINDOW && pChild && pChild->GetType() == WINDOW_MENUBARWINDOW ) 9032 { 9033 do pChild = pChild->mpWindowImpl->mpNext; while( pChild && ! pChild->IsVisible() ); 9034 DBG_ASSERT( pChild, "GetAccessibleChildWindow(): wrong index in border window"); 9035 } 9036 if ( !pChild ) 9037 { 9038 // #107176# ignore overlapwindows 9039 /* 9040 if( ImplIsOverlapWindow() ) 9041 { 9042 Window* pOverlap = GetWindow( WINDOW_FIRSTOVERLAP ); 9043 while ( !pChild && pOverlap ) 9044 { 9045 if ( !nChildren && pOverlap->IsVisible() ) 9046 { 9047 pChild = pOverlap; 9048 break; 9049 } 9050 pOverlap = pOverlap->GetWindow( WINDOW_NEXT ); 9051 if( pOverlap && pOverlap->IsVisible() ) 9052 nChildren--; 9053 } 9054 } 9055 */ 9056 9057 } 9058 if ( pChild && ( pChild->GetType() == WINDOW_BORDERWINDOW ) && ( pChild->GetChildCount() == 1 ) ) 9059 { 9060 pChild = pChild->GetChild( 0 ); 9061 } 9062 return pChild; 9063 } 9064 9065 9066 void Window::SetAccessibleRole( sal_uInt16 nRole ) 9067 { 9068 if ( !mpWindowImpl->mpAccessibleInfos ) 9069 mpWindowImpl->mpAccessibleInfos = new ImplAccessibleInfos; 9070 9071 DBG_ASSERT( mpWindowImpl->mpAccessibleInfos->nAccessibleRole == 0xFFFF, "AccessibleRole already set!" ); 9072 mpWindowImpl->mpAccessibleInfos->nAccessibleRole = nRole; 9073 } 9074 9075 sal_uInt16 Window::GetAccessibleRole() const 9076 { 9077 using namespace ::com::sun::star; 9078 9079 sal_uInt16 nRole = mpWindowImpl->mpAccessibleInfos ? mpWindowImpl->mpAccessibleInfos->nAccessibleRole : 0xFFFF; 9080 if ( nRole == 0xFFFF ) 9081 { 9082 switch ( GetType() ) 9083 { 9084 case WINDOW_MESSBOX: // MT: Would be nice to have special roles! 9085 case WINDOW_INFOBOX: 9086 case WINDOW_WARNINGBOX: 9087 case WINDOW_ERRORBOX: 9088 case WINDOW_QUERYBOX: nRole = accessibility::AccessibleRole::ALERT; break; 9089 9090 case WINDOW_MODELESSDIALOG: 9091 case WINDOW_MODALDIALOG: 9092 case WINDOW_SYSTEMDIALOG: 9093 case WINDOW_PRINTERSETUPDIALOG: 9094 case WINDOW_PRINTDIALOG: 9095 case WINDOW_TABDIALOG: 9096 case WINDOW_BUTTONDIALOG: 9097 case WINDOW_DIALOG: nRole = accessibility::AccessibleRole::DIALOG; break; 9098 9099 case WINDOW_PUSHBUTTON: 9100 case WINDOW_OKBUTTON: 9101 case WINDOW_CANCELBUTTON: 9102 case WINDOW_HELPBUTTON: 9103 case WINDOW_IMAGEBUTTON: 9104 //case WINDOW_MENUBUTTON: 9105 case WINDOW_MOREBUTTON: 9106 case WINDOW_SPINBUTTON: 9107 case WINDOW_BUTTON: nRole = accessibility::AccessibleRole::PUSH_BUTTON; break; 9108 case WINDOW_MENUBUTTON: nRole = accessibility::AccessibleRole::BUTTON_MENU; break; 9109 9110 case WINDOW_PATHDIALOG: nRole = accessibility::AccessibleRole::DIRECTORY_PANE; break; 9111 case WINDOW_FILEDIALOG: nRole = accessibility::AccessibleRole::FILE_CHOOSER; break; 9112 case WINDOW_COLORDIALOG: nRole = accessibility::AccessibleRole::COLOR_CHOOSER; break; 9113 case WINDOW_FONTDIALOG: nRole = accessibility::AccessibleRole::FONT_CHOOSER; break; 9114 9115 case WINDOW_IMAGERADIOBUTTON: 9116 case WINDOW_RADIOBUTTON: nRole = accessibility::AccessibleRole::RADIO_BUTTON; break; 9117 case WINDOW_TRISTATEBOX: 9118 case WINDOW_CHECKBOX: nRole = accessibility::AccessibleRole::CHECK_BOX; break; 9119 9120 case WINDOW_MULTILINEEDIT: nRole = accessibility::AccessibleRole::SCROLL_PANE; break; 9121 9122 case WINDOW_PATTERNFIELD: 9123 //IAccessibility2 Impplementaton 2009----- 9124 // Need to set the role of those window control to spinbox 9125 /* 9126 case WINDOW_NUMERICFIELD: 9127 case WINDOW_METRICFIELD: 9128 case WINDOW_CURRENCYFIELD: 9129 case WINDOW_LONGCURRENCYFIELD: 9130 */ 9131 //-----IAccessibility2 Impplementaton 2009 9132 case WINDOW_EDIT: nRole = ( GetStyle() & WB_PASSWORD ) ? (accessibility::AccessibleRole::PASSWORD_TEXT) : (accessibility::AccessibleRole::TEXT); break; 9133 9134 case WINDOW_PATTERNBOX: 9135 case WINDOW_NUMERICBOX: 9136 case WINDOW_METRICBOX: 9137 case WINDOW_CURRENCYBOX: 9138 case WINDOW_LONGCURRENCYBOX: 9139 case WINDOW_COMBOBOX: nRole = accessibility::AccessibleRole::COMBO_BOX; break; 9140 9141 case WINDOW_LISTBOX: 9142 case WINDOW_MULTILISTBOX: nRole = accessibility::AccessibleRole::LIST; break; 9143 9144 case WINDOW_TREELISTBOX: nRole = accessibility::AccessibleRole::TREE; break; 9145 9146 case WINDOW_FIXEDTEXT: nRole = accessibility::AccessibleRole::LABEL; break; 9147 case WINDOW_FIXEDBORDER: 9148 nRole = accessibility::AccessibleRole::SEPARATOR; break; 9149 //IAccessibility2 Impplementaton 2009----- 9150 case WINDOW_FIXEDLINE: 9151 { if( GetText().Len() > 0 ) 9152 nRole = accessibility::AccessibleRole::LABEL; 9153 else 9154 nRole = accessibility::AccessibleRole::SEPARATOR; 9155 break; 9156 } 9157 //case WINDOW_FIXEDLINE: nRole = accessibility::AccessibleRole::SEPARATOR; break; 9158 //-----IAccessibility2 Impplementaton 2009 9159 case WINDOW_FIXEDBITMAP: 9160 case WINDOW_FIXEDIMAGE: nRole = accessibility::AccessibleRole::ICON; break; 9161 case WINDOW_GROUPBOX: nRole = accessibility::AccessibleRole::GROUP_BOX; break; 9162 case WINDOW_SCROLLBAR: nRole = accessibility::AccessibleRole::SCROLL_BAR; break; 9163 9164 case WINDOW_SLIDER: 9165 case WINDOW_SPLITTER: 9166 case WINDOW_SPLITWINDOW: nRole = accessibility::AccessibleRole::SPLIT_PANE; break; 9167 9168 case WINDOW_DATEBOX: 9169 case WINDOW_TIMEBOX: 9170 case WINDOW_DATEFIELD: 9171 case WINDOW_TIMEFIELD: nRole = accessibility::AccessibleRole::DATE_EDITOR; break; 9172 9173 //IAccessibility2 Impplementaton 2009----- 9174 // Need to set the role of those window control to spinbox 9175 case WINDOW_NUMERICFIELD: 9176 case WINDOW_METRICFIELD: 9177 case WINDOW_CURRENCYFIELD: 9178 case WINDOW_LONGCURRENCYFIELD: 9179 //-----IAccessibility2 Impplementaton 2009 9180 case WINDOW_SPINFIELD: nRole = accessibility::AccessibleRole::SPIN_BOX; break; 9181 9182 case WINDOW_TOOLBOX: nRole = accessibility::AccessibleRole::TOOL_BAR; break; 9183 case WINDOW_STATUSBAR: nRole = accessibility::AccessibleRole::STATUS_BAR; break; 9184 9185 case WINDOW_TABPAGE: nRole = accessibility::AccessibleRole::PANEL; break; 9186 case WINDOW_TABCONTROL: nRole = accessibility::AccessibleRole::PAGE_TAB_LIST; break; 9187 9188 case WINDOW_DOCKINGWINDOW: 9189 case WINDOW_SYSWINDOW: nRole = (mpWindowImpl->mbFrame) ? accessibility::AccessibleRole::FRAME : 9190 accessibility::AccessibleRole::PANEL; break; 9191 9192 case WINDOW_FLOATINGWINDOW: nRole = ( mpWindowImpl->mbFrame || 9193 (mpWindowImpl->mpBorderWindow && mpWindowImpl->mpBorderWindow->mpWindowImpl->mbFrame) || 9194 (GetStyle() & WB_OWNERDRAWDECORATION) ) ? accessibility::AccessibleRole::FRAME : 9195 accessibility::AccessibleRole::WINDOW; break; 9196 9197 case WINDOW_WORKWINDOW: nRole = accessibility::AccessibleRole::ROOT_PANE; break; 9198 9199 9200 case WINDOW_SCROLLBARBOX: nRole = accessibility::AccessibleRole::FILLER; break; 9201 9202 case WINDOW_HELPTEXTWINDOW: nRole = accessibility::AccessibleRole::TOOL_TIP; break; 9203 9204 case WINDOW_RULER: nRole = accessibility::AccessibleRole::RULER; break; 9205 case WINDOW_WINDOW: 9206 case WINDOW_CONTROL: 9207 case WINDOW_BORDERWINDOW: 9208 case WINDOW_SYSTEMCHILDWINDOW: 9209 default: 9210 if (ImplIsAccessibleNativeFrame() ) 9211 nRole = accessibility::AccessibleRole::FRAME; 9212 else if( IsScrollable() ) 9213 nRole = accessibility::AccessibleRole::SCROLL_PANE; 9214 else if( ((Window*)this)->ImplGetWindow()->IsMenuFloatingWindow() ) 9215 nRole = accessibility::AccessibleRole::WINDOW; // #106002#, contextmenues are windows (i.e. toplevel) 9216 else 9217 // #104051# WINDOW seems to be a bad default role, use LAYEREDPANE instead 9218 // a WINDOW is interpreted as a top-level window, which is typically not the case 9219 //nRole = accessibility::AccessibleRole::WINDOW; 9220 nRole = accessibility::AccessibleRole::PANEL; 9221 } 9222 } 9223 return nRole; 9224 } 9225 9226 void Window::SetAccessibleName( const String& rName ) 9227 { 9228 if ( !mpWindowImpl->mpAccessibleInfos ) 9229 mpWindowImpl->mpAccessibleInfos = new ImplAccessibleInfos; 9230 9231 //IAccessibility2 Implementation 2009----- 9232 String oldName = GetAccessibleName(); 9233 delete mpWindowImpl->mpAccessibleInfos->pAccessibleName; 9234 mpWindowImpl->mpAccessibleInfos->pAccessibleName = new String( rName ); 9235 ImplCallEventListeners( VCLEVENT_WINDOW_FRAMETITLECHANGED, &oldName ); 9236 //-----IAccessibility2 Implementation 2009 9237 } 9238 9239 String Window::GetAccessibleName() const 9240 { 9241 String aAccessibleName; 9242 if ( mpWindowImpl->mpAccessibleInfos && mpWindowImpl->mpAccessibleInfos->pAccessibleName ) 9243 { 9244 aAccessibleName = *mpWindowImpl->mpAccessibleInfos->pAccessibleName; 9245 } 9246 else 9247 { 9248 switch ( GetType() ) 9249 { 9250 // case WINDOW_IMAGERADIOBUTTON: 9251 // case WINDOW_RADIOBUTTON: 9252 // case WINDOW_TRISTATEBOX: 9253 // case WINDOW_CHECKBOX: 9254 9255 case WINDOW_MULTILINEEDIT: 9256 case WINDOW_PATTERNFIELD: 9257 case WINDOW_NUMERICFIELD: 9258 case WINDOW_METRICFIELD: 9259 case WINDOW_CURRENCYFIELD: 9260 case WINDOW_LONGCURRENCYFIELD: 9261 case WINDOW_EDIT: 9262 9263 case WINDOW_DATEBOX: 9264 case WINDOW_TIMEBOX: 9265 case WINDOW_CURRENCYBOX: 9266 case WINDOW_LONGCURRENCYBOX: 9267 case WINDOW_DATEFIELD: 9268 case WINDOW_TIMEFIELD: 9269 case WINDOW_SPINFIELD: 9270 9271 case WINDOW_COMBOBOX: 9272 case WINDOW_LISTBOX: 9273 case WINDOW_MULTILISTBOX: 9274 case WINDOW_TREELISTBOX: 9275 case WINDOW_METRICBOX: 9276 { 9277 Window *pLabel = GetAccessibleRelationLabeledBy(); 9278 if ( pLabel && pLabel != this ) 9279 aAccessibleName = pLabel->GetText(); 9280 } 9281 //IAccessibility2 Implementation 2009----- 9282 if ( !aAccessibleName.Len() ) 9283 { 9284 aAccessibleName = GetQuickHelpText(); 9285 } 9286 //-----IAccessibility2 Implementation 2009 9287 break; 9288 9289 case WINDOW_IMAGEBUTTON: 9290 case WINDOW_PUSHBUTTON: 9291 aAccessibleName = GetText(); 9292 if ( !aAccessibleName.Len() ) 9293 { 9294 aAccessibleName = GetQuickHelpText(); 9295 if ( !aAccessibleName.Len() ) 9296 aAccessibleName = GetHelpText(); 9297 } 9298 break; 9299 9300 //IAccessibility2 Implementation 2009----- 9301 case WINDOW_TOOLBOX: 9302 aAccessibleName = GetText(); 9303 if( aAccessibleName.Len() == 0 ) 9304 aAccessibleName =XubString( RTL_CONSTASCII_USTRINGPARAM( "Tool Bar" ) ); 9305 break; 9306 case WINDOW_MOREBUTTON: 9307 aAccessibleName = mpWindowImpl->maText; 9308 break; 9309 //-----IAccessibility2 Implementation 2009 9310 default: 9311 aAccessibleName = GetText(); 9312 break; 9313 } 9314 9315 aAccessibleName = GetNonMnemonicString( aAccessibleName ); 9316 } 9317 9318 return aAccessibleName; 9319 } 9320 9321 void Window::SetAccessibleDescription( const String& rDescription ) 9322 { 9323 if ( ! mpWindowImpl->mpAccessibleInfos ) 9324 mpWindowImpl->mpAccessibleInfos = new ImplAccessibleInfos; 9325 9326 DBG_ASSERT( !mpWindowImpl->mpAccessibleInfos->pAccessibleDescription, "AccessibleDescription already set!" ); 9327 delete mpWindowImpl->mpAccessibleInfos->pAccessibleDescription; 9328 mpWindowImpl->mpAccessibleInfos->pAccessibleDescription = new String( rDescription ); 9329 } 9330 9331 String Window::GetAccessibleDescription() const 9332 { 9333 String aAccessibleDescription; 9334 if ( mpWindowImpl->mpAccessibleInfos && mpWindowImpl->mpAccessibleInfos->pAccessibleDescription ) 9335 { 9336 aAccessibleDescription = *mpWindowImpl->mpAccessibleInfos->pAccessibleDescription; 9337 } 9338 else 9339 { 9340 // Special code for help text windows. ZT asks the border window for the 9341 // description so we have to forward this request to our inner window. 9342 const Window* pWin = ((Window *)this)->ImplGetWindow(); 9343 if ( pWin->GetType() == WINDOW_HELPTEXTWINDOW ) 9344 aAccessibleDescription = pWin->GetHelpText(); 9345 else 9346 aAccessibleDescription = GetHelpText(); 9347 } 9348 9349 return aAccessibleDescription; 9350 } 9351 9352 void Window::SetAccessibleRelationLabeledBy( Window* pLabeledBy ) 9353 { 9354 if ( !mpWindowImpl->mpAccessibleInfos ) 9355 mpWindowImpl->mpAccessibleInfos = new ImplAccessibleInfos; 9356 mpWindowImpl->mpAccessibleInfos->pLabeledByWindow = pLabeledBy; 9357 } 9358 9359 void Window::SetAccessibleRelationLabelFor( Window* pLabelFor ) 9360 { 9361 if ( !mpWindowImpl->mpAccessibleInfos ) 9362 mpWindowImpl->mpAccessibleInfos = new ImplAccessibleInfos; 9363 mpWindowImpl->mpAccessibleInfos->pLabelForWindow = pLabelFor; 9364 } 9365 9366 void Window::SetAccessibleRelationMemberOf( Window* pMemberOfWin ) 9367 { 9368 if ( !mpWindowImpl->mpAccessibleInfos ) 9369 mpWindowImpl->mpAccessibleInfos = new ImplAccessibleInfos; 9370 mpWindowImpl->mpAccessibleInfos->pMemberOfWindow = pMemberOfWin; 9371 } 9372 9373 sal_Bool Window::IsAccessibilityEventsSuppressed( sal_Bool bTraverseParentPath ) 9374 { 9375 if( !bTraverseParentPath ) 9376 return mpWindowImpl->mbSuppressAccessibilityEvents; 9377 else 9378 { 9379 Window *pParent = this; 9380 while ( pParent && pParent->mpWindowImpl) 9381 { 9382 if( pParent->mpWindowImpl->mbSuppressAccessibilityEvents ) 9383 return sal_True; 9384 else 9385 pParent = pParent->mpWindowImpl->mpParent; // do not use GetParent() to find borderwindows that are frames 9386 } 9387 return sal_False; 9388 } 9389 } 9390 9391 void Window::SetAccessibilityEventsSuppressed(sal_Bool bSuppressed) 9392 { 9393 mpWindowImpl->mbSuppressAccessibilityEvents = bSuppressed; 9394 } 9395 9396 void Window::RecordLayoutData( vcl::ControlLayoutData* pLayout, const Rectangle& rRect ) 9397 { 9398 if( ! mpOutDevData ) 9399 ImplInitOutDevData(); 9400 mpOutDevData->mpRecordLayout = pLayout; 9401 mpOutDevData->maRecordRect = rRect; 9402 Paint( rRect ); 9403 mpOutDevData->mpRecordLayout = NULL; 9404 } 9405 9406 // ----------------------------------------------------------------------- 9407 // ----------------------------------------------------------------------- 9408 9409 9410 // returns background color used in this control 9411 // false: could not determine color 9412 sal_Bool Window::ImplGetCurrentBackgroundColor( Color& rCol ) 9413 { 9414 sal_Bool bRet = sal_True; 9415 9416 switch ( GetType() ) 9417 { 9418 // peform special handling here 9419 case WINDOW_PUSHBUTTON: 9420 case WINDOW_OKBUTTON: 9421 case WINDOW_CANCELBUTTON: 9422 // etc. 9423 default: 9424 if( IsControlBackground() ) 9425 rCol = GetControlBackground(); 9426 else if( IsBackground() ) 9427 { 9428 Wallpaper aWall = GetBackground(); 9429 if( !aWall.IsGradient() && !aWall.IsBitmap() ) 9430 rCol = aWall.GetColor(); 9431 else 9432 bRet = sal_False; 9433 } 9434 else 9435 rCol = GetSettings().GetStyleSettings().GetFaceColor(); 9436 break; 9437 } 9438 return bRet; 9439 } 9440 9441 void Window::DrawSelectionBackground( const Rectangle& rRect, sal_uInt16 highlight, sal_Bool bChecked, sal_Bool bDrawBorder, sal_Bool bDrawExtBorderOnly ) 9442 { 9443 DrawSelectionBackground( rRect, highlight, bChecked, bDrawBorder, bDrawExtBorderOnly, 0, NULL, NULL ); 9444 } 9445 9446 void Window::DrawSelectionBackground( const Rectangle& rRect, sal_uInt16 highlight, sal_Bool bChecked, sal_Bool bDrawBorder, sal_Bool bDrawExtBorderOnly, Color* pSelectionTextColor ) 9447 { 9448 DrawSelectionBackground( rRect, highlight, bChecked, bDrawBorder, bDrawExtBorderOnly, 0, pSelectionTextColor, NULL ); 9449 } 9450 9451 void Window::DrawSelectionBackground( const Rectangle& rRect, 9452 sal_uInt16 highlight, 9453 sal_Bool bChecked, 9454 sal_Bool bDrawBorder, 9455 sal_Bool bDrawExtBorderOnly, 9456 long nCornerRadius, 9457 Color* pSelectionTextColor, 9458 Color* pPaintColor 9459 ) 9460 { 9461 if( rRect.IsEmpty() ) 9462 return; 9463 9464 bool bRoundEdges = nCornerRadius > 0; 9465 9466 const StyleSettings& rStyles = GetSettings().GetStyleSettings(); 9467 9468 9469 // colors used for item highlighting 9470 Color aSelectionBorderCol( pPaintColor ? *pPaintColor : rStyles.GetHighlightColor() ); 9471 Color aSelectionFillCol( aSelectionBorderCol ); 9472 9473 sal_Bool bDark = rStyles.GetFaceColor().IsDark(); 9474 sal_Bool bBright = ( rStyles.GetFaceColor() == Color( COL_WHITE ) ); 9475 9476 int c1 = aSelectionBorderCol.GetLuminance(); 9477 int c2 = GetDisplayBackground().GetColor().GetLuminance(); 9478 9479 if( !bDark && !bBright && abs( c2-c1 ) < (pPaintColor ? 40 : 75) ) 9480 { 9481 // constrast too low 9482 sal_uInt16 h,s,b; 9483 aSelectionFillCol.RGBtoHSB( h, s, b ); 9484 if( b > 50 ) b -= 40; 9485 else b += 40; 9486 aSelectionFillCol.SetColor( Color::HSBtoRGB( h, s, b ) ); 9487 aSelectionBorderCol = aSelectionFillCol; 9488 } 9489 9490 if( bRoundEdges ) 9491 { 9492 if( aSelectionBorderCol.IsDark() ) 9493 aSelectionBorderCol.IncreaseLuminance( 128 ); 9494 else 9495 aSelectionBorderCol.DecreaseLuminance( 128 ); 9496 } 9497 9498 Rectangle aRect( rRect ); 9499 if( bDrawExtBorderOnly ) 9500 { 9501 aRect.nLeft -= 1; 9502 aRect.nTop -= 1; 9503 aRect.nRight += 1; 9504 aRect.nBottom += 1; 9505 } 9506 Color oldFillCol = GetFillColor(); 9507 Color oldLineCol = GetLineColor(); 9508 9509 if( bDrawBorder ) 9510 SetLineColor( bDark ? Color(COL_WHITE) : ( bBright ? Color(COL_BLACK) : aSelectionBorderCol ) ); 9511 else 9512 SetLineColor(); 9513 9514 sal_uInt16 nPercent = 0; 9515 if( !highlight ) 9516 { 9517 if( bDark ) 9518 aSelectionFillCol = COL_BLACK; 9519 else 9520 nPercent = 80; // just checked (light) 9521 } 9522 else 9523 { 9524 if( bChecked && highlight == 2 ) 9525 { 9526 if( bDark ) 9527 aSelectionFillCol = COL_LIGHTGRAY; 9528 else if ( bBright ) 9529 { 9530 aSelectionFillCol = COL_BLACK; 9531 SetLineColor( COL_BLACK ); 9532 nPercent = 0; 9533 } 9534 else 9535 nPercent = bRoundEdges ? 40 : 20; // selected, pressed or checked ( very dark ) 9536 } 9537 else if( bChecked || highlight == 1 ) 9538 { 9539 if( bDark ) 9540 aSelectionFillCol = COL_GRAY; 9541 else if ( bBright ) 9542 { 9543 aSelectionFillCol = COL_BLACK; 9544 SetLineColor( COL_BLACK ); 9545 nPercent = 0; 9546 } 9547 else 9548 nPercent = bRoundEdges ? 60 : 35; // selected, pressed or checked ( very dark ) 9549 } 9550 else 9551 { 9552 if( bDark ) 9553 aSelectionFillCol = COL_LIGHTGRAY; 9554 else if ( bBright ) 9555 { 9556 aSelectionFillCol = COL_BLACK; 9557 SetLineColor( COL_BLACK ); 9558 if( highlight == 3 ) 9559 nPercent = 80; 9560 else 9561 nPercent = 0; 9562 } 9563 else 9564 nPercent = 70; // selected ( dark ) 9565 } 9566 } 9567 9568 if( bDark && bDrawExtBorderOnly ) 9569 { 9570 SetFillColor(); 9571 if( pSelectionTextColor ) 9572 *pSelectionTextColor = rStyles.GetHighlightTextColor(); 9573 } 9574 else 9575 { 9576 SetFillColor( aSelectionFillCol ); 9577 if( pSelectionTextColor ) 9578 { 9579 Color aTextColor = IsControlBackground() ? GetControlForeground() : rStyles.GetButtonTextColor(); 9580 Color aHLTextColor = rStyles.GetHighlightTextColor(); 9581 int nTextDiff = abs(aSelectionFillCol.GetLuminance() - aTextColor.GetLuminance()); 9582 int nHLDiff = abs(aSelectionFillCol.GetLuminance() - aHLTextColor.GetLuminance()); 9583 *pSelectionTextColor = (nHLDiff >= nTextDiff) ? aHLTextColor : aTextColor; 9584 } 9585 } 9586 9587 9588 if( bDark ) 9589 { 9590 DrawRect( aRect ); 9591 } 9592 else 9593 { 9594 if( bRoundEdges ) 9595 { 9596 Polygon aPoly( aRect, nCornerRadius, nCornerRadius ); 9597 PolyPolygon aPolyPoly( aPoly ); 9598 DrawTransparent( aPolyPoly, nPercent ); 9599 } 9600 else 9601 { 9602 Polygon aPoly( aRect ); 9603 PolyPolygon aPolyPoly( aPoly ); 9604 DrawTransparent( aPolyPoly, nPercent ); 9605 } 9606 } 9607 9608 SetFillColor( oldFillCol ); 9609 SetLineColor( oldLineCol ); 9610 } 9611 9612 /* 9613 void Window::DbgAssertNoEventListeners() 9614 { 9615 VclWindowEvent aEvent( this, 0, NULL ); 9616 DBG_ASSERT( mpWindowImpl->maEventListeners.empty(), "Eventlistener: Who is still listening???" ) 9617 if ( !mpWindowImpl->maEventListeners.empty() ) 9618 mpWindowImpl->maEventListeners.Call( &aEvent ); 9619 9620 DBG_ASSERT( mpWindowImpl->maChildEventListeners.empty(), "ChildEventlistener: Who is still listening???" ) 9621 if ( !mpWindowImpl->maChildEventListeners.empty() ) 9622 mpWindowImpl->maChildEventListeners.Call( &aEvent ); 9623 } 9624 */ 9625 9626 // controls should return the window that gets the 9627 // focus by default, so keyevents can be sent to that window directly 9628 Window* Window::GetPreferredKeyInputWindow() 9629 { 9630 return this; 9631 } 9632 9633 9634 sal_Bool Window::IsScrollable() const 9635 { 9636 // check for scrollbars 9637 Window *pChild = mpWindowImpl->mpFirstChild; 9638 while( pChild ) 9639 { 9640 if( pChild->GetType() == WINDOW_SCROLLBAR ) 9641 return true; 9642 else 9643 pChild = pChild->mpWindowImpl->mpNext; 9644 } 9645 return false; 9646 } 9647 9648 sal_Bool Window::IsTopWindow() const 9649 { 9650 if ( mpWindowImpl->mbInDtor ) 9651 return sal_False; 9652 9653 // topwindows must be frames or they must have a borderwindow which is a frame 9654 if( !mpWindowImpl->mbFrame && (!mpWindowImpl->mpBorderWindow || (mpWindowImpl->mpBorderWindow && !mpWindowImpl->mpBorderWindow->mpWindowImpl->mbFrame) ) ) 9655 return sal_False; 9656 9657 ImplGetWinData(); 9658 if( mpWindowImpl->mpWinData->mnIsTopWindow == (sal_uInt16)~0) // still uninitialized 9659 { 9660 // #113722#, cache result of expensive queryInterface call 9661 Window *pThisWin = (Window*)this; 9662 uno::Reference< XTopWindow > xTopWindow( pThisWin->GetComponentInterface(), UNO_QUERY ); 9663 pThisWin->mpWindowImpl->mpWinData->mnIsTopWindow = xTopWindow.is() ? 1 : 0; 9664 } 9665 return mpWindowImpl->mpWinData->mnIsTopWindow == 1 ? sal_True : sal_False; 9666 } 9667 9668 void Window::ImplMirrorFramePos( Point &pt ) const 9669 { 9670 pt.X() = mpWindowImpl->mpFrame->maGeometry.nWidth-1-pt.X(); 9671 } 9672 9673 // frame based modal counter (dialogs are not modal to the whole application anymore) 9674 sal_Bool Window::IsInModalMode() const 9675 { 9676 return (mpWindowImpl->mpFrameWindow->mpWindowImpl->mpFrameData->mnModalMode != 0); 9677 } 9678 void Window::ImplIncModalCount() 9679 { 9680 Window* pFrameWindow = mpWindowImpl->mpFrameWindow; 9681 Window* pParent = pFrameWindow; 9682 while( pFrameWindow ) 9683 { 9684 pFrameWindow->mpWindowImpl->mpFrameData->mnModalMode++; 9685 while( pParent && pParent->mpWindowImpl->mpFrameWindow == pFrameWindow ) 9686 { 9687 pParent = pParent->GetParent(); 9688 } 9689 pFrameWindow = pParent ? pParent->mpWindowImpl->mpFrameWindow : NULL; 9690 } 9691 } 9692 void Window::ImplDecModalCount() 9693 { 9694 Window* pFrameWindow = mpWindowImpl->mpFrameWindow; 9695 Window* pParent = pFrameWindow; 9696 while( pFrameWindow ) 9697 { 9698 pFrameWindow->mpWindowImpl->mpFrameData->mnModalMode--; 9699 while( pParent && pParent->mpWindowImpl->mpFrameWindow == pFrameWindow ) 9700 { 9701 pParent = pParent->GetParent(); 9702 } 9703 pFrameWindow = pParent ? pParent->mpWindowImpl->mpFrameWindow : NULL; 9704 } 9705 } 9706 sal_Bool Window::ImplIsInTaskPaneList() 9707 { 9708 return mpWindowImpl->mbIsInTaskPaneList; 9709 } 9710 void Window::ImplIsInTaskPaneList( sal_Bool mbIsInTaskList ) 9711 { 9712 mpWindowImpl->mbIsInTaskPaneList = mbIsInTaskList; 9713 } 9714 9715 void Window::ImplNotifyIconifiedState( sal_Bool bIconified ) 9716 { 9717 mpWindowImpl->mpFrameWindow->ImplCallEventListeners( bIconified ? VCLEVENT_WINDOW_MINIMIZE : VCLEVENT_WINDOW_NORMALIZE ); 9718 // #109206# notify client window as well to have toolkit topwindow listeners notified 9719 if( mpWindowImpl->mpFrameWindow->mpWindowImpl->mpClientWindow && mpWindowImpl->mpFrameWindow != mpWindowImpl->mpFrameWindow->mpWindowImpl->mpClientWindow ) 9720 mpWindowImpl->mpFrameWindow->mpWindowImpl->mpClientWindow->ImplCallEventListeners( bIconified ? VCLEVENT_WINDOW_MINIMIZE : VCLEVENT_WINDOW_NORMALIZE ); 9721 } 9722 9723 sal_Bool Window::HasActiveChildFrame() 9724 { 9725 sal_Bool bRet = sal_False; 9726 Window *pFrameWin = ImplGetSVData()->maWinData.mpFirstFrame; 9727 while( pFrameWin ) 9728 { 9729 if( pFrameWin != mpWindowImpl->mpFrameWindow ) 9730 { 9731 sal_Bool bDecorated = sal_False; 9732 Window *pChildFrame = pFrameWin->ImplGetWindow(); 9733 // #i15285# unfortunately WB_MOVEABLE is the same as WB_TABSTOP which can 9734 // be removed for ToolBoxes to influence the keyboard accessibility 9735 // thus WB_MOVEABLE is no indicator for decoration anymore 9736 // but FloatingWindows carry this information in their TitleType... 9737 // TODO: avoid duplicate WinBits !!! 9738 if( pChildFrame && pChildFrame->ImplIsFloatingWindow() ) 9739 bDecorated = ((FloatingWindow*) pChildFrame)->GetTitleType() != FLOATWIN_TITLE_NONE; 9740 if( bDecorated || (pFrameWin->mpWindowImpl->mnStyle & (WB_MOVEABLE | WB_SIZEABLE) ) ) 9741 if( pChildFrame && pChildFrame->IsVisible() && pChildFrame->IsActive() ) 9742 { 9743 if( ImplIsChild( pChildFrame, sal_True ) ) 9744 { 9745 bRet = sal_True; 9746 break; 9747 } 9748 } 9749 } 9750 pFrameWin = pFrameWin->mpWindowImpl->mpFrameData->mpNextFrame; 9751 } 9752 return bRet; 9753 } 9754 9755 LanguageType Window::GetInputLanguage() const 9756 { 9757 return mpWindowImpl->mpFrame->GetInputLanguage(); 9758 } 9759 9760 void Window::EnableNativeWidget( sal_Bool bEnable ) 9761 { 9762 static const char* pNoNWF = getenv( "SAL_NO_NWF" ); 9763 if( pNoNWF && *pNoNWF ) 9764 bEnable = sal_False; 9765 9766 if( bEnable != ImplGetWinData()->mbEnableNativeWidget ) 9767 { 9768 ImplGetWinData()->mbEnableNativeWidget = bEnable; 9769 9770 // send datachanged event to allow for internal changes required for NWF 9771 // like clipmode, transparency, etc. 9772 DataChangedEvent aDCEvt( DATACHANGED_SETTINGS, &maSettings, SETTINGS_STYLE ); 9773 DataChanged( aDCEvt ); 9774 9775 // sometimes the borderwindow is queried, so keep it in sync 9776 if( mpWindowImpl->mpBorderWindow ) 9777 mpWindowImpl->mpBorderWindow->ImplGetWinData()->mbEnableNativeWidget = bEnable; 9778 } 9779 9780 // push down, useful for compound controls 9781 Window *pChild = mpWindowImpl->mpFirstChild; 9782 while( pChild ) 9783 { 9784 pChild->EnableNativeWidget( bEnable ); 9785 pChild = pChild->mpWindowImpl->mpNext; 9786 } 9787 } 9788 9789 sal_Bool Window::IsNativeWidgetEnabled() const 9790 { 9791 return ImplGetWinData()->mbEnableNativeWidget; 9792 } 9793 9794 #ifdef WNT // see #140456# 9795 #include <win/salframe.h> 9796 #endif 9797 9798 uno::Reference< rendering::XCanvas > Window::ImplGetCanvas( const Size& rFullscreenSize, 9799 bool bFullscreen, 9800 bool bSpriteCanvas ) const 9801 { 9802 // try to retrieve hard reference from weak member 9803 uno::Reference< rendering::XCanvas > xCanvas( mpWindowImpl->mxCanvas ); 9804 9805 // canvas still valid? Then we're done. 9806 if( xCanvas.is() ) 9807 return xCanvas; 9808 9809 Sequence< Any > aArg(6); 9810 9811 // Feed any with operating system's window handle 9812 // ============================================== 9813 9814 // common: first any is VCL pointer to window (for VCL canvas) 9815 aArg[ 0 ] = makeAny( reinterpret_cast<sal_Int64>(this) ); 9816 9817 // TODO(Q1): Make GetSystemData method virtual 9818 9819 // check whether we're a SysChild: have to fetch system data 9820 // directly from SystemChildWindow, because the GetSystemData 9821 // method is unfortunately not virtual 9822 const SystemChildWindow* pSysChild = dynamic_cast< const SystemChildWindow* >( this ); 9823 if( pSysChild ) 9824 { 9825 aArg[ 1 ] = pSysChild->GetSystemDataAny(); 9826 aArg[ 5 ] = pSysChild->GetSystemGfxDataAny(); 9827 } 9828 else 9829 { 9830 aArg[ 1 ] = GetSystemDataAny(); 9831 aArg[ 5 ] = GetSystemGfxDataAny(); 9832 } 9833 9834 if( bFullscreen ) 9835 aArg[ 2 ] = makeAny( ::com::sun::star::awt::Rectangle( 0, 0, 9836 rFullscreenSize.Width(), 9837 rFullscreenSize.Height() ) ); 9838 else 9839 aArg[ 2 ] = makeAny( ::com::sun::star::awt::Rectangle( mnOutOffX, mnOutOffY, mnOutWidth, mnOutHeight ) ); 9840 9841 aArg[ 3 ] = makeAny( mpWindowImpl->mbAlwaysOnTop ? sal_True : sal_False ); 9842 aArg[ 4 ] = makeAny( uno::Reference< awt::XWindow >( 9843 const_cast<Window*>(this)->GetComponentInterface(), 9844 uno::UNO_QUERY )); 9845 9846 uno::Reference< XMultiServiceFactory > xFactory = vcl::unohelper::GetMultiServiceFactory(); 9847 9848 // Create canvas instance with window handle 9849 // ========================================= 9850 if ( xFactory.is() ) 9851 { 9852 static ::vcl::DeleteUnoReferenceOnDeinit<lang::XMultiServiceFactory> xStaticCanvasFactory( 9853 uno::Reference<lang::XMultiServiceFactory>( 9854 xFactory->createInstance( 9855 OUString( RTL_CONSTASCII_USTRINGPARAM( 9856 "com.sun.star.rendering.CanvasFactory") ) ), 9857 UNO_QUERY )); 9858 uno::Reference<lang::XMultiServiceFactory> xCanvasFactory(xStaticCanvasFactory.get()); 9859 9860 if(xCanvasFactory.is()) 9861 { 9862 #ifdef WNT 9863 // see #140456# - if we're running on a multiscreen setup, 9864 // request special, multi-screen safe sprite canvas 9865 // implementation (not DX5 canvas, as it cannot cope with 9866 // surfaces spanning multiple displays). Note: canvas 9867 // (without sprite) stays the same) 9868 const sal_uInt32 nDisplay = static_cast< WinSalFrame* >( mpWindowImpl->mpFrame )->mnDisplay; 9869 if( (nDisplay >= Application::GetScreenCount()) ) 9870 { 9871 xCanvas.set( xCanvasFactory->createInstanceWithArguments( 9872 bSpriteCanvas ? 9873 OUString( RTL_CONSTASCII_USTRINGPARAM( 9874 "com.sun.star.rendering.SpriteCanvas.MultiScreen" )) : 9875 OUString( RTL_CONSTASCII_USTRINGPARAM( 9876 "com.sun.star.rendering.Canvas.MultiScreen" )), 9877 aArg ), 9878 UNO_QUERY ); 9879 9880 } 9881 else 9882 { 9883 #endif 9884 xCanvas.set( xCanvasFactory->createInstanceWithArguments( 9885 bSpriteCanvas ? 9886 OUString( RTL_CONSTASCII_USTRINGPARAM( 9887 "com.sun.star.rendering.SpriteCanvas" )) : 9888 OUString( RTL_CONSTASCII_USTRINGPARAM( 9889 "com.sun.star.rendering.Canvas" )), 9890 aArg ), 9891 UNO_QUERY ); 9892 9893 #ifdef WNT 9894 } 9895 #endif 9896 9897 mpWindowImpl->mxCanvas = xCanvas; 9898 } 9899 } 9900 9901 // no factory??? Empty reference, then. 9902 return xCanvas; 9903 } 9904 9905 uno::Reference< rendering::XCanvas > Window::GetCanvas() const 9906 { 9907 return ImplGetCanvas( Size(), false, false ); 9908 } 9909 9910 uno::Reference< rendering::XSpriteCanvas > Window::GetSpriteCanvas() const 9911 { 9912 uno::Reference< rendering::XSpriteCanvas > xSpriteCanvas( 9913 ImplGetCanvas( Size(), false, true ), uno::UNO_QUERY ); 9914 return xSpriteCanvas; 9915 } 9916 9917 uno::Reference< ::com::sun::star::rendering::XSpriteCanvas > Window::GetFullscreenSpriteCanvas( const Size& rFullscreenSize ) const 9918 { 9919 uno::Reference< rendering::XSpriteCanvas > xSpriteCanvas( 9920 ImplGetCanvas( rFullscreenSize, true, true ), uno::UNO_QUERY ); 9921 return xSpriteCanvas; 9922 } 9923 9924 void Window::ImplPaintToDevice( OutputDevice* i_pTargetOutDev, const Point& i_rPos ) 9925 { 9926 sal_Bool bRVisible = mpWindowImpl->mbReallyVisible; 9927 mpWindowImpl->mbReallyVisible = mpWindowImpl->mbVisible; 9928 sal_Bool bDevOutput = mbDevOutput; 9929 mbDevOutput = sal_True; 9930 9931 long nOldDPIX = ImplGetDPIX(); 9932 long nOldDPIY = ImplGetDPIY(); 9933 mnDPIX = i_pTargetOutDev->ImplGetDPIX(); 9934 mnDPIY = i_pTargetOutDev->ImplGetDPIY(); 9935 sal_Bool bOutput = IsOutputEnabled(); 9936 EnableOutput(); 9937 9938 DBG_ASSERT( GetMapMode().GetMapUnit() == MAP_PIXEL, "MapMode must be PIXEL based" ); 9939 if ( GetMapMode().GetMapUnit() != MAP_PIXEL ) 9940 return; 9941 9942 // preserve graphicsstate 9943 Push(); 9944 Region aClipRegion( GetClipRegion() ); 9945 SetClipRegion(); 9946 9947 GDIMetaFile* pOldMtf = GetConnectMetaFile(); 9948 GDIMetaFile aMtf; 9949 SetConnectMetaFile( &aMtf ); 9950 9951 // put a push action to metafile 9952 Push(); 9953 // copy graphics state to metafile 9954 Font aCopyFont = GetFont(); 9955 if( nOldDPIX != mnDPIX || nOldDPIY != mnDPIY ) 9956 { 9957 aCopyFont.SetHeight( aCopyFont.GetHeight() * mnDPIY / nOldDPIY ); 9958 aCopyFont.SetWidth( aCopyFont.GetWidth() * mnDPIX / nOldDPIX ); 9959 } 9960 SetFont( aCopyFont ); 9961 SetTextColor( GetTextColor() ); 9962 if( IsLineColor() ) 9963 SetLineColor( GetLineColor() ); 9964 else 9965 SetLineColor(); 9966 if( IsFillColor() ) 9967 SetFillColor( GetFillColor() ); 9968 else 9969 SetFillColor(); 9970 if( IsTextLineColor() ) 9971 SetTextLineColor( GetTextLineColor() ); 9972 else 9973 SetTextLineColor(); 9974 if( IsOverlineColor() ) 9975 SetOverlineColor( GetOverlineColor() ); 9976 else 9977 SetOverlineColor(); 9978 if( IsTextFillColor() ) 9979 SetTextFillColor( GetTextFillColor() ); 9980 else 9981 SetTextFillColor(); 9982 SetTextAlign( GetTextAlign() ); 9983 SetRasterOp( GetRasterOp() ); 9984 if( IsRefPoint() ) 9985 SetRefPoint( GetRefPoint() ); 9986 else 9987 SetRefPoint(); 9988 SetLayoutMode( GetLayoutMode() ); 9989 SetDigitLanguage( GetDigitLanguage() ); 9990 Rectangle aPaintRect( Point( 0, 0 ), GetOutputSizePixel() ); 9991 aClipRegion.Intersect( aPaintRect ); 9992 SetClipRegion( aClipRegion ); 9993 9994 // do the actual paint 9995 9996 // background 9997 if( ! IsPaintTransparent() && IsBackground() && ! (GetParentClipMode() & PARENTCLIPMODE_NOCLIP ) ) 9998 Erase(); 9999 // foreground 10000 Paint( aPaintRect ); 10001 // put a pop action to metafile 10002 Pop(); 10003 10004 SetConnectMetaFile( pOldMtf ); 10005 EnableOutput( bOutput ); 10006 mpWindowImpl->mbReallyVisible = bRVisible; 10007 10008 // paint metafile to VDev 10009 VirtualDevice* pMaskedDevice = new VirtualDevice( *i_pTargetOutDev, 0, 0 ); 10010 pMaskedDevice->SetOutputSizePixel( GetOutputSizePixel() ); 10011 pMaskedDevice->EnableRTL( IsRTLEnabled() ); 10012 aMtf.WindStart(); 10013 aMtf.Play( pMaskedDevice ); 10014 BitmapEx aBmpEx( pMaskedDevice->GetBitmapEx( Point( 0, 0 ), pMaskedDevice->GetOutputSizePixel() ) ); 10015 i_pTargetOutDev->DrawBitmapEx( i_rPos, aBmpEx ); 10016 // get rid of virtual device now so they don't pile up during recursive calls 10017 delete pMaskedDevice, pMaskedDevice = NULL; 10018 10019 10020 for( Window* pChild = mpWindowImpl->mpFirstChild; pChild; pChild = pChild->mpWindowImpl->mpNext ) 10021 { 10022 if( pChild->mpWindowImpl->mpFrame == mpWindowImpl->mpFrame && pChild->IsVisible() ) 10023 { 10024 long nDeltaX = pChild->mnOutOffX - mnOutOffX; 10025 if( ImplHasMirroredGraphics() ) 10026 nDeltaX = mnOutWidth - nDeltaX - pChild->mnOutWidth; 10027 long nDeltaY = pChild->GetOutOffYPixel() - GetOutOffYPixel(); 10028 Point aPos( i_rPos ); 10029 Point aDelta( nDeltaX, nDeltaY ); 10030 aPos += aDelta; 10031 pChild->ImplPaintToDevice( i_pTargetOutDev, aPos ); 10032 } 10033 } 10034 10035 // restore graphics state 10036 Pop(); 10037 10038 EnableOutput( bOutput ); 10039 mpWindowImpl->mbReallyVisible = bRVisible; 10040 mbDevOutput = bDevOutput; 10041 mnDPIX = nOldDPIX; 10042 mnDPIY = nOldDPIY; 10043 } 10044 10045 void Window::PaintToDevice( OutputDevice* pDev, const Point& rPos, const Size& /*rSize*/ ) 10046 { 10047 // FIXME: scaling: currently this is for pixel copying only 10048 10049 DBG_ASSERT( ! pDev->ImplHasMirroredGraphics(), "PaintToDevice to mirroring graphics" ); 10050 DBG_ASSERT( ! pDev->IsRTLEnabled(), "PaintToDevice to mirroring device" ); 10051 10052 10053 Point aPos = pDev->LogicToPixel( rPos ); 10054 10055 Window* pRealParent = NULL; 10056 if( ! mpWindowImpl->mbVisible ) 10057 { 10058 Window* pTempParent = ImplGetDefaultWindow(); 10059 if( pTempParent ) 10060 pTempParent->EnableChildTransparentMode(); 10061 pRealParent = GetParent(); 10062 SetParent( pTempParent ); 10063 // trigger correct visibility flags for children 10064 Show(); 10065 Hide(); 10066 } 10067 10068 sal_Bool bVisible = mpWindowImpl->mbVisible; 10069 mpWindowImpl->mbVisible = sal_True; 10070 10071 if( mpWindowImpl->mpBorderWindow ) 10072 mpWindowImpl->mpBorderWindow->ImplPaintToDevice( pDev, rPos ); 10073 else 10074 ImplPaintToDevice( pDev, rPos ); 10075 10076 mpWindowImpl->mbVisible = bVisible; 10077 10078 if( pRealParent ) 10079 SetParent( pRealParent ); 10080 } 10081 10082 XubString Window::GetSurroundingText() const 10083 { 10084 return XubString::EmptyString(); 10085 } 10086 10087 Selection Window::GetSurroundingTextSelection() const 10088 { 10089 return Selection( 0, 0 ); 10090 } 10091 10092