a45016fa18
2008/03/31 14:00:29 rt 1.2.46.1: #i87441# Change license header to LPGL v3.
128 lines
4.6 KiB
C++
128 lines
4.6 KiB
C++
/*************************************************************************
|
|
*
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* Copyright 2008 by Sun Microsystems, Inc.
|
|
*
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
|
*
|
|
* $RCSfile: shapemanager.hxx,v $
|
|
* $Revision: 1.3 $
|
|
*
|
|
* This file is part of OpenOffice.org.
|
|
*
|
|
* 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.
|
|
*
|
|
* 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).
|
|
*
|
|
* 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.
|
|
*
|
|
************************************************************************/
|
|
|
|
#ifndef INCLUDED_SLIDESHOW_SHAPEMANAGER_HXX
|
|
#define INCLUDED_SLIDESHOW_SHAPEMANAGER_HXX
|
|
|
|
#include "disposable.hxx"
|
|
#include <com/sun/star/uno/Reference.hxx>
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
namespace com { namespace sun { namespace star { namespace drawing {
|
|
class XShape;
|
|
} } } }
|
|
|
|
/* Definition of ShapeManager interface */
|
|
|
|
namespace slideshow
|
|
{
|
|
namespace internal
|
|
{
|
|
class HyperlinkArea;
|
|
class AnimatableShape;
|
|
class Shape;
|
|
|
|
/** ShapeManager interface
|
|
|
|
Implementers of this interface manage appearance and
|
|
animation of slideshow shapes.
|
|
*/
|
|
class ShapeManager : public Disposable
|
|
{
|
|
public:
|
|
/** Notify the ShapeManager that the given Shape starts an
|
|
animation now.
|
|
|
|
This method enters animation mode for the Shape. If
|
|
the shape is already in animation mode, the call is
|
|
counted, and the shape only leaves animation mode
|
|
after a corresponding number of leaveAnimationMode()
|
|
calls.
|
|
*/
|
|
virtual void enterAnimationMode( const boost::shared_ptr<AnimatableShape>& rShape ) = 0;
|
|
|
|
/** Notify the ShapeManager that the given Shape is no
|
|
longer animated.
|
|
|
|
When called a corresponding number of times as
|
|
enterAnimationMode() for a given shape, this methods
|
|
ends animation mode for the given Shape. It is illegal
|
|
to call this method more often than
|
|
enterAnimationMode().
|
|
*/
|
|
virtual void leaveAnimationMode( const boost::shared_ptr<AnimatableShape>& rShape ) = 0;
|
|
|
|
/** Notify that a shape needs an update
|
|
|
|
This method notifies the ShapeManager that a shape
|
|
update is necessary. Use this if e.g. a running
|
|
animation changed the shape appearance.
|
|
|
|
@param rShape
|
|
Shape which needs an update
|
|
*/
|
|
virtual void notifyShapeUpdate( const boost::shared_ptr<Shape>& rShape ) = 0;
|
|
|
|
/** Lookup a Shape from an XShape model object
|
|
|
|
This method looks up the internal shape map for one
|
|
representing the given XShape.
|
|
|
|
@param xShape
|
|
The XShape object, for which the representing Shape
|
|
should be looked up.
|
|
*/
|
|
virtual boost::shared_ptr<Shape> lookupShape(
|
|
::com::sun::star::uno::Reference<
|
|
::com::sun::star::drawing::XShape > const & xShape ) const = 0;
|
|
|
|
/** Register given shape as a hyperlink target
|
|
|
|
@param rArea
|
|
Hyperlink sensitive area. Will participate in
|
|
hyperlink region lookup. Must be in absolute user
|
|
space coordinates.
|
|
*/
|
|
virtual void addHyperlinkArea( const boost::shared_ptr<HyperlinkArea>& rArea ) = 0;
|
|
|
|
/** Unregister given shape as a hyperlink target
|
|
|
|
@param rArea
|
|
Hyperlink sensitive area. Will cease to participate in
|
|
hyperlink region lookup.
|
|
*/
|
|
virtual void removeHyperlinkArea( const boost::shared_ptr<HyperlinkArea>& rArea ) = 0;
|
|
};
|
|
|
|
typedef ::boost::shared_ptr< ShapeManager > ShapeManagerSharedPtr;
|
|
}
|
|
}
|
|
|
|
#endif /* INCLUDED_SLIDESHOW_SHAPEMANAGER_HXX */
|