| 
									
										
										
										
											2010-10-27 12:53:26 +01:00
										 |  |  | /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:24:29 +00:00
										 |  |  |  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-02-12 15:01:35 +01:00
										 |  |  |  * Copyright 2000, 2010 Oracle and/or its affiliates. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:24:29 +00:00
										 |  |  |  * OpenOffice.org - a multi-platform office productivity suite | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:24:29 +00:00
										 |  |  |  * This file is part of OpenOffice.org. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:24:29 +00:00
										 |  |  |  * 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. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:24:29 +00:00
										 |  |  |  * 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). | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:24:29 +00:00
										 |  |  |  * 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. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  ************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-17 14:06:47 +00:00
										 |  |  | #ifndef INCLUDED_SLIDESHOW_EVENTQUEUE_HXX
 | 
					
						
							|  |  |  | #define INCLUDED_SLIDESHOW_EVENTQUEUE_HXX
 | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <canvas/elapsedtime.hxx>
 | 
					
						
							| 
									
										
										
										
											2007-07-17 14:06:47 +00:00
										 |  |  | #include <osl/mutex.hxx>
 | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-17 14:06:47 +00:00
										 |  |  | #include "event.hxx"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/noncopyable.hpp>
 | 
					
						
							|  |  |  | #include <functional>
 | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | #include <queue>
 | 
					
						
							| 
									
										
										
										
											2006-07-26 06:39:44 +00:00
										 |  |  | #include <vector>
 | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Definition of ActivitiesQueue class */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-13 14:56:39 +00:00
										 |  |  | namespace slideshow | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     namespace internal | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** This class handles events in a presentation. Events are
 | 
					
						
							|  |  |  |             time instants where e.g. effects start. | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2005-03-10 12:54:47 +00:00
										 |  |  |         class EventQueue : private ::boost::noncopyable | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |         { | 
					
						
							|  |  |  |         public: | 
					
						
							| 
									
										
										
										
											2005-03-10 12:54:47 +00:00
										 |  |  |             EventQueue( | 
					
						
							|  |  |  |                 ::boost::shared_ptr< ::canvas::tools::ElapsedTime > | 
					
						
							|  |  |  |                 const & pPresTimer ); | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             ~EventQueue(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /** Add the given event to the queue. The event is fired
 | 
					
						
							|  |  |  |                 at, or shortly after, its Event::getActivationTime instant. | 
					
						
							|  |  |  |              */ | 
					
						
							|  |  |  |             bool addEvent( const EventSharedPtr& event ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-26 06:39:44 +00:00
										 |  |  |             /** Add the given event to the queue. The event is fired
 | 
					
						
							|  |  |  |                 at, or shortly after, its Event::getActivationTime instant. | 
					
						
							|  |  |  |                 The difference to addEvent() is that events added during | 
					
						
							|  |  |  |                 process() are postponed to next process(). | 
					
						
							|  |  |  |              */ | 
					
						
							|  |  |  |             bool addEventForNextRound( const EventSharedPtr& event ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-04 13:41:44 +00:00
										 |  |  |             /** Another way to control the order of asynchronous event
 | 
					
						
							|  |  |  |                 exeqution.  Use this method to schedule events that are to | 
					
						
							|  |  |  |                 be executed after all regular events that have no delay, | 
					
						
							|  |  |  |                 even when they schedule new regular events without delay. | 
					
						
							|  |  |  |             */ | 
					
						
							|  |  |  |             bool addEventWhenQueueIsEmpty (const EventSharedPtr& rpEvent); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |             /** Process the event queue.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-09 13:49:14 +00:00
										 |  |  |                 This method executes all events whose timeout has | 
					
						
							|  |  |  |                 expired when calling this method (i.e. all events | 
					
						
							|  |  |  |                 whose scheduled time is less or equal the current | 
					
						
							|  |  |  |                 time). | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-09 13:49:14 +00:00
										 |  |  |                 Check for the next available event's timeout via | 
					
						
							|  |  |  |                 nextTimeout(), or whether the queue is empty | 
					
						
							|  |  |  |                 altogether via isEmpty(). | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |              */ | 
					
						
							| 
									
										
										
										
											2006-02-09 13:49:14 +00:00
										 |  |  |             void process(); | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /** Query state of the queue
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @return false, if queue is empty, true otherwise | 
					
						
							|  |  |  |              */ | 
					
						
							| 
									
										
										
										
											2006-02-09 13:49:14 +00:00
										 |  |  |             bool isEmpty() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /** Query timeout for the topmost event in the queue.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @return Timeout in seconds, until the next event is | 
					
						
							|  |  |  |                 ready. The time returned here is relative to the pres | 
					
						
							|  |  |  |                 timer (i.e. the timer specified at the EventQueue | 
					
						
							|  |  |  |                 constructor). When the queue is empty (i.e. isEmpty() | 
					
						
							|  |  |  |                 returns true), the returned value is the highest | 
					
						
							|  |  |  |                 representable double value | 
					
						
							|  |  |  |                 (::std::numeric_limits<double>::max()). If the topmost | 
					
						
							|  |  |  |                 event in the queue is already pending, the timeout | 
					
						
							|  |  |  |                 returned here will actually be negative. | 
					
						
							|  |  |  |             */ | 
					
						
							|  |  |  |             double nextTimeout() const; | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /** Remove all pending events from the queue.
 | 
					
						
							|  |  |  |              */ | 
					
						
							|  |  |  |             void clear(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-26 06:39:44 +00:00
										 |  |  |             /** Forces an empty queue, firing all events immediately
 | 
					
						
							|  |  |  |                 without minding any times. | 
					
						
							|  |  |  |                 @attention do only call from event loop, this calls process_()! | 
					
						
							|  |  |  |              */ | 
					
						
							|  |  |  |             void forceEmpty(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-10 12:54:47 +00:00
										 |  |  |             /** Gets the queue's timer object.
 | 
					
						
							|  |  |  |              */ | 
					
						
							|  |  |  |             ::boost::shared_ptr< ::canvas::tools::ElapsedTime > const & | 
					
						
							|  |  |  |             getTimer() const { return mpTimer; } | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-10 12:54:47 +00:00
										 |  |  |         private: | 
					
						
							| 
									
										
										
										
											2007-07-17 14:06:47 +00:00
										 |  |  |             mutable ::osl::Mutex      maMutex; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-30 07:15:11 +00:00
										 |  |  |             struct EventEntry : public ::std::unary_function<EventEntry, bool> | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |             { | 
					
						
							|  |  |  |                 EventSharedPtr  pEvent; | 
					
						
							|  |  |  |                 double          nTime; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 bool operator<( const EventEntry& ) const; // to leverage priority_queue's default compare
 | 
					
						
							| 
									
										
										
										
											2006-07-26 06:39:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 EventEntry( EventSharedPtr const& p, double t ) | 
					
						
							|  |  |  |                     : pEvent(p), nTime(t) {} | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             typedef ::std::priority_queue< EventEntry > ImplQueueType; | 
					
						
							|  |  |  |             ImplQueueType                   maEvents; | 
					
						
							| 
									
										
										
										
											2006-07-26 06:39:44 +00:00
										 |  |  |             typedef ::std::vector<EventEntry> EventEntryVector; | 
					
						
							|  |  |  |             EventEntryVector                maNextEvents; | 
					
						
							| 
									
										
										
										
											2009-03-04 13:41:44 +00:00
										 |  |  |             ImplQueueType                   maNextNextEvents; | 
					
						
							| 
									
										
										
										
											2006-07-26 06:39:44 +00:00
										 |  |  |             void process_( bool bFireAllEvents ); | 
					
						
							| 
									
										
										
										
											2005-03-10 12:54:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |             // perform timing of events via relative time
 | 
					
						
							|  |  |  |             // measurements. The world time starts, when the
 | 
					
						
							|  |  |  |             // EventQueue object is created
 | 
					
						
							| 
									
										
										
										
											2005-03-10 12:54:47 +00:00
										 |  |  |             ::boost::shared_ptr< ::canvas::tools::ElapsedTime > mpTimer; | 
					
						
							| 
									
										
										
										
											2004-11-26 18:16:22 +00:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2007-07-17 14:06:47 +00:00
										 |  |  | #endif /* INCLUDED_SLIDESHOW_EVENTQUEUE_HXX */
 | 
					
						
							| 
									
										
										
										
											2010-10-27 12:53:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |