comparison engine/core/model/metamodel/action.h @ 0:4a0efb7baf70

* Datasets becomes the new trunk and retires after that :-)
author mvbarracuda@33b003aa-7bff-0310-803a-e67f0ece8222
date Sun, 29 Jun 2008 18:44:17 +0000
parents
children 90005975cdbb
comparison
equal deleted inserted replaced
-1:000000000000 0:4a0efb7baf70
1 /***************************************************************************
2 * Copyright (C) 2005-2008 by the FIFE team *
3 * http://www.fifengine.de *
4 * This file is part of FIFE. *
5 * *
6 * FIFE is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation; either version 2 of the License, or *
9 * (at your option) any later version. *
10 * *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
15 * *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program; if not, write to the *
18 * Free Software Foundation, Inc., *
19 * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA *
20 ***************************************************************************/
21
22 #ifndef FIFE_MODEL_METAMODEL_ACTION_H
23 #define FIFE_MODEL_METAMODEL_ACTION_H
24
25 // Standard C++ library includes
26 #include <string>
27 #include <vector>
28 #include <list>
29
30 // 3rd party library includes
31
32 // FIFE includes
33 // These includes are split up in two parts, separated by one empty line
34 // First block: files included from the FIFE root src directory
35 // Second block: files included from the same folder
36 #include "util/math/angles.h"
37 #include "util/base/resourceclass.h"
38
39 #include "abstractvisual.h"
40
41 namespace FIFE {
42
43 class Action : public ResourceClass {
44 public:
45 /** Constructor
46 * Actions are created by calling addAction from object, thus
47 * this method should really be called only by object or test code
48 */
49 Action(const std::string& identifier);
50
51 /** Destructor
52 */
53 virtual ~Action();
54
55 /** Get the identifier for this action.
56 */
57 const std::string& getId() { return m_id; }
58
59 /** Sets the duration for this action
60 */
61 void setDuration(unsigned int duration) { m_duration = duration; }
62
63 /** Gets the duration of this action
64 */
65 unsigned int getDuration() { return m_duration; }
66
67 /** Sets visualization to be used. Transfers ownership.
68 */
69 void adoptVisual(AbstractVisual* visual) { m_visual = visual; }
70
71 /** Gets used visualization
72 */
73 template<typename T> T* getVisual() const { return reinterpret_cast<T*>(m_visual); }
74
75
76 private:
77 std::string m_id;
78
79 // duration of the action
80 unsigned int m_duration;
81 // visualization for action
82 AbstractVisual* m_visual;
83 };
84
85 }
86
87 #endif