Ginga  0.13.6
 All Classes Namespaces Functions Variables
EventTransitionManager.h
1 /******************************************************************************
2 Este arquivo eh parte da implementacao do ambiente declarativo do middleware
3 Ginga (Ginga-NCL).
4 
5 Direitos Autorais Reservados (c) 1989-2007 PUC-Rio/Laboratorio TeleMidia
6 
7 Este programa eh software livre; voce pode redistribui-lo e/ou modificah-lo sob
8 os termos da Licenca Publica Geral GNU versao 2 conforme publicada pela Free
9 Software Foundation.
10 
11 Este programa eh distribuido na expectativa de que seja util, porem, SEM
12 NENHUMA GARANTIA; nem mesmo a garantia implicita de COMERCIABILIDADE OU
13 ADEQUACAO A UMA FINALIDADE ESPECIFICA. Consulte a Licenca Publica Geral do
14 GNU versao 2 para mais detalhes.
15 
16 Voce deve ter recebido uma copia da Licenca Publica Geral do GNU versao 2 junto
17 com este programa; se nao, escreva para a Free Software Foundation, Inc., no
18 endereco 59 Temple Street, Suite 330, Boston, MA 02111-1307 USA.
19 
20 Para maiores informacoes:
21 ncl @ telemidia.puc-rio.br
22 http://www.ncl.org.br
23 http://www.ginga.org.br
24 http://www.telemidia.puc-rio.br
25 ******************************************************************************
26 This file is part of the declarative environment of middleware Ginga (Ginga-NCL)
27 
28 Copyright: 1989-2007 PUC-RIO/LABORATORIO TELEMIDIA, All Rights Reserved.
29 
30 This program is free software; you can redistribute it and/or modify it under
31 the terms of the GNU General Public License version 2 as published by
32 the Free Software Foundation.
33 
34 This program is distributed in the hope that it will be useful, but WITHOUT ANY
35 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
36 PARTICULAR PURPOSE. See the GNU General Public License version 2 for more
37 details.
38 
39 You should have received a copy of the GNU General Public License version 2
40 along with this program; if not, write to the Free Software
41 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
42 
43 For further information contact:
44 ncl @ telemidia.puc-rio.br
45 http://www.ncl.org.br
46 http://www.ginga.org.br
47 http://www.telemidia.puc-rio.br
48 *******************************************************************************/
49 
50 #ifndef EventTransitionManager_H_
51 #define EventTransitionManager_H_
52 
53 #include "system/thread/Thread.h"
54 using namespace ::br::pucrio::telemidia::ginga::core::system::thread;
55 
56 #include "ncl/interfaces/RelativeTimeIntervalAnchor.h"
57 #include "ncl/interfaces/SampleIntervalAnchor.h"
58 using namespace ::br::pucrio::telemidia::ncl::interfaces;
59 
60 #include "ncl/connectors/EventUtil.h"
61 using namespace ::br::pucrio::telemidia::ncl::connectors;
62 
63 #include "player/IPlayer.h"
64 using namespace ::br::pucrio::telemidia::ginga::core::player;
65 
66 #include "PresentationEvent.h"
67 using namespace ::br::pucrio::telemidia::ginga::ncl::model::event;
68 
69 #include "BeginEventTransition.h"
70 #include "EndEventTransition.h"
71 
72 #include <map>
73 #include <vector>
74 using namespace std;
75 
76 namespace br {
77 namespace pucrio {
78 namespace telemidia {
79 namespace ginga {
80 namespace ncl {
81 namespace model {
82 namespace event {
83 namespace transition {
85  private:
86  map<short int, int> currentTransitionIndex;
87  map<short int, int> startTransitionIndex;
88  map<short int, vector<EventTransition*>*> transTable;
89  pthread_mutex_t transMutex;
90 
91  public:
93  virtual ~EventTransitionManager();
94 
95  private:
96  short int getType(PresentationEvent* event);
97  vector<EventTransition*>* getTransitionEvents(short int type);
98 
99  public:
100  void addPresentationEvent(PresentationEvent* event);
101 
102  private:
103  void addEventTransition(EventTransition* transition, short int type);
104 
105  public:
106  void removeEventTransition(PresentationEvent* event);
107 
108  void resetTimeIndex();
109  void resetTimeIndexByType(short int type);
110  void prepare(bool wholeContent, double startTime, short int type);
111  void start(double offsetTime);
112  void stop(double endTime, bool applicationType=false);
113  void abort(double endTime, bool applicationType=false);
114 
115  void timeBaseNaturalEnd(
116  int64_t timeValue,
117  FormatterEvent* mainEvent,
118  short int transType);
119 
120  void updateTransitionTable(
121  double timeValue,
122  IPlayer* player,
123  FormatterEvent* mainEvent,
124  short int transType);
125 
126  set<double>* getTransitionsValues(short int transType);
127  EventTransition* getNextTransition(FormatterEvent* mainEvent);
128  };
129 }
130 }
131 }
132 }
133 }
134 }
135 }
136 }
137 
138 #endif /*EventTransitionManager_H_*/