INTEGRATION: CWS impress36 (1.1.2); FILE ADDED

2005/02/24 12:26:18 af 1.1.2.1: #i43335# Moved here from ../toolpanel.
This commit is contained in:
Kurt Zenker 2005-03-18 15:48:55 +00:00
parent 3ca8b6b48c
commit 05eff632a0

View file

@ -0,0 +1,136 @@
/*************************************************************************
*
* $RCSfile: ILayoutableWindow.hxx,v $
*
* $Revision: 1.2 $
*
* last change: $Author: kz $ $Date: 2005-03-18 16:48:55 $
*
* 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_TOOLPANEL_I_LAYOUTABLE_WINDOW_HXX
#define SD_TOOLPANEL_I_LAYOUTABLE_WINDOW_HXX
#include <tools/gen.hxx>
#include <sal/types.h>
class Window;
namespace sd { namespace toolpanel {
class ILayouter
{
public:
/** This method is called by layoutable controls when they have to be
resized.
*/
virtual void RequestResize (void) = 0;
};
/** This interface has to be implemented by windows that want to be
layouted by a ToolPanel, SubToolPanel, or ScrollablePanel object.
*/
class ILayoutableWindow
{
public:
virtual ~ILayoutableWindow (void) {};
/** Return the preferred size without constraints on either the
height or the width.
The size the window will later be set to may but does not have
to be equal to this size.
*/
virtual Size GetPreferredSize (void) = 0;
/** Return the preferred width with the constraint, that the
window will be set to the given height.
The width the window will later be set to may but does not have
to be equal to this width.
*/
virtual sal_Int32 GetPreferredWidth (sal_Int32 nHeight) = 0;
/** Return the preferred height with the constraint, that the
window will be set to the given width.
The height the window will later be set to may but does not have
to be equal to this height.
*/
virtual sal_Int32 GetPreferredHeight (sal_Int32 nWidth) = 0;
/** Return wether the window is generally resizable. When used by
a VerticalLayouter then the width will always be resized and
the return value of this method determines whether the height
may be modified as well.
*/
virtual bool IsResizable (void) = 0;
/** Return the window so that its size and position can be set.
@return
Returns the window which is layouted or NULL to indicate
that the object is in an invalid state.
*/
virtual ::Window* GetWindow (void) = 0;
/** Return the minimal width of the window.
*/
virtual sal_Int32 GetMinimumWidth (void) = 0;
};
} } // end of namespace ::sd::toolpanel
#endif