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 _SV_SALSYS_HXX
21 #define _SV_SALSYS_HXX
23 #include <tools/gen.hxx>
24 #include <vcl/dllapi.h>
31 /* Button combinations for ShowNativeMessageBox
33 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_OK
= 0;
34 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_OK_CANCEL
= 1;
35 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_ABORT_RETRY_IGNORE
= 2;
36 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_YES_NO_CANCEL
= 3;
37 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_YES_NO
= 4;
38 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_RETRY_CANCEL
= 5;
40 /* Button identifier for ShowNativeMessageBox
42 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_OK
= 1;
43 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_CANCEL
= 2;
44 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_ABORT
= 3;
45 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_RETRY
= 4;
46 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_IGNORE
= 5;
47 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_YES
= 6;
48 const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_NO
= 7;
54 class VCL_PLUGIN_PUBLIC SalSystem
60 // get info about the display
62 /* Gets the number of active screens attached to the display
64 @returns the number of active screens
66 virtual unsigned int GetDisplayScreenCount() = 0;
67 /* Queries whether multiple screens are part of one bigger display
69 @returns true if screens form one big display
70 false if screens are distinct and windows cannot
71 be moved between, or span multiple screens
73 virtual bool IsUnifiedDisplay() { return true; }
74 /* Queries the default screen number. The default screen is the
75 screen on which windows will appear if no special positioning
78 @returns the default screen number
80 virtual unsigned int GetDisplayBuiltInScreen() { return 0; }
81 /* Gets relative position and size of the screens attached to the display
84 The screen number to be queried
86 @returns position: (0,0) in case of IsMultiscreen() == true
87 else position relative to whole display
88 size: size of the screen
90 virtual Rectangle
GetDisplayScreenPosSizePixel( unsigned int nScreen
) = 0;
91 /* Gets position and size of the work area of a screen attached to the display
94 The screen number to be queried
96 @returns position and size relative to the scree
98 virtual Rectangle
GetDisplayScreenWorkAreaPosSizePixel( unsigned int nScreen
) = 0;
99 /* Gets the name of a screen
102 The screen number to be queried
104 @returns the name of the screen
106 virtual rtl::OUString
GetDisplayScreenName( unsigned int nScreen
) = 0;
108 /* Shows a native message box with the specified title, message and button
112 The title to be shown by the dialog box.
115 The message to be shown by the dialog box.
117 @param nButtonCombination
118 Specify which button combination the message box should display.
119 See button combinations above.
121 @param nDefaultButton
122 Specifies which button has the focus initially.
123 See button identifiers above.
124 The effect of specifying a button that doesn't belong
125 to the specified button combination is undefined.
128 If false, assume initialization of the application failed early and do
129 not try to access any resources.
131 @returns the identifier of the button that was pressed by the user.
132 See button identifier above. If the function fails the
135 virtual int ShowNativeMessageBox( const rtl::OUString
& rTitle
,
136 const rtl::OUString
& rMessage
,
137 int nButtonCombination
,
139 bool bUseResources
) = 0;
142 SalSystem
* ImplGetSalSystem();
144 #endif // _SV_SALSYS_HXX
146 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */