Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/pickupsFS14/src/modules/jump/JumpItem.h @ 10108

Last change on this file since 10108 was 10074, checked in by fvultier, 11 years ago

new items added. improved level generator.

File size: 3.5 KB
Line 
1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
3 *                    > www.orxonox.net <
4 *
5 *
6 *   License notice:
7 *
8 *   This program is free software; you can redistribute it and/or
9 *   modify it under the terms of the GNU General Public License
10 *   as published by the Free Software Foundation; either version 2
11 *   of the License, or (at your option) any later version.
12 *
13 *   This program is distributed in the hope that it will be useful,
14 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
15 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 *   GNU General Public License for more details.
17 *
18 *   You should have received a copy of the GNU General Public License
19 *   along with this program; if not, write to the Free Software
20 *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21 *
22 *   Author:
23 *      Fabian 'x3n' Landau
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29/**
30    @file JumpItem.h
31    @brief Declaration of the JumpItem class.
32    @ingroup Jump
33*/
34
35#ifndef _JumpItem_H__
36#define _JumpItem_H__
37
38#include "jump/JumpPrereqs.h"
39
40#include "util/Math.h"
41
42#include "worldentities/MovableEntity.h"
43
44
45namespace orxonox
46{
47
48    /**
49    @brief
50        This class manages the ball for @ref orxonox::Jump "Jump".
51
52        It is responsible for both the movement of the ball in the x,z-plane as well as its interaction with the boundaries of the playing field (defined by the @ref orxonox::JumpCenterpoint "JumpCenterpoint") and the @ref orxonox::JumpFigure "JumpFigures". Or more precisely, it makes the ball bounce off then upper and lower delimiters of the playing field, it makes the ball bounce off the bats and also detects when a player scores and takes appropriate measures.
53
54    @author
55        Fabian 'x3n' Landau
56
57    @ingroup Jump
58    */
59    class _JumpExport JumpItem : public MovableEntity
60    {
61        public:
62            JumpItem(Context* context);
63            virtual ~JumpItem();
64            virtual void tick(float dt);
65            virtual void XMLPort(Element& xmlelement, XMLPort::Mode mode);
66            virtual void setProperties(float newLeftBoundary, float newRightBoundary, float newLowerBoundary, float newUpperBoundary, float newHSpeed, float newVSpeed);
67            virtual void setFigure(WeakPtr<JumpFigure> bats); //!< Set the bats for the ball.
68            virtual void touchFigure();
69
70            void setFieldDimension(float width, float height)
71                { this->fieldWidth_ = width; this->fieldHeight_ = height; }
72            void setFieldDimension(const Vector2& dimension)
73                { this->setFieldDimension(dimension.x, dimension.y); }
74            Vector2 getFieldDimension() const
75                { return Vector2(this->fieldWidth_, this->fieldHeight_); }
76
77            void setWidth(const float width)
78                { this->width_ = width; }
79            float getWidth() const
80                { return width_; }
81            void setHeight(const float height)
82                { this->height_ = height; }
83            float getHeight() const
84                { return height_; }
85
86            bool attachedToFigure_;
87
88        protected:
89            float fieldWidth_; //!< The width of the playing field.
90            float fieldHeight_; //!< The height of the playing field.
91
92            WeakPtr<JumpFigure> figure_; //!< An array with the two bats.
93            float height_;
94            float width_;
95
96            float leftBoundary_;
97            float rightBoundary_;
98            float lowerBoundary_;
99            float upperBoundary_;
100    };
101}
102
103#endif /* _JumpItem_H__ */
Note: See TracBrowser for help on using the repository browser.