2007/01/29 14:02:18 thb 1.7.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
		
			
				
	
	
		
			132 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*************************************************************************
 | |
|  *
 | |
|  *  OpenOffice.org - a multi-platform office productivity suite
 | |
|  *
 | |
|  *  $RCSfile: activitiesqueue.hxx,v $
 | |
|  *
 | |
|  *  $Revision: 1.8 $
 | |
|  *
 | |
|  *  last change: $Author: obo $ $Date: 2007-07-17 15:01:06 $
 | |
|  *
 | |
|  *  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_ACTIVITIESQUEUE_HXX
 | |
| #define INCLUDED_SLIDESHOW_ACTIVITIESQUEUE_HXX
 | |
| 
 | |
| #include <deque>
 | |
| 
 | |
| #include "activity.hxx"
 | |
| #include "unoviewcontainer.hxx"
 | |
| 
 | |
| #include <canvas/elapsedtime.hxx>
 | |
| 
 | |
| #include <boost/shared_ptr.hpp>
 | |
| #include <boost/utility.hpp> // for boost::noncopyable
 | |
| 
 | |
| 
 | |
| /* Definition of ActivitiesQueue class */
 | |
| 
 | |
| namespace slideshow
 | |
| {
 | |
|     namespace internal
 | |
|     {
 | |
|         /** This class handles the XSprite updates needed for
 | |
|             animations, such as moves, scales etc. You can add
 | |
|             activity objects to this class, which are called in a
 | |
|             round-robin fashion.
 | |
|         */
 | |
|         class ActivitiesQueue : private ::boost::noncopyable
 | |
|         {
 | |
|         public:
 | |
|             /** Create an ActivitiesQueue.
 | |
| 
 | |
|                 @param pPresTimer
 | |
|                 Pointer to global presentation timer. Used for
 | |
|                 adjusting and holding global presentation time.
 | |
|              */
 | |
|             ActivitiesQueue(
 | |
|                 const ::boost::shared_ptr< ::canvas::tools::ElapsedTime >&  pPresTimer );
 | |
|             ~ActivitiesQueue();
 | |
| 
 | |
|             /** Add the given activity to the queue.
 | |
|              */
 | |
|             bool addActivity( const ActivitySharedPtr& pActivity );
 | |
| 
 | |
|             /** Process the activities queue.
 | |
| 
 | |
|                 This method performs the smallest atomic processing
 | |
|                 possible on the queue (typically, this means one
 | |
|                 activity get processed).
 | |
|              */
 | |
|             void process();
 | |
| 
 | |
|             /** Call all dequeued activities' dequeued() method
 | |
|              */
 | |
|             void processDequeued();
 | |
| 
 | |
|             /** Query state of the queue
 | |
| 
 | |
|                 @return false, if queue is empty, true otherwise
 | |
|              */
 | |
|             bool isEmpty() const;
 | |
| 
 | |
|             /** Remove all pending activities from the queue.
 | |
|              */
 | |
|             void clear();
 | |
| 
 | |
|             /** Gets the queue's timer object.
 | |
|              */
 | |
|             ::boost::shared_ptr< ::canvas::tools::ElapsedTime > const &
 | |
|             getTimer() const { return mpTimer; }
 | |
| 
 | |
|         private:
 | |
|             ::boost::shared_ptr< ::canvas::tools::ElapsedTime > mpTimer;
 | |
| 
 | |
|             typedef ::std::deque< ActivitySharedPtr > ActivityQueue;
 | |
| 
 | |
|             ActivityQueue           maCurrentActivitiesWaiting;  // currently running
 | |
|                                                                  // activities, that still
 | |
|                                                                  // await processing for this
 | |
|                                                                  // round
 | |
| 
 | |
|             ActivityQueue           maCurrentActivitiesReinsert;    // currently running
 | |
|                                                                       // activities, that are
 | |
|                                                                       // already processed for
 | |
|                                                                       // this round, and wants
 | |
|                                                                     // to be reinserted next
 | |
|                                                                     // round
 | |
| 
 | |
|             ActivityQueue           maDequeuedActivities; // This list collects all activities which did not request
 | |
|                                                           // a reinsertion. After the screen update has been
 | |
|                                                           // performed, those are notified via dequeued(). This
 | |
|                                                           // facilitates cleanup actions taking place _after_ the
 | |
|                                                           // current frame has been displayed.
 | |
|         };
 | |
| 
 | |
|     }
 | |
| }
 | |
| #endif /* INCLUDED_SLIDESHOW_ACTIVITIESQUEUE_HXX */
 |