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_INC_SALFRAME_HXX
21 #define INCLUDED_VCL_INC_SALFRAME_HXX
24 #include "salwtype.hxx"
25 #include "salgeom.hxx"
27 #include <vcl/help.hxx>
28 #include <o3tl/typed_flags_set.hxx>
30 #include <vcl/window.hxx>
31 // complete vcl::Window for SalFrame::CallCallback under -fsanitize=function
38 namespace vcl
{ class WindowData
; }
39 struct SalInputContext
;
43 enum class SalFrameToTop
{
45 RestoreWhenMin
= 0x01,
46 ForegroundTask
= 0x02,
51 template<> struct typed_flags
<SalFrameToTop
> : is_typed_flags
<SalFrameToTop
, 0x0f> {};
54 namespace vcl
{ class KeyCode
; }
61 enum class FloatWinPopupFlags
;
64 enum class SalFrameStyleFlags
68 MOVEABLE
= 0x00000002,
69 SIZEABLE
= 0x00000004,
70 CLOSEABLE
= 0x00000008,
71 // no shadow effect on Windows XP
72 NOSHADOW
= 0x00000010,
73 // indicate tooltip windows, so they can always be topmost
75 // windows without windowmanager decoration, this typically only applies to floating windows
76 OWNERDRAWDECORATION
= 0x00000040,
79 // the window containing the intro bitmap, aka splashscreen
81 // tdf#144624: don't set icon
83 // system child window inside another SalFrame
84 SYSTEMCHILD
= 0x08000000,
85 // plugged system child window
89 // toolwindows should be painted with a smaller decoration
90 TOOLWINDOW
= 0x40000000,
94 template<> struct typed_flags
<SalFrameStyleFlags
> : is_typed_flags
<SalFrameStyleFlags
, 0x798001ff> {};
97 // Extended frame style (sal equivalent to extended WinBits)
98 typedef sal_uInt64 SalExtStyle
;
99 #define SAL_FRAME_EXT_STYLE_DOCUMENT SalExtStyle(0x00000001)
100 #define SAL_FRAME_EXT_STYLE_DOCMODIFIED SalExtStyle(0x00000002)
102 // Flags for SetPosSize
103 #define SAL_FRAME_POSSIZE_X (sal_uInt16(0x0001))
104 #define SAL_FRAME_POSSIZE_Y (sal_uInt16(0x0002))
105 #define SAL_FRAME_POSSIZE_WIDTH (sal_uInt16(0x0004))
106 #define SAL_FRAME_POSSIZE_HEIGHT (sal_uInt16(0x0008))
108 struct SystemParentData
;
111 /// A SalFrame is a system window (e.g. an X11 window).
112 class VCL_PLUGIN_PUBLIC SalFrame
113 : public vcl::DeletionNotifier
114 , public SalGeometryProvider
117 // the VCL window corresponding to this frame
118 VclPtr
<vcl::Window
> m_pWindow
;
119 SALFRAMEPROC m_pProc
;
120 Link
<bool, void> m_aModalHierarchyHdl
;
122 mutable std::unique_ptr
<weld::Window
> m_xFrameWeld
;
125 virtual ~SalFrame() override
;
127 SalFrameGeometry maGeometry
; ///< absolute, unmirrored values
129 // SalGeometryProvider
130 virtual tools::Long
GetWidth() const override
{ return maGeometry
.width(); }
131 virtual tools::Long
GetHeight() const override
{ return maGeometry
.height(); }
132 virtual bool IsOffScreen() const override
{ return false; }
134 // SalGraphics or NULL, but two Graphics for all SalFrames
136 virtual SalGraphics
* AcquireGraphics() = 0;
137 virtual void ReleaseGraphics( SalGraphics
* pGraphics
) = 0;
139 // Event must be destroyed, when Frame is destroyed
140 // When Event is called, SalInstance::Yield() must be returned
141 virtual bool PostEvent(std::unique_ptr
<ImplSVEvent
> pData
) = 0;
143 virtual void SetTitle( const OUString
& rTitle
) = 0;
144 virtual void SetIcon( sal_uInt16 nIcon
) = 0;
145 virtual void SetRepresentedURL( const OUString
& );
146 virtual void SetMenu( SalMenu
*pSalMenu
) = 0;
148 virtual void SetExtendedFrameStyle( SalExtStyle nExtStyle
) = 0;
150 // Before the window is visible, a resize event
151 // must be sent with the correct size
152 virtual void Show( bool bVisible
, bool bNoActivate
= false ) = 0;
154 // Set ClientSize and Center the Window to the desktop
155 // and send/post a resize message
156 virtual void SetMinClientSize( tools::Long nWidth
, tools::Long nHeight
) = 0;
157 virtual void SetMaxClientSize( tools::Long nWidth
, tools::Long nHeight
) = 0;
158 virtual void SetPosSize( tools::Long nX
, tools::Long nY
, tools::Long nWidth
, tools::Long nHeight
, sal_uInt16 nFlags
) = 0;
159 static OUString
DumpSetPosSize(tools::Long nX
, tools::Long nY
, tools::Long nWidth
, tools::Long nHeight
, sal_uInt16 nFlags
);
160 virtual void GetClientSize( tools::Long
& rWidth
, tools::Long
& rHeight
) = 0;
161 virtual void GetWorkArea( tools::Rectangle
& rRect
) = 0;
162 virtual SalFrame
* GetParent() const = 0;
163 // Note: x will be mirrored at parent if UI mirroring is active
164 SalFrameGeometry
GetGeometry() const;
165 const SalFrameGeometry
& GetUnmirroredGeometry() const { return maGeometry
; }
167 virtual void SetWindowState(const vcl::WindowData
*) = 0;
168 // return the absolute, unmirrored system frame state
169 // if this returns false the structure is uninitialised
171 virtual bool GetWindowState(vcl::WindowData
*) = 0;
172 virtual void ShowFullScreen( bool bFullScreen
, sal_Int32 nDisplay
) = 0;
173 virtual void PositionByToolkit( const tools::Rectangle
&, FloatWinPopupFlags
) {};
175 // Enable/Disable ScreenSaver, SystemAgents, ...
176 virtual void StartPresentation( bool bStart
) = 0;
177 // Show Window over all other Windows
178 virtual void SetAlwaysOnTop( bool bOnTop
) = 0;
180 // Window to top and grab focus
181 virtual void ToTop( SalFrameToTop nFlags
) = 0;
183 // grab focus to the main widget, can be no-op if the vclplug only uses one widget
184 virtual void GrabFocus() {}
186 // this function can call with the same
188 virtual void SetPointer( PointerStyle ePointerStyle
) = 0;
189 virtual void CaptureMouse( bool bMouse
) = 0;
190 virtual void SetPointerPos( tools::Long nX
, tools::Long nY
) = 0;
192 // flush output buffer
193 virtual void Flush() = 0;
194 virtual void Flush( const tools::Rectangle
& );
196 virtual void SetInputContext( SalInputContext
* pContext
) = 0;
197 virtual void EndExtTextInput( EndExtTextInputFlags nFlags
) = 0;
199 virtual OUString
GetKeyName( sal_uInt16 nKeyCode
) = 0;
201 // returns in 'rKeyCode' the single keycode that translates to the given unicode when using a keyboard layout of language 'aLangType'
202 // returns false if no mapping exists or function not supported
203 // this is required for advanced menu support
204 virtual bool MapUnicodeToKeyCode( sal_Unicode aUnicode
, LanguageType aLangType
, vcl::KeyCode
& rKeyCode
) = 0;
206 // returns the input language used for the last key stroke
207 // may be LANGUAGE_DONTKNOW if not supported by the OS
208 virtual LanguageType
GetInputLanguage() = 0;
210 virtual void UpdateSettings( AllSettings
& rSettings
) = 0;
212 virtual void Beep() = 0;
214 // returns system data (most prominent: window handle)
215 virtual const SystemEnvData
*
216 GetSystemData() const = 0;
218 // tdf#139609 SystemEnvData::GetWindowHandle() calls this to on-demand fill the aWindow
219 // member of SystemEnvData for backends that want to defer doing that
220 virtual void ResolveWindowHandle(SystemEnvData
& /*rData*/) const {};
222 // get current modifier, button mask and mouse position
223 struct SalPointerState
226 Point maPos
; // in frame coordinates
229 virtual SalPointerState
GetPointerState() = 0;
231 virtual KeyIndicatorState
GetIndicatorState() = 0;
233 virtual void SimulateKeyPress( sal_uInt16 nKeyCode
) = 0;
235 // set new parent window
236 virtual void SetParent( SalFrame
* pNewParent
) = 0;
237 // reparent window to act as a plugin; implementation
238 // may choose to use a new system window internally
239 // return false to indicate failure
240 virtual void SetPluginParent( SystemParentData
* pNewParent
) = 0;
242 // move the frame to a new screen
243 virtual void SetScreenNumber( unsigned int nScreen
) = 0;
245 virtual void SetApplicationID( const OUString
&rApplicationID
) = 0;
247 // shaped system windows
248 // set clip region to none (-> rectangular windows, normal state)
249 virtual void ResetClipRegion() = 0;
250 // start setting the clipregion consisting of nRects rectangles
251 virtual void BeginSetClipRegion( sal_uInt32 nRects
) = 0;
252 // add a rectangle to the clip region
253 virtual void UnionClipRegion( tools::Long nX
, tools::Long nY
, tools::Long nWidth
, tools::Long nHeight
) = 0;
254 // done setting up the clipregion
255 virtual void EndSetClipRegion() = 0;
257 virtual void SetModal(bool /*bModal*/)
261 virtual bool GetModal() const
266 // return true to indicate tooltips are shown natively, false otherwise
267 virtual bool ShowTooltip(const OUString
& /*rHelpText*/, const tools::Rectangle
& /*rHelpArea*/)
272 // return !0 to indicate popovers are shown natively, 0 otherwise
273 virtual void* ShowPopover(const OUString
& /*rHelpText*/, vcl::Window
* /*pParent*/, const tools::Rectangle
& /*rHelpArea*/, QuickHelpFlags
/*nFlags*/)
278 // return true to indicate popovers are shown natively, false otherwise
279 virtual bool UpdatePopover(void* /*nId*/, const OUString
& /*rHelpText*/, vcl::Window
* /*pParent*/, const tools::Rectangle
& /*rHelpArea*/)
284 // return true to indicate popovers are shown natively, false otherwise
285 virtual bool HidePopover(void* /*nId*/)
290 virtual weld::Window
* GetFrameWeld() const;
292 // Callbacks (independent part in vcl/source/window/winproc.cxx)
293 // for default message handling return 0
294 void SetCallback( vcl::Window
* pWindow
, SALFRAMEPROC pProc
);
296 // returns the instance set
297 vcl::Window
* GetWindow() const { return m_pWindow
; }
299 void SetModalHierarchyHdl(const Link
<bool, void>& rLink
) { m_aModalHierarchyHdl
= rLink
; }
300 void NotifyModalHierarchy(bool bModal
) { m_aModalHierarchyHdl
.Call(bModal
); }
302 virtual void UpdateDarkMode() {}
304 // Call the callback set; this sometimes necessary for implementation classes
305 // that should not know more than necessary about the SalFrame implementation
306 // (e.g. input methods, printer update handlers).
307 bool CallCallback( SalEvent nEvent
, const void* pEvent
) const
308 { return m_pProc
&& m_pProc( m_pWindow
, nEvent
, pEvent
); }
310 // Helper method for input method handling: Calculate cursor index in (UTF-16) OUString,
311 // starting at nCursorIndex, moving number of characters (not UTF-16 codepoints) specified
312 // in nOffset, nChars.
313 static Selection
CalcDeleteSurroundingSelection(const OUString
& rSurroundingText
,
314 sal_Int32 nCursorIndex
, int nOffset
, int nChars
);
321 #endif // INCLUDED_VCL_INC_SALFRAME_HXX
323 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */