2007/01/29 14:02:28 thb 1.5.12.1: Issue number: #i37778# Larger slideshow refactoring. Wrote design and coding style manifest, and adapted the code to actually conform to this. In detail: - cleaned up ownership/disposable/weak_ptr story. removed hacks and explicit Disposable implementations, where workaround were available - removed object mutices, where superfluous - reworked EventMultiplexer (using templatized listener class now), added more events. EventMultiplexer now serves as a true blackboard - reworked directory structure: disjunct parts are now physically separated into directories, instantiation happens via factories & abstract interfaces - added CursorManager, to make setting mouse cursor less hackish - reworked DrawShape, to implement SeparateListener pattern - reworked IntrinsicAnimationActivity, to avoid cyclic references - modified hyperlink & shape cursor handling to communicate via EventMultiplexer - renamed & cleaned up files (presentation.cxx now named slideshowimpl.cxx, etc.) - added first version of the z-order fix to layer/layermanager - cleaned up include guards and include syntax
		
			
				
	
	
		
			159 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*************************************************************************
 | |
|  *
 | |
|  *  OpenOffice.org - a multi-platform office productivity suite
 | |
|  *
 | |
|  *  $RCSfile: shapesubset.hxx,v $
 | |
|  *
 | |
|  *  $Revision: 1.6 $
 | |
|  *
 | |
|  *  last change: $Author: obo $ $Date: 2007-07-17 15:14:53 $
 | |
|  *
 | |
|  *  The Contents of this file are made available subject to
 | |
|  *  the terms of GNU Lesser General Public License Version 2.1.
 | |
|  *
 | |
|  *
 | |
|  *    GNU Lesser General Public License Version 2.1
 | |
|  *    =============================================
 | |
|  *    Copyright 2005 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
 | |
|  *
 | |
|  ************************************************************************/
 | |
| 
 | |
| #ifndef INCLUDED_SLIDESHOW_SHAPESUBSET_HXX
 | |
| #define INCLUDED_SLIDESHOW_SHAPESUBSET_HXX
 | |
| 
 | |
| #include "attributableshape.hxx"
 | |
| #include "subsettableshapemanager.hxx"
 | |
| #include "doctreenode.hxx"
 | |
| 
 | |
| #include <boost/shared_ptr.hpp>
 | |
| 
 | |
| namespace slideshow
 | |
| {
 | |
|     namespace internal
 | |
|     {
 | |
|         class ShapeSubset;
 | |
|         typedef ::boost::shared_ptr< ShapeSubset > ShapeSubsetSharedPtr;
 | |
| 
 | |
|         /* Definition of ShapeSubset class */
 | |
| 
 | |
|         /** Subset RAII wrapper for shapes.
 | |
| 
 | |
|             This class wraps the plain Shape with a wrapper for subset
 | |
|             functionality. Subsetting can be turned on and off. Note
 | |
|             that the reason to have shape subsetting RAII implemented
 | |
|             separately (i.e. not within the DrawShape) was that
 | |
|             subsetting (and de-subsetting) needs the
 | |
|             SubsettableShapeManager. And holding that at the DrawShape
 | |
|             creates one heck of a circular reference.
 | |
|          */
 | |
|         class ShapeSubset
 | |
|         {
 | |
|         public:
 | |
|             /** Create a subset directly from a Shape.
 | |
| 
 | |
|                 @param rOriginalShape
 | |
|                 Original shape to subset
 | |
| 
 | |
|                 @param rTreeNode
 | |
|                 Subset this object should represent
 | |
| 
 | |
|                 @param rShapeManager
 | |
|                 Manager object, where subsets are
 | |
|                 registered/unregistered
 | |
|              */
 | |
|             ShapeSubset( const AttributableShapeSharedPtr&       rOriginalShape,
 | |
|                          const DocTreeNode&                      rTreeNode,
 | |
|                          const SubsettableShapeManagerSharedPtr& rSubsetManager );
 | |
| 
 | |
|             /** Create a subset from another subset.
 | |
| 
 | |
|                 Note: if you want this subset to subtract from the
 | |
|                 passed subset reference (and not from the original,
 | |
|                 unsubsetted shape), the passed subset must be enabled
 | |
|                 (enableSubsetShape() must have been called)
 | |
| 
 | |
|                 @param rOriginalSubset
 | |
|                 Original subset, which to subset again.
 | |
| 
 | |
|                 @param rTreeNode
 | |
|                 Subset of the original subset
 | |
|              */
 | |
|             ShapeSubset( const ShapeSubsetSharedPtr&        rOriginalSubset,
 | |
|                          const DocTreeNode&                 rTreeNode );
 | |
| 
 | |
|             /** Create full set for the given shape.
 | |
| 
 | |
|                 @param rOriginalShape
 | |
|                 Original shape, which will be represented as a whole
 | |
|                 by this object
 | |
|              */
 | |
|             ShapeSubset( const AttributableShapeSharedPtr&       rOriginalShape,
 | |
|                          const SubsettableShapeManagerSharedPtr& rShapeManager );
 | |
| 
 | |
|             ~ShapeSubset();
 | |
| 
 | |
|             /** Get the actual subset shape.
 | |
| 
 | |
|                 If the subset is currently revoked, this method
 | |
|                 returns the original shape.
 | |
|              */
 | |
|             AttributableShapeSharedPtr  getSubsetShape() const;
 | |
| 
 | |
|             /** Enable the subset shape.
 | |
| 
 | |
|                 This method enables the subset. That means, on
 | |
|                 successful completion of this method, the original
 | |
|                 shape will cease to show the subset range, and
 | |
|                 getSubsetShape() will return a valid shape.
 | |
| 
 | |
|                 @return true, if subsetting was successfully enabled.
 | |
|              */
 | |
|             bool            enableSubsetShape();
 | |
| 
 | |
|             /** Disable the subset shape.
 | |
| 
 | |
|                 This method revokes the subset from the original
 | |
|                 shape. That means, the original shape will again show
 | |
|                 the hidden range.
 | |
|              */
 | |
|             void            disableSubsetShape();
 | |
| 
 | |
|             /** Query whether this subset actually is none, but
 | |
|                 contains the whole original shape's content
 | |
|              */
 | |
|             bool isFullSet() const;
 | |
| 
 | |
|             /** Query subset this object represents
 | |
|              */
 | |
|             DocTreeNode getSubset() const;
 | |
| 
 | |
|         private:
 | |
|             // default copy/assignment are okay
 | |
|             //ShapeSubset(const ShapeSubset&);
 | |
|             //ShapeSubset& operator=( const ShapeSubset& );
 | |
| 
 | |
|             AttributableShapeSharedPtr       mpOriginalShape;
 | |
|             AttributableShapeSharedPtr       mpSubsetShape;
 | |
|             DocTreeNode                      maTreeNode;
 | |
|             SubsettableShapeManagerSharedPtr mpShapeManager;
 | |
|         };
 | |
|     }
 | |
| }
 | |
| 
 | |
| #endif /* INCLUDED_SLIDESHOW_SHAPESUBSET_HXX */
 |