office-gobmx/sd/source/ui/inc/PaneDockingWindow.hxx
Oliver Bolte 4ff0f7c3d0 INTEGRATION: CWS impress52 (1.6.110); FILE MERGED
2005/04/27 14:11:34 af 1.6.110.1: #i48263# Added WindowEventListener() link method.
2005-05-02 12:18:38 +00:00

163 lines
5.6 KiB
C++

/*************************************************************************
*
* $RCSfile: PaneDockingWindow.hxx,v $
*
* $Revision: 1.7 $
*
* last change: $Author: obo $ $Date: 2005-05-02 13:18:38 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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 for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (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.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#ifndef SD_PANE_DOCKING_WINDOW_HXX
#define SD_PANE_DOCKING_WINDOW_HXX
#ifndef _SFXDOCKWIN_HXX
#include <sfx2/dockwin.hxx>
#endif
#include <sfx2/viewfrm.hxx>
#include "PaneManager.hxx"
class ToolBox;
namespace sd {
class PaneDockingWindow
: public SfxDockingWindow
{
public:
/** Create a new docking window that will be displayed in the specified
pane.
The constructor will determine the ViewShellBase via the given
bindings and tell its PaneManager about the new window. It will ask
the PaneManager for a window title.
@param pBindings
Used, among others, to determine the ViewShellBase and
PaneManager that manage the new docking window.
@param pChildWindow
This child window is the logical container for the new docking
window.
@param pParent
The parent window of the new docking window.
@param rResId
The resource is used to determine initial size and attributes.
@param ePane
The pane in which to show the docking window.
*/
PaneDockingWindow (
SfxBindings *pBindings,
SfxChildWindow *pChildWindow,
::Window* pParent,
const ResId& rResId,
PaneManager::PaneType ePane);
virtual ~PaneDockingWindow (void);
virtual void Paint (const Rectangle& rRectangle);
virtual void Resize (void);
virtual long Notify( NotifyEvent& rNEvt );
virtual void StateChanged( StateChangedType nType );
virtual void DataChanged( const DataChangedEvent& rDCEvt );
/** Initializing the title tool box either creates a new title tool box
or clears all items from an existing one. A closer is added as only
item.
*/
void InitializeTitleToolBox (void);
/** Add a top down menu to the title bar or rather the top-level menu
entry. The given callback is called when the menu is clicked and it
is the task of the callback to show the menu.
@return
The id of the new menu is returned. It can be compared by the
callback to the value of GetCurItemId() when called at the given
tool box.
*/
USHORT AddMenu (const String& rsMenuName, ULONG nHelpId, const Link& rCallback);
/** Set the title of the docking window to the given string. Use this
method when the title is not yet known at the time of construction
or can not be passed to the constructor.
*/
void SetTitle (const String& rsTitle);
private:
/** The pane which is represented by the docking window.
*/
PaneManager::PaneType mePane;
/** Title that is shown at the top of the docking window.
*/
String msTitle;
/** The tool box that is displayed in the window title area contains
menus and the closer button.
*/
::std::auto_ptr<ToolBox> mpTitleToolBox;
/** The border that is painted arround the inner window. The bevel
shadow lines are part of the border, so where the border is 0 no
such line is painted.
*/
SvBorder maBorder;
sal_uInt16 mnChildWindowId;
DECL_LINK(ToolboxSelectHandler, ToolBox*);
DECL_LINK(WindowEventListener, VclSimpleEvent*);
};
} // end of namespace ::sd
#endif