2010-10-14 01:27:31 -05:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2007-04-11 12:09:07 -05:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-11 01:57:38 -05:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2007-04-11 12:09:07 -05:00
|
|
|
*
|
2010-02-12 08:01:35 -06:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2007-04-11 12:09:07 -05:00
|
|
|
*
|
2008-04-11 01:57:38 -05:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2007-04-11 12:09:07 -05:00
|
|
|
*
|
2008-04-11 01:57:38 -05:00
|
|
|
* This file is part of OpenOffice.org.
|
2007-04-11 12:09:07 -05:00
|
|
|
*
|
2008-04-11 01:57:38 -05:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2007-04-11 12:09:07 -05:00
|
|
|
*
|
2008-04-11 01:57:38 -05:00
|
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2007-04-11 12:09:07 -05:00
|
|
|
*
|
2008-04-11 01:57:38 -05:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2007-04-11 12:09:07 -05:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _SV_SALSYS_HXX
|
|
|
|
#define _SV_SALSYS_HXX
|
|
|
|
|
|
|
|
#include <tools/gen.hxx>
|
|
|
|
#include <vcl/dllapi.h>
|
|
|
|
|
2011-11-21 02:00:21 -06:00
|
|
|
namespace rtl
|
|
|
|
{
|
|
|
|
class OUString;
|
|
|
|
}
|
2007-04-11 12:09:07 -05:00
|
|
|
|
|
|
|
/* Button combinations for ShowNativeMessageBox
|
|
|
|
*/
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_OK = 0;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_OK_CANCEL = 1;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_ABORT_RETRY_IGNORE = 2;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_YES_NO_CANCEL = 3;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_YES_NO = 4;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTNCOMBI_RETRY_CANCEL = 5;
|
|
|
|
|
|
|
|
/* Button identifier for ShowNativeMessageBox
|
|
|
|
*/
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_OK = 1;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_CANCEL = 2;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_ABORT = 3;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_RETRY = 4;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_IGNORE = 5;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_YES = 6;
|
|
|
|
const int SALSYSTEM_SHOWNATIVEMSGBOX_BTN_NO = 7;
|
|
|
|
|
|
|
|
|
|
|
|
// -------------
|
|
|
|
// - SalSystem -
|
|
|
|
// -------------
|
2010-12-08 06:53:30 -06:00
|
|
|
class VCL_PLUGIN_PUBLIC SalSystem
|
2007-04-11 12:09:07 -05:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
SalSystem() {}
|
|
|
|
virtual ~SalSystem();
|
|
|
|
|
|
|
|
// get info about the display
|
|
|
|
|
|
|
|
/* Gets the number of active screens attached to the display
|
|
|
|
|
|
|
|
@returns the number of active screens
|
|
|
|
*/
|
|
|
|
virtual unsigned int GetDisplayScreenCount() = 0;
|
2012-01-14 04:31:40 -06:00
|
|
|
/* Queries whether multiple screens are part of one bigger display
|
2007-04-11 12:09:07 -05:00
|
|
|
|
2012-01-15 06:23:11 -06:00
|
|
|
@returns true if screens form one big display
|
2012-01-14 04:31:40 -06:00
|
|
|
false if screens are distinct and windows cannot
|
|
|
|
be moved between, or span multiple screens
|
2007-04-11 12:09:07 -05:00
|
|
|
*/
|
2012-01-14 04:31:40 -06:00
|
|
|
virtual bool IsUnifiedDisplay() { return true; }
|
2007-04-11 12:09:07 -05:00
|
|
|
/* Queries the default screen number. The default screen is the
|
|
|
|
screen on which windows will appear if no special positioning
|
|
|
|
is made.
|
|
|
|
|
|
|
|
@returns the default screen number
|
|
|
|
*/
|
2012-05-30 04:15:27 -05:00
|
|
|
virtual unsigned int GetDisplayBuiltInScreen() { return 0; }
|
2007-04-11 12:09:07 -05:00
|
|
|
/* Gets relative position and size of the screens attached to the display
|
|
|
|
|
|
|
|
@param nScreen
|
|
|
|
The screen number to be queried
|
|
|
|
|
|
|
|
@returns position: (0,0) in case of IsMultiscreen() == true
|
|
|
|
else position relative to whole display
|
|
|
|
size: size of the screen
|
|
|
|
*/
|
|
|
|
virtual Rectangle GetDisplayScreenPosSizePixel( unsigned int nScreen ) = 0;
|
|
|
|
/* Gets position and size of the work area of a screen attached to the display
|
|
|
|
|
|
|
|
@param nScreen
|
|
|
|
The screen number to be queried
|
|
|
|
|
|
|
|
@returns position and size relative to the scree
|
|
|
|
*/
|
2012-01-14 05:28:22 -06:00
|
|
|
virtual Rectangle GetDisplayScreenWorkAreaPosSizePixel( unsigned int nScreen ) = 0;
|
2007-04-11 12:09:07 -05:00
|
|
|
/* Gets the name of a screen
|
|
|
|
|
|
|
|
@param nScreen
|
|
|
|
The screen number to be queried
|
|
|
|
|
|
|
|
@returns the name of the screen
|
|
|
|
*/
|
2012-01-14 05:28:22 -06:00
|
|
|
virtual rtl::OUString GetDisplayScreenName( unsigned int nScreen ) = 0;
|
2007-04-11 12:09:07 -05:00
|
|
|
|
|
|
|
/* Shows a native message box with the specified title, message and button
|
|
|
|
combination.
|
|
|
|
|
|
|
|
@param rTitle
|
|
|
|
The title to be shown by the dialog box.
|
|
|
|
|
|
|
|
@param rMessage
|
|
|
|
The message to be shown by the dialog box.
|
|
|
|
|
|
|
|
@param nButtonCombination
|
|
|
|
Specify which button combination the message box should display.
|
|
|
|
See button combinations above.
|
|
|
|
|
|
|
|
@param nDefaultButton
|
|
|
|
Specifies which button has the focus initially.
|
|
|
|
See button identifiers above.
|
|
|
|
The effect of specifying a button that doesn't belong
|
|
|
|
to the specified button combination is undefined.
|
|
|
|
|
|
|
|
@returns the identifier of the button that was pressed by the user.
|
|
|
|
See button identifier above. If the function fails the
|
|
|
|
return value is 0.
|
|
|
|
*/
|
2011-11-21 02:00:21 -06:00
|
|
|
virtual int ShowNativeMessageBox( const rtl::OUString& rTitle,
|
|
|
|
const rtl::OUString& rMessage,
|
2007-04-11 12:09:07 -05:00
|
|
|
int nButtonCombination,
|
|
|
|
int nDefaultButton) = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
SalSystem* ImplGetSalSystem();
|
|
|
|
|
|
|
|
#endif // _SV_SALSYS_HXX
|
2010-10-14 01:27:31 -05:00
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|