1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_VCL_WINDOW_HXX
21 #define INCLUDED_VCL_WINDOW_HXX
23 #include <tools/solar.h>
24 #include <vcl/dllapi.h>
25 #include <vcl/outdev.hxx>
26 #include <tools/link.hxx>
27 #include <tools/wintypes.hxx>
28 #include <vcl/vclenum.hxx>
29 #include <vcl/keycodes.hxx>
30 #include <vcl/region.hxx>
31 #include <vcl/uitest/factory.hxx>
32 #include <vcl/IDialogRenderable.hxx>
33 #include <rtl/ustring.hxx>
34 #include <com/sun/star/uno/Reference.hxx>
41 struct ImplCalcToTopData
;
43 struct SystemParentData
;
44 class ImplBorderWindow
;
54 class DataChangedEvent
;
59 class MenuFloatingWindow
;
64 enum class ImplPaintFlags
;
65 enum class VclEventId
;
66 enum class PointerStyle
;
68 namespace com::sun::star
{
69 namespace accessibility
{
70 struct AccessibleRelation
;
83 namespace datatransfer::clipboard
{
86 namespace datatransfer::dnd
{
87 class XDragGestureRecognizer
;
94 struct ControlLayoutData
;
97 namespace svt
{ class PopupWindowControllerImpl
; }
99 namespace weld
{ class Window
; }
101 template<class T
> class VclPtr
;
102 namespace tools
{ class JsonWriter
; }
104 enum class TrackingEventFlags
115 template<> struct typed_flags
<TrackingEventFlags
> : is_typed_flags
<TrackingEventFlags
, 0x1107> {};
119 // Type for GetWindow()
120 enum class GetWindowType
134 FirstTopWindowChild
= 13,
135 NextTopWindowSibling
= 16,
138 // Flags for setPosSizePixel()
139 // These must match the definitions in css::awt::PosSize
140 enum class PosSizeFlags
148 Size
= Width
| Height
,
149 PosSize
= Pos
| Size
,
155 template<> struct typed_flags
<PosSizeFlags
> : is_typed_flags
<PosSizeFlags
, 0x000f> {};
162 NoFocusChange
= 0x0002,
164 ForegroundTask
= 0x0008,
168 template<> struct typed_flags
<ShowFlags
> : is_typed_flags
<ShowFlags
, 0x000e> {};
171 // Flags for SetZOrder()
172 enum class ZOrderFlags
182 template<> struct typed_flags
<ZOrderFlags
> : is_typed_flags
<ZOrderFlags
, 0x000f> {};
186 enum class ActivateModeFlags
193 template<> struct typed_flags
<ActivateModeFlags
> : is_typed_flags
<ActivateModeFlags
, 0x0001> {};
197 enum class ToTopFlags
200 RestoreWhenMin
= 0x0001,
201 ForegroundTask
= 0x0002,
202 NoGrabFocus
= 0x0004,
203 GrabFocusOnly
= 0x0008,
207 template<> struct typed_flags
<ToTopFlags
> : is_typed_flags
<ToTopFlags
, 0x000f> {};
210 // Flags for Invalidate
211 // must match css::awt::InvalidateStyle
212 enum class InvalidateFlags
215 /** The child windows are invalidated, too. */
217 /** The child windows are not invalidated. */
219 /** The invalidated area is painted with the background color/pattern. */
221 /** The invalidated area is updated immediately. */
223 /** The parent window is invalidated, too. */
224 Transparent
= 0x0010,
225 /** The parent window is not invalidated. */
226 NoTransparent
= 0x0020,
227 /** The area is invalidated regardless of overlapping child windows. */
228 NoClipChildren
= 0x4000,
232 template<> struct typed_flags
<InvalidateFlags
> : is_typed_flags
<InvalidateFlags
, 0x403f> {};
235 // Flags for Validate
236 enum class ValidateFlags
244 template<> struct typed_flags
<ValidateFlags
> : is_typed_flags
<ValidateFlags
, 0x0003> {};
248 enum class ScrollFlags
254 UseClipRegion
= 0x0008,
259 template<> struct typed_flags
<ScrollFlags
> : is_typed_flags
<ScrollFlags
, 0x001f> {};
262 // Flags for ParentClipMode
263 enum class ParentClipMode
271 template<> struct typed_flags
<ParentClipMode
> : is_typed_flags
<ParentClipMode
, 0x0003> {};
274 // Flags for ShowTracking()
275 enum class ShowTrackFlags
{
282 TrackWindow
= 0x1000,
287 template<> struct typed_flags
<ShowTrackFlags
> : is_typed_flags
<ShowTrackFlags
, 0x300f> {};
290 // Flags for StartTracking()
291 enum class StartTrackingFlags
295 ScrollRepeat
= 0x0004,
296 ButtonRepeat
= 0x0008,
301 template<> struct typed_flags
<StartTrackingFlags
> : is_typed_flags
<StartTrackingFlags
, 0x000f> {};
304 // Flags for StartAutoScroll()
305 enum class StartAutoScrollFlags
313 template<> struct typed_flags
<StartAutoScrollFlags
> : is_typed_flags
<StartAutoScrollFlags
, 0x0003> {};
316 // Flags for StateChanged()
317 enum class StateChangedType
: sal_uInt16
329 ControlForeground
= 14,
330 ControlBackground
= 15,
338 // must match constants in css:awt::FocusChangeReason
339 enum class GetFocusFlags
343 CURSOR
= 0x0002, // avoid name-clash with X11 #define
349 UniqueMnemonic
= 0x0100,
351 FloatWinPopupModeEndCancel
= 0x0400,
355 template<> struct typed_flags
<GetFocusFlags
> : is_typed_flags
<GetFocusFlags
, 0x077f> {};
368 template<> struct typed_flags
<DrawFlags
> : is_typed_flags
<DrawFlags
, 0x0005> {};
371 // DialogControl-Flags
372 enum class DialogControlFlags
377 FloatWinPopupModeEndCancel
= 0x0004,
381 template<> struct typed_flags
<DialogControlFlags
> : is_typed_flags
<DialogControlFlags
, 0x0007> {};
384 // EndExtTextInput() Flags
385 enum class EndExtTextInputFlags
392 template<> struct typed_flags
<EndExtTextInputFlags
> : is_typed_flags
<EndExtTextInputFlags
, 0x0001> {};
395 #define IMPL_MINSIZE_BUTTON_WIDTH 70
396 #define IMPL_MINSIZE_BUTTON_HEIGHT 22
397 #define IMPL_EXTRA_BUTTON_WIDTH 18
398 #define IMPL_EXTRA_BUTTON_HEIGHT 10
399 #define IMPL_SEP_BUTTON_X 5
400 #define IMPL_SEP_BUTTON_Y 5
401 #define IMPL_MINSIZE_MSGBOX_WIDTH 150
402 #define IMPL_DIALOG_OFFSET 5
403 #define IMPL_DIALOG_BAR_OFFSET 3
404 #define IMPL_MSGBOX_OFFSET_EXTRA_X 0
405 #define IMPL_MSGBOX_OFFSET_EXTRA_Y 2
406 #define IMPL_SEP_MSGBOX_IMAGE 8
408 // ImplGetDlgWindow()
409 enum class GetDlgWindowType
416 const char* ImplDbgCheckWindow( const void* pObj
);
419 namespace vcl
{ class Window
; }
420 namespace vcl
{ class Cursor
; }
431 class FloatingWindow
;
435 class SystemChildWindow
;
436 class ImplDockingWindowWrapper
;
437 class ImplPopupFloatWin
;
441 enum class WindowHitTest
{
447 template<> struct typed_flags
<WindowHitTest
> : is_typed_flags
<WindowHitTest
, 0x0003> {};
451 enum class WindowExtendedStyle
{
454 DocModified
= 0x0002,
456 * This is a frame window that is requested to be hidden (not just "not yet
462 template<> struct typed_flags
<WindowExtendedStyle
> : is_typed_flags
<WindowExtendedStyle
, 0x0007> {};
467 class VCL_DLLPUBLIC RenderTools
470 // transparent background for selected or checked items in toolboxes etc.
471 // + selection Color with a text color complementing the selection background
473 static void DrawSelectionBackground(vcl::RenderContext
& rRenderContext
, vcl::Window
const & rWindow
,
474 const tools::Rectangle
& rRect
, sal_uInt16 nHighlight
,
475 bool bChecked
, bool bDrawBorder
, bool bDrawExtBorderOnly
,
476 Color
* pSelectionTextColor
= nullptr, tools::Long nCornerRadius
= 0,
477 Color
const * pPaintColor
= nullptr);
480 class VCL_DLLPUBLIC Window
: public ::OutputDevice
482 friend class ::vcl::Cursor
;
483 friend class ::OutputDevice
;
484 friend class ::Application
;
485 friend class ::SystemWindow
;
486 friend class ::WorkWindow
;
487 friend class ::Dialog
;
489 friend class ::MessBox
;
490 friend class ::MessageDialog
;
491 friend class ::DockingWindow
;
492 friend class ::FloatingWindow
;
493 friend class ::GroupBox
;
494 friend class ::PushButton
;
495 friend class ::RadioButton
;
496 friend class ::SystemChildWindow
;
497 friend class ::ImplBorderWindow
;
498 friend class ::PaintHelper
;
499 friend class ::LifecycleTest
;
501 // TODO: improve missing functionality
502 // only required because of SetFloatingMode()
503 friend class ::ImplDockingWindowWrapper
;
504 friend class ::ImplPopupFloatWin
;
505 friend class ::MenuFloatingWindow
;
507 friend class ::svt::PopupWindowControllerImpl
;
510 // NOTE: to remove many dependencies of other modules
511 // to this central file, all members are now hidden
512 // in the WindowImpl class and all inline functions
514 // (WindowImpl is a pImpl pattern)
516 // Please do *not* add new members or inline functions to class Window,
517 // but use class WindowImpl instead
519 std::unique_ptr
<WindowImpl
> mpWindowImpl
;
522 friend const char* ::ImplDbgCheckWindow( const void* pObj
);
527 DECL_DLLPRIVATE_LINK( ImplHandlePaintHdl
, Timer
*, void );
528 DECL_DLLPRIVATE_LINK( ImplGenerateMouseMoveHdl
, void*, void );
529 DECL_DLLPRIVATE_LINK( ImplTrackTimerHdl
, Timer
*, void );
530 DECL_DLLPRIVATE_LINK( ImplAsyncFocusHdl
, void*, void );
531 DECL_DLLPRIVATE_LINK( ImplHandleResizeTimerHdl
, Timer
*, void );
534 SAL_DLLPRIVATE
static void ImplInitAppFontData( vcl::Window
const * pWindow
);
536 SAL_DLLPRIVATE
vcl::Window
* ImplGetFrameWindow() const;
537 weld::Window
* GetFrameWeld() const;
538 vcl::Window
* GetFrameWindow() const;
539 SalFrame
* ImplGetFrame() const;
540 SAL_DLLPRIVATE ImplFrameData
* ImplGetFrameData();
542 vcl::Window
* ImplGetWindow() const; ///< if this is a proxy return the client, otherwise itself
543 SAL_DLLPRIVATE ImplWinData
* ImplGetWinData() const;
544 SAL_DLLPRIVATE
vcl::Window
* ImplGetClientWindow() const;
545 SAL_DLLPRIVATE
vcl::Window
* ImplGetDlgWindow( sal_uInt16 n
, GetDlgWindowType nType
, sal_uInt16 nStart
= 0, sal_uInt16 nEnd
= 0xFFFF, sal_uInt16
* pIndex
= nullptr );
546 SAL_DLLPRIVATE
vcl::Window
* ImplGetParent() const;
547 SAL_DLLPRIVATE
vcl::Window
* ImplFindWindow( const Point
& rFramePos
);
549 SAL_DLLPRIVATE
void ImplInvalidateFrameRegion( const vcl::Region
* pRegion
, InvalidateFlags nFlags
);
550 SAL_DLLPRIVATE
void ImplInvalidateOverlapFrameRegion( const vcl::Region
& rRegion
);
552 SAL_DLLPRIVATE
bool ImplSetClipFlag( bool bSysObjOnlySmaller
= false );
554 SAL_DLLPRIVATE
bool ImplIsWindowOrChild( const vcl::Window
* pWindow
, bool bSystemWindow
= false ) const;
555 SAL_DLLPRIVATE
bool ImplIsChild( const vcl::Window
* pWindow
, bool bSystemWindow
= false ) const;
556 SAL_DLLPRIVATE
bool ImplIsFloatingWindow() const;
557 SAL_DLLPRIVATE
bool ImplIsPushButton() const;
558 SAL_DLLPRIVATE
bool ImplIsSplitter() const;
559 SAL_DLLPRIVATE
bool ImplIsOverlapWindow() const;
561 SAL_DLLPRIVATE
void ImplIsInTaskPaneList( bool mbIsInTaskList
);
563 SAL_DLLPRIVATE WindowImpl
* ImplGetWindowImpl() const { return mpWindowImpl
.get(); }
565 SAL_DLLPRIVATE Point
ImplFrameToOutput( const Point
& rPos
);
567 SAL_DLLPRIVATE
void ImplGrabFocus( GetFocusFlags nFlags
);
568 SAL_DLLPRIVATE
void ImplGrabFocusToDocument( GetFocusFlags nFlags
);
569 SAL_DLLPRIVATE
void ImplInvertFocus( const tools::Rectangle
& rRect
);
571 SAL_DLLPRIVATE PointerStyle
ImplGetMousePointer() const;
572 SAL_DLLPRIVATE
void ImplCallMouseMove( sal_uInt16 nMouseCode
, bool bModChanged
= false );
573 SAL_DLLPRIVATE
void ImplGenerateMouseMove();
575 SAL_DLLPRIVATE
void ImplNotifyKeyMouseCommandEventListeners( NotifyEvent
& rNEvt
);
576 SAL_DLLPRIVATE
void ImplNotifyIconifiedState( bool bIconified
);
578 SAL_DLLPRIVATE
void ImplUpdateAll();
580 SAL_DLLPRIVATE
void ImplControlFocus( GetFocusFlags nFlags
= GetFocusFlags::NONE
);
582 SAL_DLLPRIVATE
void ImplMirrorFramePos( Point
&pt
) const;
584 SAL_DLLPRIVATE
void ImplPosSizeWindow( tools::Long nX
, tools::Long nY
, tools::Long nWidth
, tools::Long nHeight
, PosSizeFlags nFlags
);
586 SAL_DLLPRIVATE
void ImplCallResize();
587 SAL_DLLPRIVATE
void ImplCallMove();
589 void IncModalCount();
590 void DecModalCount();
592 SAL_DLLPRIVATE
static void ImplCalcSymbolRect( tools::Rectangle
& rRect
);
596 /** This is intended to be used to clear any locally held references to other Window-subclass objects */
597 virtual void dispose() override
;
599 SAL_DLLPRIVATE
void ImplInit( vcl::Window
* pParent
, WinBits nStyle
, SystemParentData
* pSystemParentData
);
601 SAL_DLLPRIVATE Point
ImplOutputToFrame( const Point
& rPos
);
603 SAL_DLLPRIVATE
void ImplInvalidateParentFrameRegion( vcl::Region
& rRegion
);
604 SAL_DLLPRIVATE
void ImplValidateFrameRegion( const vcl::Region
* rRegion
, ValidateFlags nFlags
);
605 SAL_DLLPRIVATE
void ImplValidate();
606 SAL_DLLPRIVATE
void ImplMoveInvalidateRegion( const tools::Rectangle
& rRect
, tools::Long nHorzScroll
, tools::Long nVertScroll
, bool bChildren
);
607 SAL_DLLPRIVATE
void ImplMoveAllInvalidateRegions( const tools::Rectangle
& rRect
, tools::Long nHorzScroll
, tools::Long nVertScroll
, bool bChildren
);
609 SAL_DLLPRIVATE
vcl::Window
* ImplGetBorderWindow() const;
611 SAL_DLLPRIVATE
void ImplInvalidate( const vcl::Region
* rRegion
, InvalidateFlags nFlags
);
613 virtual WindowHitTest
ImplHitTest( const Point
& rFramePos
);
615 SAL_DLLPRIVATE
void ImplSetMouseTransparent( bool bTransparent
);
617 SAL_DLLPRIVATE
void ImplScroll( const tools::Rectangle
& rRect
, tools::Long nHorzScroll
, tools::Long nVertScroll
, ScrollFlags nFlags
);
619 SAL_DLLPRIVATE
bool ImplSetClipFlagChildren( bool bSysObjOnlySmaller
);
620 SAL_DLLPRIVATE
bool ImplSetClipFlagOverlapWindows( bool bSysObjOnlySmaller
= false );
622 SAL_DLLPRIVATE
void PushPaintHelper(PaintHelper
* pHelper
, vcl::RenderContext
& rRenderContext
);
623 SAL_DLLPRIVATE
void PopPaintHelper(PaintHelper
const * pHelper
);
627 SAL_DLLPRIVATE
void ImplSetFrameParent( const vcl::Window
* pParent
);
629 SAL_DLLPRIVATE
void ImplInsertWindow( vcl::Window
* pParent
);
630 SAL_DLLPRIVATE
void ImplRemoveWindow( bool bRemoveFrameData
);
632 SAL_DLLPRIVATE SalGraphics
* ImplGetFrameGraphics() const;
634 SAL_DLLPRIVATE
static void ImplCallFocusChangeActivate( vcl::Window
* pNewOverlapWindow
, vcl::Window
* pOldOverlapWindow
);
635 SAL_DLLPRIVATE
vcl::Window
* ImplGetFirstOverlapWindow();
636 SAL_DLLPRIVATE
const vcl::Window
* ImplGetFirstOverlapWindow() const;
638 SAL_DLLPRIVATE
bool ImplIsRealParentPath( const vcl::Window
* pWindow
) const;
640 SAL_DLLPRIVATE
bool ImplTestMousePointerSet();
642 SAL_DLLPRIVATE
void ImplResetReallyVisible();
643 SAL_DLLPRIVATE
void ImplSetReallyVisible();
645 SAL_DLLPRIVATE
void ImplCallInitShow();
647 SAL_DLLPRIVATE
void ImplInitResolutionSettings();
649 SAL_DLLPRIVATE
void ImplPointToLogic(vcl::RenderContext
const & rRenderContext
, vcl::Font
& rFont
) const;
650 SAL_DLLPRIVATE
void ImplLogicToPoint(vcl::RenderContext
const & rRenderContext
, vcl::Font
& rFont
) const;
652 SAL_DLLPRIVATE
bool ImplSysObjClip( const vcl::Region
* pOldRegion
);
653 SAL_DLLPRIVATE
void ImplUpdateSysObjChildrenClip();
654 SAL_DLLPRIVATE
void ImplUpdateSysObjOverlapsClip();
655 SAL_DLLPRIVATE
void ImplUpdateSysObjClip();
657 SAL_DLLPRIVATE
void ImplIntersectWindowClipRegion( vcl::Region
& rRegion
);
658 SAL_DLLPRIVATE
void ImplIntersectWindowRegion( vcl::Region
& rRegion
);
659 SAL_DLLPRIVATE
void ImplExcludeWindowRegion( vcl::Region
& rRegion
);
660 SAL_DLLPRIVATE
void ImplExcludeOverlapWindows( vcl::Region
& rRegion
) const;
661 SAL_DLLPRIVATE
void ImplExcludeOverlapWindows2( vcl::Region
& rRegion
);
663 SAL_DLLPRIVATE
void ImplClipBoundaries( vcl::Region
& rRegion
, bool bThis
, bool bOverlaps
);
664 SAL_DLLPRIVATE
bool ImplClipChildren( vcl::Region
& rRegion
) const;
665 SAL_DLLPRIVATE
void ImplClipAllChildren( vcl::Region
& rRegion
) const;
666 SAL_DLLPRIVATE
void ImplClipSiblings( vcl::Region
& rRegion
) const;
668 SAL_DLLPRIVATE
void ImplInitWinClipRegion();
669 SAL_DLLPRIVATE
void ImplInitWinChildClipRegion();
670 SAL_DLLPRIVATE
vcl::Region
* ImplGetWinChildClipRegion();
672 SAL_DLLPRIVATE
void ImplIntersectAndUnionOverlapWindows( const vcl::Region
& rInterRegion
, vcl::Region
& rRegion
) const;
673 SAL_DLLPRIVATE
void ImplIntersectAndUnionOverlapWindows2( const vcl::Region
& rInterRegion
, vcl::Region
& rRegion
);
674 SAL_DLLPRIVATE
void ImplCalcOverlapRegionOverlaps( const vcl::Region
& rInterRegion
, vcl::Region
& rRegion
) const;
675 SAL_DLLPRIVATE
void ImplCalcOverlapRegion( const tools::Rectangle
& rSourceRect
, vcl::Region
& rRegion
,
676 bool bChildren
, bool bSiblings
);
678 /** Invoke the actual painting.
680 This function is kind of recursive - it may be called from the
681 PaintHelper destructor; and on the other hand it creates PaintHelper
682 that (when destructed) calls other ImplCallPaint()'s.
684 SAL_DLLPRIVATE
void ImplCallPaint(const vcl::Region
* pRegion
, ImplPaintFlags nPaintFlags
);
686 SAL_DLLPRIVATE
void ImplCallOverlapPaint();
688 SAL_DLLPRIVATE
void ImplUpdateWindowPtr( vcl::Window
* pWindow
);
689 SAL_DLLPRIVATE
void ImplUpdateWindowPtr();
690 SAL_DLLPRIVATE
void ImplUpdateOverlapWindowPtr( bool bNewFrame
);
692 SAL_DLLPRIVATE
bool ImplUpdatePos();
693 SAL_DLLPRIVATE
void ImplUpdateSysObjPos();
695 SAL_DLLPRIVATE
void ImplUpdateGlobalSettings( AllSettings
& rSettings
, bool bCallHdl
= true ) const;
697 SAL_DLLPRIVATE
void ImplToBottomChild();
699 SAL_DLLPRIVATE
void ImplCalcToTop( ImplCalcToTopData
* pPrevData
);
700 SAL_DLLPRIVATE
void ImplToTop( ToTopFlags nFlags
);
701 SAL_DLLPRIVATE
void ImplStartToTop( ToTopFlags nFlags
);
702 SAL_DLLPRIVATE
void ImplFocusToTop( ToTopFlags nFlags
, bool bReallyVisible
);
704 SAL_DLLPRIVATE
void ImplShowAllOverlaps();
705 SAL_DLLPRIVATE
void ImplHideAllOverlaps();
707 SAL_DLLPRIVATE
bool ImplDlgCtrl( const KeyEvent
& rKEvt
, bool bKeyInput
);
708 SAL_DLLPRIVATE
bool ImplHasDlgCtrl() const;
709 SAL_DLLPRIVATE
void ImplDlgCtrlNextWindow();
710 SAL_DLLPRIVATE
void ImplDlgCtrlFocusChanged( vcl::Window
* pWindow
, bool bGetFocus
);
711 SAL_DLLPRIVATE
vcl::Window
* ImplFindDlgCtrlWindow( vcl::Window
* pWindow
);
713 SAL_DLLPRIVATE
static void ImplNewInputContext();
715 SAL_DLLPRIVATE
void ImplCallActivateListeners(vcl::Window
*);
716 SAL_DLLPRIVATE
void ImplCallDeactivateListeners(vcl::Window
*);
718 SAL_DLLPRIVATE
static void ImplHandleScroll(ScrollBar
* pHScrl
, double nX
, ScrollBar
* pVScrl
, double nY
);
720 SAL_DLLPRIVATE
tools::Rectangle
ImplOutputToUnmirroredAbsoluteScreenPixel( const tools::Rectangle
& rRect
) const;
721 SAL_DLLPRIVATE
tools::Rectangle
ImplUnmirroredAbsoluteScreenToOutputPixel( const tools::Rectangle
& rRect
) const;
722 SAL_DLLPRIVATE
tools::Long
ImplGetUnmirroredOutOffX();
724 // retrieves the list of owner draw decorated windows for this window hierarchy
725 SAL_DLLPRIVATE ::std::vector
<VclPtr
<vcl::Window
> >& ImplGetOwnerDrawList();
727 SAL_DLLPRIVATE
vcl::Window
* ImplGetTopmostFrameWindow();
729 SAL_DLLPRIVATE
tools::Rectangle
ImplGetWindowExtentsRelative(const vcl::Window
*pRelativeWindow
) const;
731 SAL_DLLPRIVATE
bool ImplStopDnd();
732 SAL_DLLPRIVATE
void ImplStartDnd();
734 virtual void ImplPaintToDevice( ::OutputDevice
* pTargetOutDev
, const Point
& rPos
);
736 SAL_DLLPRIVATE
css::uno::Reference
< css::rendering::XCanvas
>
737 ImplGetCanvas( bool bSpriteCanvas
) const;
740 virtual vcl::Region
GetActiveClipRegion() const override
;
741 virtual vcl::Region
GetOutputBoundsClipRegion() const override
;
744 // Single argument ctors shall be explicit.
745 explicit Window( WindowType nType
);
747 void SetCompoundControl( bool bCompound
);
749 void CallEventListeners( VclEventId nEvent
, void* pData
= nullptr );
751 virtual bool AcquireGraphics() const override
;
752 virtual void ReleaseGraphics( bool bRelease
= true ) override
;
754 virtual void InitClipRegion() override
;
756 void ImplClearFontData(bool bNewFontLists
) override
;
757 void ImplRefreshFontData(bool bNewFontLists
) override
;
758 void ImplInitMapModeObjects() override
;
760 // FIXME: this is a hack to workaround missing layout functionality
761 virtual void ImplAdjustNWFSizes();
763 virtual void CopyDeviceArea( SalTwoRect
& aPosAry
, bool bWindowInvalidate
) override
;
764 virtual const OutputDevice
* DrawOutDevDirectCheck(const OutputDevice
* pSrcDev
) const override
;
765 virtual void DrawOutDevDirectProcess( const OutputDevice
* pSrcDev
, SalTwoRect
& rPosAry
, SalGraphics
* pSrcGraphics
) override
;
766 virtual void ClipToPaintRegion( tools::Rectangle
& rDstRect
) override
;
767 virtual bool UsePolyPolygonForComplexGradient() override
;
769 virtual void ApplySettings(vcl::RenderContext
& rRenderContext
);
771 bool HasMirroredGraphics() const override
;
774 // Single argument ctors shall be explicit.
775 explicit Window( vcl::Window
* pParent
, WinBits nStyle
= 0 );
777 virtual ~Window() override
;
779 ::OutputDevice
const* GetOutDev() const;
780 ::OutputDevice
* GetOutDev();
782 Color
GetBackgroundColor() const override
;
784 size_t GetSyncCount() const override
{ return 0x000000ff; }
785 virtual void EnableRTL ( bool bEnable
= true ) override
;
786 virtual void MouseMove( const MouseEvent
& rMEvt
);
787 virtual void MouseButtonDown( const MouseEvent
& rMEvt
);
788 virtual void MouseButtonUp( const MouseEvent
& rMEvt
);
789 virtual void KeyInput( const KeyEvent
& rKEvt
);
790 virtual void KeyUp( const KeyEvent
& rKEvt
);
791 virtual void PrePaint(vcl::RenderContext
& rRenderContext
);
792 virtual void Paint(vcl::RenderContext
& rRenderContext
, const tools::Rectangle
& rRect
);
793 virtual void PostPaint(vcl::RenderContext
& rRenderContext
);
795 using OutputDevice::Erase
;
796 void Erase(vcl::RenderContext
& rRenderContext
);
798 virtual void Draw( ::OutputDevice
* pDev
, const Point
& rPos
, DrawFlags nFlags
);
800 virtual void Resize();
801 virtual void Activate();
802 virtual void Deactivate();
803 virtual void GetFocus();
804 virtual void LoseFocus();
805 virtual void RequestHelp( const HelpEvent
& rHEvt
);
806 virtual void Command( const CommandEvent
& rCEvt
);
807 virtual void Tracking( const TrackingEvent
& rTEvt
);
808 virtual void StateChanged( StateChangedType nStateChange
);
809 virtual void DataChanged( const DataChangedEvent
& rDCEvt
);
810 virtual bool PreNotify( NotifyEvent
& rNEvt
);
811 virtual bool EventNotify( NotifyEvent
& rNEvt
);
813 // These methods call the relevant virtual method when not in/post dispose
814 void CompatGetFocus();
815 void CompatLoseFocus();
816 void CompatStateChanged( StateChangedType nStateChange
);
817 void CompatDataChanged( const DataChangedEvent
& rDCEvt
);
818 bool CompatPreNotify( NotifyEvent
& rNEvt
);
819 bool CompatNotify( NotifyEvent
& rNEvt
);
821 void AddEventListener( const Link
<VclWindowEvent
&,void>& rEventListener
);
822 void RemoveEventListener( const Link
<VclWindowEvent
&,void>& rEventListener
);
823 void AddChildEventListener( const Link
<VclWindowEvent
&,void>& rEventListener
);
824 void RemoveChildEventListener( const Link
<VclWindowEvent
&,void>& rEventListener
);
826 ImplSVEvent
* PostUserEvent( const Link
<void*,void>& rLink
, void* pCaller
= nullptr, bool bReferenceLink
= false );
827 void RemoveUserEvent( ImplSVEvent
* nUserEvent
);
829 // returns the input language used for the last key stroke
830 // may be LANGUAGE_DONTKNOW if not supported by the OS
831 LanguageType
GetInputLanguage() const;
833 void SetStyle( WinBits nStyle
);
834 WinBits
GetStyle() const;
835 WinBits
GetPrevStyle() const;
836 void SetExtendedStyle( WindowExtendedStyle nExtendedStyle
);
837 WindowExtendedStyle
GetExtendedStyle() const;
838 void SetType( WindowType nType
);
839 WindowType
GetType() const;
840 bool IsSystemWindow() const;
841 bool IsDockingWindow() const;
842 bool IsDialog() const;
843 bool IsMenuFloatingWindow() const;
844 bool IsToolbarFloatingWindow() const;
845 bool IsTopWindow() const;
846 bool IsDisposed() const;
847 SystemWindow
* GetSystemWindow() const;
849 /// Can the widget derived from this Window do the double-buffering via RenderContext properly?
850 bool SupportsDoubleBuffering() const;
851 /// Enable/disable double-buffering of the frame window and all its children.
852 void RequestDoubleBuffering(bool bRequest
);
854 void EnableAllResize();
856 void SetBorderStyle( WindowBorderStyle nBorderStyle
);
857 WindowBorderStyle
GetBorderStyle() const;
858 void GetBorder( sal_Int32
& rLeftBorder
, sal_Int32
& rTopBorder
,
859 sal_Int32
& rRightBorder
, sal_Int32
& rBottomBorder
) const;
860 Size
CalcWindowSize( const Size
& rOutSz
) const;
861 Size
CalcOutputSize( const Size
& rWinSz
) const;
862 tools::Long
CalcTitleWidth() const;
864 void EnableClipSiblings( bool bClipSiblings
= true );
866 void EnableChildTransparentMode( bool bEnable
= true );
867 bool IsChildTransparentModeEnabled() const;
869 void SetMouseTransparent( bool bTransparent
);
870 bool IsMouseTransparent() const;
871 void SetPaintTransparent( bool bTransparent
);
872 bool IsPaintTransparent() const;
873 void SetDialogControlStart( bool bStart
);
874 bool IsDialogControlStart() const;
875 void SetDialogControlFlags( DialogControlFlags nFlags
);
876 DialogControlFlags
GetDialogControlFlags() const;
880 sal_uLong mnState
; // the button state
881 Point maPos
; // mouse position in output coordinates
883 PointerState
GetPointerState();
884 bool IsMouseOver() const;
886 void SetInputContext( const InputContext
& rInputContext
);
887 const InputContext
& GetInputContext() const;
888 void PostExtTextInputEvent(VclEventId nType
, const OUString
& rText
);
889 void EndExtTextInput();
890 void SetCursorRect( const tools::Rectangle
* pRect
= nullptr, tools::Long nExtTextInputWidth
= 0 );
891 const tools::Rectangle
* GetCursorRect() const;
892 tools::Long
GetCursorExtTextInputWidth() const;
894 void SetCompositionCharRect( const tools::Rectangle
* pRect
, tools::Long nCompositionLength
, bool bVertical
= false );
896 using ::OutputDevice::SetSettings
;
897 virtual void SetSettings( const AllSettings
& rSettings
) override
;
898 void SetSettings( const AllSettings
& rSettings
, bool bChild
);
899 void UpdateSettings( const AllSettings
& rSettings
, bool bChild
= false );
900 void NotifyAllChildren( DataChangedEvent
& rDCEvt
);
902 void SetPointFont(vcl::RenderContext
& rRenderContext
, const vcl::Font
& rFont
);
903 vcl::Font
GetPointFont(vcl::RenderContext
const & rRenderContext
) const;
904 void SetZoomedPointFont(vcl::RenderContext
& rRenderContext
, const vcl::Font
& rFont
);
905 tools::Long
GetDrawPixel( ::OutputDevice
const * pDev
, tools::Long nPixels
) const;
906 vcl::Font
GetDrawPixelFont( ::OutputDevice
const * pDev
) const;
908 void SetControlFont();
909 void SetControlFont( const vcl::Font
& rFont
);
910 vcl::Font
GetControlFont() const;
911 bool IsControlFont() const;
912 void ApplyControlFont(vcl::RenderContext
& rRenderContext
, const vcl::Font
& rDefaultFont
);
914 void SetControlForeground();
915 void SetControlForeground(const Color
& rColor
);
916 const Color
& GetControlForeground() const;
917 bool IsControlForeground() const;
918 void ApplyControlForeground(vcl::RenderContext
& rRenderContext
, const Color
& rDefaultColor
);
920 void SetControlBackground();
921 void SetControlBackground( const Color
& rColor
);
922 const Color
& GetControlBackground() const;
923 bool IsControlBackground() const;
924 void ApplyControlBackground(vcl::RenderContext
& rRenderContext
, const Color
& rDefaultColor
);
926 void SetParentClipMode( ParentClipMode nMode
= ParentClipMode::NONE
);
927 ParentClipMode
GetParentClipMode() const;
929 void SetWindowRegionPixel();
930 void SetWindowRegionPixel( const vcl::Region
& rRegion
);
931 vcl::Region
GetWindowClipRegionPixel() const;
932 vcl::Region
GetPaintRegion() const;
933 bool IsInPaint() const;
934 // while IsInPaint returns true ExpandPaintClipRegion adds the
935 // submitted region to the paint clip region so you can
936 // paint additional parts of your window if necessary
937 void ExpandPaintClipRegion( const vcl::Region
& rRegion
);
939 void SetParent( vcl::Window
* pNewParent
);
940 vcl::Window
* GetParent() const;
941 // return the dialog we are contained in or NULL if un-contained
942 Dialog
* GetParentDialog() const;
943 bool IsAncestorOf( const vcl::Window
& rWindow
) const;
945 void Show( bool bVisible
= true, ShowFlags nFlags
= ShowFlags::NONE
);
946 void Hide() { Show( false ); }
947 bool IsVisible() const;
948 bool IsReallyVisible() const;
949 bool IsReallyShown() const;
950 bool IsInInitShow() const;
952 void Enable( bool bEnable
= true, bool bChild
= true );
953 void Disable( bool bChild
= true ) { Enable( false, bChild
); }
954 bool IsEnabled() const;
956 void EnableInput( bool bEnable
= true, bool bChild
= true );
957 void EnableInput( bool bEnable
, const vcl::Window
* pExcludeWindow
);
958 bool IsInputEnabled() const;
960 /** Override <code>EnableInput</code>. This can be necessary due to other people
961 using EnableInput for whole window hierarchies.
964 sets always enabled flag
967 if true children are recursively set to AlwaysEnableInput
969 void AlwaysEnableInput( bool bAlways
, bool bChild
= true );
971 /** returns the current AlwaysEnableInput state
973 true if window is in AlwaysEnableInput state
975 bool IsAlwaysEnableInput() const;
977 /** A window is in modal mode if one of its children or subchildren
978 is a running modal window (a modal dialog)
980 @returns sal_True if a child or subchild is a running modal window
982 bool IsInModalMode() const;
984 void SetActivateMode( ActivateModeFlags nMode
);
985 ActivateModeFlags
GetActivateMode() const;
987 void ToTop( ToTopFlags nFlags
= ToTopFlags::NONE
);
988 void SetZOrder( vcl::Window
* pRefWindow
, ZOrderFlags nFlags
);
989 void EnableAlwaysOnTop( bool bEnable
= true );
990 bool IsAlwaysOnTopEnabled() const;
992 virtual void setPosSizePixel( tools::Long nX
, tools::Long nY
,
993 tools::Long nWidth
, tools::Long nHeight
,
994 PosSizeFlags nFlags
= PosSizeFlags::All
);
995 virtual void SetPosPixel( const Point
& rNewPos
);
996 virtual Point
GetPosPixel() const;
997 virtual void SetSizePixel( const Size
& rNewSize
);
998 virtual Size
GetSizePixel() const;
999 virtual void SetPosSizePixel( const Point
& rNewPos
,
1000 const Size
& rNewSize
);
1001 virtual void SetOutputSizePixel( const Size
& rNewSize
);
1002 bool IsDefaultPos() const;
1003 bool IsDefaultSize() const;
1004 Point
GetOffsetPixelFrom(const vcl::Window
& rWindow
) const;
1006 // those conversion routines might deliver different results during UI mirroring
1007 Point
OutputToScreenPixel( const Point
& rPos
) const;
1008 Point
ScreenToOutputPixel( const Point
& rPos
) const;
1009 // the normalized screen methods work independent from UI mirroring
1010 Point
OutputToNormalizedScreenPixel( const Point
& rPos
) const;
1011 Point
NormalizedScreenToOutputPixel( const Point
& rPos
) const;
1012 Point
OutputToAbsoluteScreenPixel( const Point
& rPos
) const;
1013 Point
AbsoluteScreenToOutputPixel( const Point
& rPos
) const;
1014 tools::Rectangle
GetDesktopRectPixel() const;
1015 // window extents including border and decoration
1016 tools::Rectangle
GetWindowExtentsRelative(const vcl::Window
*pRelativeWindow
) const;
1018 bool IsScrollable() const;
1019 virtual void Scroll( tools::Long nHorzScroll
, tools::Long nVertScroll
,
1020 ScrollFlags nFlags
= ScrollFlags::NONE
);
1021 void Scroll( tools::Long nHorzScroll
, tools::Long nVertScroll
,
1022 const tools::Rectangle
& rRect
, ScrollFlags nFlags
= ScrollFlags::NONE
);
1023 virtual void Invalidate( InvalidateFlags nFlags
= InvalidateFlags::NONE
);
1024 virtual void Invalidate( const tools::Rectangle
& rRect
, InvalidateFlags nFlags
= InvalidateFlags::NONE
);
1025 virtual void Invalidate( const vcl::Region
& rRegion
, InvalidateFlags nFlags
= InvalidateFlags::NONE
);
1027 * Notification about some rectangle of the output device got invalidated.Used for the main
1030 * @param pRectangle If 0, that means the whole area, otherwise the area in logic coordinates.
1032 virtual void LogicInvalidate(const tools::Rectangle
* pRectangle
);
1035 * Notification about some rectangle of the output device got invalidated. Used for the
1036 * dialogs and floating windows (e.g. context menu, popup).
1038 * @param pRectangle If 0, that means the whole area, otherwise the area in pixel coordinates.
1040 virtual void PixelInvalidate(const tools::Rectangle
* pRectangle
);
1042 bool HasPaintEvent() const;
1043 void PaintImmediately();
1044 void Flush() override
;
1046 // toggles new docking support, enabled via toolkit
1047 void EnableDocking( bool bEnable
= true );
1048 // retrieves the single dockingmanager instance
1049 static DockingManager
* GetDockingManager();
1051 void EnablePaint( bool bEnable
);
1052 bool IsPaintEnabled() const;
1053 void SetUpdateMode( bool bUpdate
);
1054 bool IsUpdateMode() const;
1055 void SetParentUpdateMode( bool bUpdate
);
1058 bool HasFocus() const;
1059 bool HasChildPathFocus( bool bSystemWindow
= false ) const;
1060 bool IsActive() const;
1061 bool HasActiveChildFrame() const;
1062 GetFocusFlags
GetGetFocusFlags() const;
1063 void GrabFocusToDocument();
1064 VclPtr
<vcl::Window
> GetFocusedWindow() const;
1067 * Set this when you need to act as if the window has focus even if it
1068 * doesn't. This is necessary for implementing tab stops inside floating
1069 * windows, but floating windows don't get focus from the system.
1071 void SetFakeFocus( bool bFocus
);
1073 bool IsCompoundControl() const;
1075 static VclPtr
<vcl::Window
> SaveFocus();
1076 static void EndSaveFocus(const VclPtr
<vcl::Window
>& xFocusWin
);
1078 void LocalStartDrag();
1079 void CaptureMouse();
1080 void ReleaseMouse();
1081 bool IsMouseCaptured() const;
1083 void SetPointer( PointerStyle
);
1084 PointerStyle
GetPointer() const;
1085 void EnableChildPointerOverwrite( bool bOverwrite
);
1086 void SetPointerPosPixel( const Point
& rPos
);
1087 Point
GetPointerPosPixel();
1088 Point
GetLastPointerPosPixel();
1089 /// Similar to SetPointerPosPixel(), but sets the frame data's last mouse position instead.
1090 void SetLastMousePos(const Point
& rPos
);
1091 void ShowPointer( bool bVisible
);
1094 bool IsWait() const;
1096 void SetCursor( vcl::Cursor
* pCursor
);
1097 vcl::Cursor
* GetCursor() const;
1099 void SetZoom( const Fraction
& rZoom
);
1100 const Fraction
& GetZoom() const;
1101 bool IsZoom() const;
1102 tools::Long
CalcZoom( tools::Long n
) const;
1104 virtual void SetText( const OUString
& rStr
);
1105 virtual OUString
GetText() const;
1106 // return the actual text displayed
1107 // this may have e.g. accelerators removed or portions
1108 // replaced by ellipses
1109 virtual OUString
GetDisplayText() const;
1110 // gets the visible background color. for transparent windows
1111 // this may be the parent's background color; for controls
1112 // this may be a child's background color (e.g. ListBox)
1113 virtual const Wallpaper
& GetDisplayBackground() const;
1115 void SetHelpText( const OUString
& rHelpText
);
1116 const OUString
& GetHelpText() const;
1118 void SetQuickHelpText( const OUString
& rHelpText
);
1119 const OUString
& GetQuickHelpText() const;
1121 void SetHelpId( const OString
& );
1122 const OString
& GetHelpId() const;
1124 sal_uInt16
GetChildCount() const;
1125 vcl::Window
* GetChild( sal_uInt16 nChild
) const;
1126 vcl::Window
* GetWindow( GetWindowType nType
) const;
1127 bool IsChild( const vcl::Window
* pWindow
) const;
1128 bool IsWindowOrChild( const vcl::Window
* pWindow
, bool bSystemWindow
= false ) const;
1130 /// Add all children to rAllChildren recursively.
1131 SAL_DLLPRIVATE
void CollectChildren(::std::vector
<vcl::Window
*>& rAllChildren
);
1133 virtual void ShowFocus(const tools::Rectangle
& rRect
);
1136 // transparent background for selected or checked items in toolboxes etc.
1137 void DrawSelectionBackground( const tools::Rectangle
& rRect
, sal_uInt16 highlight
, bool bChecked
, bool bDrawBorder
);
1139 void ShowTracking( const tools::Rectangle
& rRect
,
1140 ShowTrackFlags nFlags
= ShowTrackFlags::Small
);
1141 void HideTracking();
1142 void InvertTracking( const tools::Rectangle
& rRect
, ShowTrackFlags nFlags
);
1144 void StartTracking( StartTrackingFlags nFlags
= StartTrackingFlags::NONE
);
1145 void EndTracking( TrackingEventFlags nFlags
= TrackingEventFlags::NONE
);
1146 bool IsTracking() const;
1148 void StartAutoScroll( StartAutoScrollFlags nFlags
);
1149 void EndAutoScroll();
1151 bool HandleScrollCommand( const CommandEvent
& rCmd
,
1153 ScrollBar
* pVScrl
);
1155 void SaveBackground(VirtualDevice
& rSaveDevice
,
1156 const Point
& rPos
, const Size
& rSize
, const Size
&) const override
;
1158 virtual const SystemEnvData
* GetSystemData() const;
1160 // API to set/query the component interfaces
1161 virtual css::uno::Reference
< css::awt::XWindowPeer
>
1162 GetComponentInterface( bool bCreate
= true );
1164 void SetComponentInterface( css::uno::Reference
< css::awt::XWindowPeer
> const & xIFace
);
1166 void SetUseFrameData(bool bUseFrameData
);
1168 /// Interface to register for dialog / window tunneling.
1169 void SetLOKNotifier(const vcl::ILibreOfficeKitNotifier
* pNotifier
, bool bParent
= false);
1170 const vcl::ILibreOfficeKitNotifier
* GetLOKNotifier() const;
1171 vcl::LOKWindowId
GetLOKWindowId() const;
1173 /// Find the nearest parent with LOK Notifier; can be itself if this Window has LOK notifier set.
1174 VclPtr
<vcl::Window
> GetParentWithLOKNotifier();
1176 /// Indicate that LOK is not going to use this dialog any more.
1177 void ReleaseLOKNotifier();
1179 /// Find an existing Window based on the LOKWindowId.
1180 static VclPtr
<vcl::Window
> FindLOKWindow(vcl::LOKWindowId nWindowId
);
1182 /// check if LOK Window container is empty
1183 static bool IsLOKWindowsEmpty();
1185 /// Dumps itself and potentially its children to a property tree, to be written easily to JSON.
1186 virtual void DumpAsPropertyTree(tools::JsonWriter
&);
1188 /// Same as MouseButtonDown(), but coordinates are in logic unit. used for LOK
1189 virtual void LogicMouseButtonDown(const MouseEvent
&) {};
1190 /// Same as MouseButtonUp(), but coordinates are in logic unit. used for LOK
1191 virtual void LogicMouseButtonUp(const MouseEvent
&) {};
1192 /// Same as MouseMove(), but coordinates are in logic unit. used for LOK
1193 virtual void LogicMouseMove(const MouseEvent
&) {};
1195 /** @name Accessibility
1200 css::uno::Reference
< css::accessibility::XAccessible
>
1201 GetAccessible( bool bCreate
= true );
1203 virtual css::uno::Reference
< css::accessibility::XAccessible
>
1206 void SetAccessible( const css::uno::Reference
< css::accessibility::XAccessible
>& );
1208 vcl::Window
* GetAccessibleParentWindow() const;
1209 sal_uInt16
GetAccessibleChildWindowCount();
1210 vcl::Window
* GetAccessibleChildWindow( sal_uInt16 n
);
1212 void SetAccessibleRole( sal_uInt16 nRole
);
1213 sal_uInt16
GetAccessibleRole() const;
1215 void SetAccessibleName( const OUString
& rName
);
1216 OUString
GetAccessibleName() const;
1218 void SetAccessibleDescription( const OUString
& rDescr
);
1219 OUString
GetAccessibleDescription() const;
1221 void SetAccessibleRelationLabeledBy( vcl::Window
* pLabeledBy
);
1222 vcl::Window
* GetAccessibleRelationLabeledBy() const;
1224 void SetAccessibleRelationLabelFor( vcl::Window
* pLabelFor
);
1225 vcl::Window
* GetAccessibleRelationLabelFor() const;
1227 void SetAccessibleRelationMemberOf( vcl::Window
* pMemberOf
);
1228 vcl::Window
* GetAccessibleRelationMemberOf() const;
1230 // to avoid sending accessibility events in cases like closing dialogs
1231 // by default checks complete parent path
1232 bool IsAccessibilityEventsSuppressed( bool bTraverseParentPath
= true );
1233 void SetAccessibilityEventsSuppressed(bool bSuppressed
);
1235 KeyEvent
GetActivationKey() const;
1239 // These eventually are supposed to go when everything is converted to .ui
1240 SAL_DLLPRIVATE
vcl::Window
* getLegacyNonLayoutAccessibleRelationMemberOf() const;
1241 SAL_DLLPRIVATE
vcl::Window
* getLegacyNonLayoutAccessibleRelationLabeledBy() const;
1242 SAL_DLLPRIVATE
vcl::Window
* getLegacyNonLayoutAccessibleRelationLabelFor() const;
1244 // Let Label override the code part of GetAccessibleRelationLabelFor
1245 virtual vcl::Window
* getAccessibleRelationLabelFor() const;
1246 virtual sal_uInt16
getDefaultAccessibleRole() const;
1247 virtual OUString
getDefaultAccessibleName() const;
1250 * Advisory Sizing - what is a good size for this widget
1252 * Retrieves the preferred size of a widget ignoring
1253 * "width-request" and "height-request" properties.
1255 * Implement this in sub-classes to tell layout
1256 * the preferred widget size.
1258 * Use get_preferred_size to retrieve this value
1259 * cached and mediated via height and width requests
1261 virtual Size
GetOptimalSize() const;
1262 /// clear OptimalSize cache
1263 void InvalidateSizeCache();
1266 SAL_DLLPRIVATE
bool ImplIsAccessibleCandidate() const;
1267 SAL_DLLPRIVATE
bool ImplIsAccessibleNativeFrame() const;
1271 * Retrieves the preferred size of a widget taking
1272 * into account the "width-request" and "height-request" properties.
1274 * Overrides the result of GetOptimalSize to honor the
1275 * width-request and height-request properties.
1277 * So the same as get_ungrouped_preferred_size except
1278 * it ignores groups. A building block of get_preferred_size
1279 * that access the size cache
1281 * @see get_preferred_size
1283 Size
get_ungrouped_preferred_size() const;
1285 /// request XCanvas render interface for this window
1286 css::uno::Reference
< css::rendering::XCanvas
>
1288 /// request XSpriteCanvas render interface for this window
1289 css::uno::Reference
< css::rendering::XSpriteCanvas
>
1290 GetSpriteCanvas() const;
1292 /* records all DrawText operations within the passed rectangle;
1293 * a synchronous paint is sent to achieve this
1295 void RecordLayoutData( vcl::ControlLayoutData
* pLayout
, const tools::Rectangle
& rRect
);
1297 // set and retrieve for Toolkit
1298 VCLXWindow
* GetWindowPeer() const;
1299 void SetWindowPeer( css::uno::Reference
< css::awt::XWindowPeer
> const & xPeer
, VCLXWindow
* pVCLXWindow
);
1301 // remember if it was generated by Toolkit
1302 bool IsCreatedWithToolkit() const;
1303 void SetCreatedWithToolkit( bool b
);
1305 // Drag and Drop interfaces
1306 css::uno::Reference
< css::datatransfer::dnd::XDropTarget
> GetDropTarget();
1307 css::uno::Reference
< css::datatransfer::dnd::XDragSource
> GetDragSource();
1308 css::uno::Reference
< css::datatransfer::dnd::XDragGestureRecognizer
> GetDragGestureRecognizer();
1310 // Clipboard/Selection interfaces
1311 css::uno::Reference
< css::datatransfer::clipboard::XClipboard
> GetClipboard();
1312 /// Sets a custom clipboard for the window's frame, instead of creating it on-demand using css::datatransfer::clipboard::SystemClipboard.
1313 void SetClipboard(css::uno::Reference
<css::datatransfer::clipboard::XClipboard
> const & xClipboard
);
1314 css::uno::Reference
< css::datatransfer::clipboard::XClipboard
> GetPrimarySelection();
1317 * Widgets call this to inform their owner container that the widget wants
1318 * to renegotiate its size. Should be called when a widget has a new size
1319 * request. e.g. a FixedText Control gets a new label.
1321 * akin to gtk_widget_queue_resize
1323 virtual void queue_resize(StateChangedType eReason
= StateChangedType::Layout
);
1326 * Sets the "height-request" property
1328 * Override for height request of the widget, or -1 if natural request
1331 * @see get_preferred_size, set_width_request
1333 void set_height_request(sal_Int32 nHeightRequest
);
1334 sal_Int32
get_height_request() const;
1337 * Sets the "width-request" property
1339 * Override for width request of the widget, or -1 if natural request
1342 * @see get_preferred_size, set_height_request
1344 void set_width_request(sal_Int32 nWidthRequest
);
1345 sal_Int32
get_width_request() const;
1348 * Retrieves the preferred size of a widget taking
1349 * into account the "width-request" and "height-request" properties.
1351 * Overrides the result of GetOptimalSize to honor the
1352 * width-request and height-request properties.
1354 * @see GetOptimalSize
1356 * akin to gtk_widget_get_preferred_size
1358 Size
get_preferred_size() const;
1361 * How to horizontally align this widget
1363 VclAlign
get_halign() const;
1364 void set_halign(VclAlign eAlign
);
1367 * How to vertically align this widget
1369 VclAlign
get_valign() const;
1370 void set_valign(VclAlign eAlign
);
1373 * Whether the widget would like to use any available extra horizontal
1376 bool get_hexpand() const;
1377 void set_hexpand(bool bExpand
);
1380 * Whether the widget would like to use any available extra vertical
1383 bool get_vexpand() const;
1384 void set_vexpand(bool bExpand
);
1387 * Whether the widget would like to use any available extra space.
1389 bool get_expand() const;
1390 void set_expand(bool bExpand
);
1393 * Whether the widget should receive extra space when the parent grows
1395 bool get_fill() const;
1396 void set_fill(bool bFill
);
1398 void set_border_width(sal_Int32 nBorderWidth
);
1399 sal_Int32
get_border_width() const;
1401 void set_margin_left(sal_Int32 nWidth
);
1402 sal_Int32
get_margin_left() const;
1404 void set_margin_right(sal_Int32 nWidth
);
1405 sal_Int32
get_margin_right() const;
1407 void set_margin_top(sal_Int32 nWidth
);
1408 sal_Int32
get_margin_top() const;
1410 void set_margin_bottom(sal_Int32 nWidth
);
1411 sal_Int32
get_margin_bottom() const;
1414 * How the widget is packed with reference to the start or end of the parent
1416 VclPackType
get_pack_type() const;
1417 void set_pack_type(VclPackType ePackType
);
1420 * The extra space to put between the widget and its neighbors
1422 sal_Int32
get_padding() const;
1423 void set_padding(sal_Int32 nPadding
);
1426 * The number of columns that the widget spans
1428 sal_Int32
get_grid_width() const;
1429 void set_grid_width(sal_Int32 nCols
);
1432 * The column number to attach the left side of the widget to
1434 sal_Int32
get_grid_left_attach() const;
1435 void set_grid_left_attach(sal_Int32 nAttach
);
1438 * The number of row that the widget spans
1440 sal_Int32
get_grid_height() const;
1441 void set_grid_height(sal_Int32 nRows
);
1444 * The row number to attach the top side of the widget to
1446 sal_Int32
get_grid_top_attach() const;
1447 void set_grid_top_attach(sal_Int32 nAttach
);
1450 * If true this child appears in a secondary layout group of children
1451 * e.g. help buttons in a buttonbox
1453 bool get_secondary() const;
1454 void set_secondary(bool bSecondary
);
1457 * If true this child is exempted from homogeneous sizing
1458 * e.g. special button in a buttonbox
1460 bool get_non_homogeneous() const;
1461 void set_non_homogeneous(bool bNonHomogeneous
);
1464 * Sets a widget property
1466 * @return false if property is unknown
1468 virtual bool set_property(const OString
&rKey
, const OUString
&rValue
);
1471 * Sets a font attribute
1473 * @return false if attribute is unknown
1475 bool set_font_attribute(const OString
&rKey
, const OUString
&rValue
);
1478 * Adds this widget to the xGroup VclSizeGroup
1481 void add_to_size_group(const std::shared_ptr
<VclSizeGroup
>& xGroup
);
1482 void remove_from_all_size_groups();
1485 * add/remove mnemonic label
1487 void add_mnemonic_label(FixedText
*pLabel
);
1488 void remove_mnemonic_label(FixedText
*pLabel
);
1489 const std::vector
<VclPtr
<FixedText
> >& list_mnemonic_labels() const;
1492 * Move this widget to be the nNewPosition'd child of its parent
1494 void reorderWithinParent(sal_uInt16 nNewPosition
);
1499 void set_id(const OUString
& rID
);
1502 * Get the ID of the window.
1504 const OUString
& get_id() const;
1507 // Native Widget Rendering functions
1510 // form controls must never use native widgets, this can be toggled here
1511 void EnableNativeWidget( bool bEnable
= true );
1512 bool IsNativeWidgetEnabled() const;
1514 // a helper method for a Control's Draw method
1515 void PaintToDevice( ::OutputDevice
* pDevice
, const Point
& rPos
);
1517 /* tdf#119390 set parent to default window. Typically for use in advance of destroying
1518 * a floating windows which has the current focus so focus will revert to the main
1519 * document window and not the first widget in the current parent of the floating
1522 void SetParentToDefaultWindow();
1525 // Keyboard access functions
1527 /** Query the states of keyboard indicators - Caps Lock, Num Lock and
1528 Scroll Lock. Use the following mask to retrieve the state of each
1531 KeyIndicatorState::CAPS_LOCK
1532 KeyIndicatorState::NUM_LOCK
1533 KeyIndicatorState::SCROLL_LOCK
1535 KeyIndicatorState
GetIndicatorState() const;
1537 void SimulateKeyPress( sal_uInt16 nKeyCode
) const;
1539 virtual OUString
GetSurroundingText() const;
1540 virtual Selection
GetSurroundingTextSelection() const;
1541 virtual bool DeleteSurroundingText(const Selection
& rSelection
);
1543 virtual FactoryFunction
GetUITestFactory() const;
1545 virtual bool IsChart() const { return false; }
1547 void SetHelpHdl(const Link
<vcl::Window
&, bool>& rLink
);
1548 void SetMnemonicActivateHdl(const Link
<vcl::Window
&, bool>& rLink
);
1549 void SetModalHierarchyHdl(const Link
<bool, void>& rLink
);
1550 void SetDumpAsPropertyTreeHdl(const Link
<tools::JsonWriter
&, void>& rLink
);
1552 css::awt::DeviceInfo
GetDeviceInfo() const override
;
1557 #endif // INCLUDED_VCL_WINDOW_HXX
1559 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */