/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #ifndef _SV_SALSYS_HXX #define _SV_SALSYS_HXX #include #include #include /* 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 - // ------------- class VCL_PLUGIN_PUBLIC SalSystem { 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; /* Queries whether multiple screens are truly separate @returns true if screens are distinct and windows cannot be moved between them or span multiple of them false if screens form up one big display */ virtual bool IsMultiDisplay() = 0; /* 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 */ virtual unsigned int GetDefaultDisplayNumber() = 0; /* 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 */ virtual Rectangle GetDisplayWorkAreaPosSizePixel( unsigned int nScreen ) = 0; /* Gets the name of a screen @param nScreen The screen number to be queried @returns the name of the screen */ virtual rtl::OUString GetScreenName( unsigned int nScreen ) = 0; /* 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. */ virtual int ShowNativeMessageBox( const String& rTitle, const String& rMessage, int nButtonCombination, int nDefaultButton) = 0; }; SalSystem* ImplGetSalSystem(); #endif // _SV_SALSYS_HXX