2012-04-19 14:35:52 +08:00
|
|
|
/****************************************************************************
|
2012-06-14 15:13:16 +08:00
|
|
|
Copyright (c) 2010-2012 cocos2d-x.org
|
2012-04-19 14:35:52 +08:00
|
|
|
Copyright (c) 2010 Lam Pham
|
|
|
|
|
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
#ifndef __MISC_NODE_CCPROGRESS_TIMER_H__
|
|
|
|
#define __MISC_NODE_CCPROGRESS_TIMER_H__
|
|
|
|
|
2012-06-19 13:50:11 +08:00
|
|
|
#include "sprite_nodes/CCSprite.h"
|
2013-04-13 05:51:29 +08:00
|
|
|
#ifdef EMSCRIPTEN
|
|
|
|
#include "base_nodes/CCGLBufferedNode.h"
|
|
|
|
#endif // EMSCRIPTEN
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
NS_CC_BEGIN
|
|
|
|
|
2012-06-20 18:09:11 +08:00
|
|
|
/**
|
|
|
|
* @addtogroup misc_nodes
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2010-08-11 18:15:52 +08:00
|
|
|
/** Types of progress
|
|
|
|
@since v0.99.1
|
2012-04-19 14:35:52 +08:00
|
|
|
*/
|
2010-08-11 18:15:52 +08:00
|
|
|
typedef enum {
|
2012-04-19 14:35:52 +08:00
|
|
|
/// Radial Counter-Clockwise
|
2013-06-20 14:13:12 +08:00
|
|
|
kProgressTimerTypeRadial,
|
2012-04-19 14:35:52 +08:00
|
|
|
/// Bar
|
2013-06-20 14:13:12 +08:00
|
|
|
kProgressTimerTypeBar,
|
|
|
|
} ProgressTimerType;
|
2012-04-19 14:35:52 +08:00
|
|
|
|
2010-08-11 18:15:52 +08:00
|
|
|
/**
|
2013-06-20 14:13:12 +08:00
|
|
|
@brief ProgressTimer is a subclass of Node.
|
2010-08-11 18:15:52 +08:00
|
|
|
It renders the inner sprite according to the percentage.
|
|
|
|
The progress can be Radial, Horizontal or vertical.
|
|
|
|
@since v0.99.1
|
2012-04-19 14:35:52 +08:00
|
|
|
*/
|
2013-06-20 14:13:12 +08:00
|
|
|
class CC_DLL ProgressTimer : public NodeRGBA
|
2013-04-13 05:51:29 +08:00
|
|
|
#ifdef EMSCRIPTEN
|
2013-06-20 14:13:12 +08:00
|
|
|
, public GLBufferedNode
|
2013-04-13 05:51:29 +08:00
|
|
|
#endif // EMSCRIPTEN
|
2012-04-19 14:35:52 +08:00
|
|
|
{
|
|
|
|
public:
|
2013-06-20 14:13:12 +08:00
|
|
|
ProgressTimer();
|
|
|
|
~ProgressTimer(void);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
/** Change the percentage to change progress. */
|
2013-06-20 14:13:12 +08:00
|
|
|
inline ProgressTimerType getType(void) { return _type; }
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
/** Percentages are from 0 to 100 */
|
2013-06-15 14:03:30 +08:00
|
|
|
inline float getPercentage(void) {return _percentage; }
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
/** The image to show the progress percentage, retain */
|
2013-06-20 14:13:12 +08:00
|
|
|
inline Sprite* getSprite(void) { return _sprite; }
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
/** Initializes a progress timer with the sprite as the shape the timer goes through */
|
2013-06-20 14:13:12 +08:00
|
|
|
bool initWithSprite(Sprite* sp);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
void setPercentage(float fPercentage);
|
2013-06-20 14:13:12 +08:00
|
|
|
void setSprite(Sprite *pSprite);
|
|
|
|
void setType(ProgressTimerType type);
|
2012-04-19 14:35:52 +08:00
|
|
|
void setReverseProgress(bool reverse);
|
|
|
|
|
|
|
|
virtual void draw(void);
|
2013-07-05 15:06:38 +08:00
|
|
|
void setAnchorPoint(const Point& anchorPoint);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
2013-07-15 16:06:59 +08:00
|
|
|
virtual void setColor(const Color3B& color);
|
|
|
|
virtual const Color3B& getColor() const;
|
|
|
|
virtual GLubyte getOpacity() const;
|
|
|
|
virtual void setOpacity(GLubyte opacity);
|
2012-06-15 15:10:40 +08:00
|
|
|
|
2013-06-15 14:03:30 +08:00
|
|
|
inline bool isReverseDirection() { return _reverseDirection; };
|
|
|
|
inline void setReverseDirection(bool value) { _reverseDirection = value; };
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
public:
|
|
|
|
/** Creates a progress timer with the sprite as the shape the timer goes through */
|
2013-06-20 14:13:12 +08:00
|
|
|
static ProgressTimer* create(Sprite* sp);
|
2012-04-19 14:35:52 +08:00
|
|
|
protected:
|
2013-07-05 16:49:22 +08:00
|
|
|
Tex2F textureCoordFromAlphaPoint(Point alpha);
|
|
|
|
Vertex2F vertexFromAlphaPoint(Point alpha);
|
2012-04-19 14:35:52 +08:00
|
|
|
void updateProgress(void);
|
|
|
|
void updateBar(void);
|
|
|
|
void updateRadial(void);
|
|
|
|
void updateColor(void);
|
2013-06-20 14:13:12 +08:00
|
|
|
Point boundaryTexCoord(char index);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
protected:
|
2013-06-20 14:13:12 +08:00
|
|
|
ProgressTimerType _type;
|
2013-06-15 14:03:30 +08:00
|
|
|
float _percentage;
|
2013-06-20 14:13:12 +08:00
|
|
|
Sprite *_sprite;
|
2013-06-15 14:03:30 +08:00
|
|
|
int _vertexDataCount;
|
2013-07-05 16:49:22 +08:00
|
|
|
V2F_C4B_T2F *_vertexData;
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Midpoint is used to modify the progress start position.
|
|
|
|
* If you're using radials type then the midpoint changes the center point
|
|
|
|
* If you're using bar type the the midpoint changes the bar growth
|
|
|
|
* it expands from the center but clamps to the sprites edge so:
|
2013-07-12 18:04:32 +08:00
|
|
|
* you want a left to right then set the midpoint all the way to Point(0,y)
|
|
|
|
* you want a right to left then set the midpoint all the way to Point(1,y)
|
|
|
|
* you want a bottom to top then set the midpoint all the way to Point(x,0)
|
|
|
|
* you want a top to bottom then set the midpoint all the way to Point(x,1)
|
2012-04-19 14:35:52 +08:00
|
|
|
*/
|
2013-06-20 14:13:12 +08:00
|
|
|
CC_PROPERTY(Point, _midpoint, Midpoint);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This allows the bar type to move the component at a specific rate
|
|
|
|
* Set the component to 0 to make sure it stays at 100%.
|
|
|
|
* For example you want a left to right bar but not have the height stay 100%
|
2013-07-12 18:04:32 +08:00
|
|
|
* Set the rate to be Point(0,1); and set the midpoint to = Point(0,.5f);
|
2012-04-19 14:35:52 +08:00
|
|
|
*/
|
2013-06-20 14:13:12 +08:00
|
|
|
CC_SYNTHESIZE(Point, _barChangeRate, BarChangeRate);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
2013-06-15 14:03:30 +08:00
|
|
|
bool _reverseDirection;
|
2012-04-19 14:35:52 +08:00
|
|
|
};
|
|
|
|
|
2012-06-20 18:09:11 +08:00
|
|
|
// end of misc_nodes group
|
|
|
|
/// @}
|
|
|
|
|
2012-04-19 14:35:52 +08:00
|
|
|
NS_CC_END
|
|
|
|
|
|
|
|
#endif //__MISC_NODE_CCPROGRESS_TIMER_H__
|