From bb7cf801e6469ecac79196428dda229e00c16df4 Mon Sep 17 00:00:00 2001 From: pandamicro Date: Tue, 10 Jun 2014 11:28:34 +0800 Subject: [PATCH] Fixed #5533: Add SpriteFrame's constructor and make constructor & init functions protected --- cocos/2d/CCSpriteFrame.cpp | 7 +++++ cocos/2d/CCSpriteFrame.h | 61 +++++++++++++++++++++----------------- 2 files changed, 40 insertions(+), 28 deletions(-) diff --git a/cocos/2d/CCSpriteFrame.cpp b/cocos/2d/CCSpriteFrame.cpp index 51d02c4d73..f52c56e48c 100644 --- a/cocos/2d/CCSpriteFrame.cpp +++ b/cocos/2d/CCSpriteFrame.cpp @@ -69,6 +69,13 @@ SpriteFrame* SpriteFrame::create(const std::string& filename, const Rect& rect, return spriteFrame; } +SpriteFrame::SpriteFrame(void) +: _rotated(false) +, _texture(nullptr) +{ + +} + bool SpriteFrame::initWithTexture(Texture2D* texture, const Rect& rect) { Rect rectInPixels = CC_RECT_POINTS_TO_PIXELS(rect); diff --git a/cocos/2d/CCSpriteFrame.h b/cocos/2d/CCSpriteFrame.h index 9a534fbcdc..bf214ff653 100644 --- a/cocos/2d/CCSpriteFrame.h +++ b/cocos/2d/CCSpriteFrame.h @@ -75,34 +75,6 @@ public: The originalSize is the size in points of the frame before being trimmed. */ static SpriteFrame* createWithTexture(Texture2D* pobTexture, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize); - /** - * @js NA - * @lua NA - */ - virtual ~SpriteFrame(void); - - /** Initializes a SpriteFrame with a texture, rect in points. - It is assumed that the frame was not trimmed. - */ - bool initWithTexture(Texture2D* pobTexture, const Rect& rect); - - /** Initializes a SpriteFrame with a texture filename, rect in points; - It is assumed that the frame was not trimmed. - */ - bool initWithTextureFilename(const std::string& filename, const Rect& rect); - - /** Initializes a SpriteFrame with a texture, rect, rotated, offset and originalSize in pixels. - The originalSize is the size in points of the frame before being trimmed. - */ - bool initWithTexture(Texture2D* pobTexture, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize); - - /** Initializes a SpriteFrame with a texture, rect, rotated, offset and originalSize in pixels. - The originalSize is the size in pixels of the frame before being trimmed. - - @since v1.1 - */ - bool initWithTextureFilename(const std::string& filename, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize); - // attributes inline const Rect& getRectInPixels() const { return _rectInPixels; } @@ -141,6 +113,39 @@ public: // Overrides virtual SpriteFrame *clone() const override; + +CC_CONSTRUCTOR_ACCESS: + /** + * @lua NA + */ + SpriteFrame(void); + + /** + * @lua NA + */ + virtual ~SpriteFrame(void); + + /** Initializes a SpriteFrame with a texture, rect in points. + It is assumed that the frame was not trimmed. + */ + bool initWithTexture(Texture2D* pobTexture, const Rect& rect); + + /** Initializes a SpriteFrame with a texture filename, rect in points; + It is assumed that the frame was not trimmed. + */ + bool initWithTextureFilename(const std::string& filename, const Rect& rect); + + /** Initializes a SpriteFrame with a texture, rect, rotated, offset and originalSize in pixels. + The originalSize is the size in points of the frame before being trimmed. + */ + bool initWithTexture(Texture2D* pobTexture, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize); + + /** Initializes a SpriteFrame with a texture, rect, rotated, offset and originalSize in pixels. + The originalSize is the size in pixels of the frame before being trimmed. + + @since v1.1 + */ + bool initWithTextureFilename(const std::string& filename, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize); protected: Vec2 _offset;