CCArmature.h 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. /****************************************************************************
  2. Copyright (c) 2013-2017 Chukong Technologies Inc.
  3. http://www.cocos2d-x.org
  4. Permission is hereby granted, free of charge, to any person obtaining a copy
  5. of this software and associated documentation files (the "Software"), to deal
  6. in the Software without restriction, including without limitation the rights
  7. to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. copies of the Software, and to permit persons to whom the Software is
  9. furnished to do so, subject to the following conditions:
  10. The above copyright notice and this permission notice shall be included in
  11. all copies or substantial portions of the Software.
  12. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  13. IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  14. FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  15. AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  16. LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  17. OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  18. THE SOFTWARE.
  19. ****************************************************************************/
  20. #ifndef __CCARMATURE_H__
  21. #define __CCARMATURE_H__
  22. #include "editor-support/cocostudio/CCArmatureDefine.h"
  23. #include "editor-support/cocostudio/CCBone.h"
  24. #include "editor-support/cocostudio/CCBatchNode.h"
  25. #include "editor-support/cocostudio/CCArmatureAnimation.h"
  26. #include "editor-support/cocostudio/CCSpriteFrameCacheHelper.h"
  27. #include "editor-support/cocostudio/CCArmatureDataManager.h"
  28. #include "editor-support/cocostudio/CocosStudioExport.h"
  29. #include "math/CCMath.h"
  30. class b2Body;
  31. struct cpBody;
  32. namespace cocostudio {
  33. CC_DEPRECATED_ATTRIBUTE typedef ProcessBase CCProcessBase;
  34. CC_DEPRECATED_ATTRIBUTE typedef BaseData CCBaseData;
  35. CC_DEPRECATED_ATTRIBUTE typedef DisplayData CCDisplayData;
  36. CC_DEPRECATED_ATTRIBUTE typedef SpriteDisplayData CCSpriteDisplayData;
  37. CC_DEPRECATED_ATTRIBUTE typedef ArmatureDisplayData CCArmatureDisplayData;
  38. CC_DEPRECATED_ATTRIBUTE typedef ParticleDisplayData CCParticleDisplayData;
  39. CC_DEPRECATED_ATTRIBUTE typedef BoneData CCBoneData;
  40. CC_DEPRECATED_ATTRIBUTE typedef FrameData CCFrameData;
  41. CC_DEPRECATED_ATTRIBUTE typedef MovementBoneData CCMovementBoneData;
  42. CC_DEPRECATED_ATTRIBUTE typedef MovementData CCMovementData;
  43. CC_DEPRECATED_ATTRIBUTE typedef AnimationData CCAnimationData;
  44. CC_DEPRECATED_ATTRIBUTE typedef ContourData CCContourData;
  45. CC_DEPRECATED_ATTRIBUTE typedef TextureData CCTextureData;
  46. CC_DEPRECATED_ATTRIBUTE typedef DecorativeDisplay CCDecorativeDisplay;
  47. CC_DEPRECATED_ATTRIBUTE typedef DisplayData CCDisplayData;
  48. CC_DEPRECATED_ATTRIBUTE typedef DisplayFactory CCDisplayFactory;
  49. CC_DEPRECATED_ATTRIBUTE typedef BatchNode CCBatchNode;
  50. CC_DEPRECATED_ATTRIBUTE typedef DecorativeDisplay CCDecorativeDisplay;
  51. CC_DEPRECATED_ATTRIBUTE typedef DisplayManager CCDisplayManager;
  52. CC_DEPRECATED_ATTRIBUTE typedef ColliderBody CCColliderBody;
  53. CC_DEPRECATED_ATTRIBUTE typedef ColliderDetector CCColliderDetector;
  54. CC_DEPRECATED_ATTRIBUTE typedef SpriteFrameCacheHelper CCSpriteFrameCacheHelper;
  55. CC_DEPRECATED_ATTRIBUTE typedef ArmatureData CCArmatureData;
  56. CC_DEPRECATED_ATTRIBUTE typedef Bone CCBone;
  57. CC_DEPRECATED_ATTRIBUTE typedef ArmatureAnimation CCArmatureAnimation;
  58. CC_DEPRECATED_ATTRIBUTE typedef Armature CCArmature;
  59. CC_DEPRECATED_ATTRIBUTE typedef ArmatureDataManager CCArmatureDataManager;
  60. CC_DEPRECATED_ATTRIBUTE typedef cocos2d::tweenfunc::TweenType CCTweenType;
  61. class CC_STUDIO_DLL Armature : public cocos2d::Node, public cocos2d::BlendProtocol
  62. {
  63. public:
  64. /**
  65. * Allocates and initializes an armature.
  66. * @return An initialized armature which is marked as "autorelease".
  67. */
  68. static Armature *create();
  69. /**
  70. * Allocates an armature, and use the ArmatureData named name in ArmatureDataManager to initializes the armature.
  71. *
  72. * @param name Armature will use the name to find the ArmatureData to initializes it.
  73. * @return A initialized armature which is marked as "autorelease".
  74. */
  75. static Armature *create(const std::string& name);
  76. static Armature *create(const std::string& name, Bone *parentBone);
  77. public:
  78. /**
  79. * @js ctor
  80. */
  81. Armature();
  82. /**
  83. * @js NA
  84. * @lua NA
  85. */
  86. virtual ~Armature(void);
  87. /**
  88. * Init the empty armature
  89. */
  90. virtual bool init() override;
  91. /**
  92. * Init an armature with specified name
  93. * @param name Armature name
  94. */
  95. virtual bool init(const std::string& name);
  96. virtual bool init(const std::string& name, Bone *parentBone);
  97. /**
  98. * Add a Bone to this Armature,
  99. *
  100. * @param bone The Bone you want to add to Armature
  101. * @param parentName The parent Bone's name you want to add to . If it's nullptr, then set Armature to its parent
  102. */
  103. virtual void addBone(Bone *bone, const std::string& parentName);
  104. /**
  105. * Get a bone with the specified name
  106. *
  107. * @param name The bone's name you want to get
  108. */
  109. virtual Bone *getBone(const std::string& name) const;
  110. /**
  111. * Change a bone's parent with the specified parent name.
  112. *
  113. * @param bone The bone you want to change parent
  114. * @param parentName The new parent's name.
  115. */
  116. virtual void changeBoneParent(Bone *bone, const std::string& parentName);
  117. /**
  118. * Remove a bone with the specified name. If recursion it will also remove child Bone recursionly.
  119. *
  120. * @param bone The bone you want to remove
  121. * @param recursion Determine whether remove the bone's child recursion.
  122. */
  123. virtual void removeBone(Bone *bone, bool recursion);
  124. /**
  125. * Get Armature's bone dictionary
  126. * @return Armature's bone dictionary
  127. */
  128. const cocos2d::Map<std::string, Bone*>& getBoneDic() const;
  129. /**
  130. * This boundingBox will calculate all bones' boundingBox every time
  131. */
  132. virtual cocos2d::Rect getBoundingBox() const override;
  133. Bone *getBoneAtPoint(float x, float y) const;
  134. // overrides
  135. /**
  136. * @js NA
  137. * @lua NA
  138. */
  139. virtual void visit(cocos2d::Renderer *renderer, const cocos2d::Mat4 &parentTransform, uint32_t parentFlags) override;
  140. virtual void draw(cocos2d::Renderer *renderer, const cocos2d::Mat4 &transform, uint32_t flags) override;
  141. virtual void update(float dt) override;
  142. virtual void onEnter() override;
  143. virtual void onExit() override;
  144. virtual const cocos2d::Mat4& getNodeToParentTransform() const override;
  145. /**
  146. * @js NA
  147. * @lua NA
  148. */
  149. inline void setBlendFunc(const cocos2d::BlendFunc &blendFunc) override { _blendFunc = blendFunc; }
  150. /**
  151. * @js NA
  152. * @lua NA
  153. */
  154. inline const cocos2d::BlendFunc &getBlendFunc(void) const override{ return _blendFunc; }
  155. /**
  156. * Set contentsize and Calculate anchor point.
  157. */
  158. virtual void updateOffsetPoint();
  159. virtual void setAnchorPoint(const cocos2d::Vec2& point) override;
  160. virtual const cocos2d::Vec2& getAnchorPointInPoints() const override;
  161. virtual const cocos2d::Vec2& getOffsetPoints() const;
  162. virtual void setAnimation(ArmatureAnimation *animation);
  163. virtual ArmatureAnimation *getAnimation() const;
  164. virtual bool getArmatureTransformDirty() const;
  165. #if ENABLE_PHYSICS_BOX2D_DETECT || ENABLE_PHYSICS_CHIPMUNK_DETECT
  166. virtual void setColliderFilter(ColliderFilter *filter);
  167. #elif ENABLE_PHYSICS_SAVE_CALCULATED_VERTEX
  168. CC_DEPRECATED_ATTRIBUTE virtual void drawContour();
  169. #endif
  170. virtual void setArmatureData(ArmatureData *armatureData) { _armatureData = armatureData; }
  171. virtual ArmatureData *getArmatureData() const { return _armatureData; }
  172. virtual void setParentBone(Bone *parentBone);
  173. virtual Bone *getParentBone() const;
  174. virtual void setVersion(float version) { _version = version; }
  175. virtual float getVersion() const { return _version; }
  176. virtual void setBatchNode(BatchNode *batchNode) { _batchNode = batchNode; }
  177. virtual BatchNode *getBatchNode() const { return _batchNode; }
  178. #if ENABLE_PHYSICS_BOX2D_DETECT
  179. virtual b2Fixture *getShapeList();
  180. /**
  181. * @js NA
  182. * @lua NA
  183. */
  184. virtual void setBody(b2Body *body);
  185. /**
  186. * @js NA
  187. * @lua NA
  188. */
  189. virtual b2Body *getBody() const;
  190. #elif ENABLE_PHYSICS_CHIPMUNK_DETECT
  191. /**
  192. * @js NA
  193. * @lua NA
  194. */
  195. virtual cpShape *getShapeList();
  196. /**
  197. * @js NA
  198. * @lua NA
  199. */
  200. virtual void setBody(cpBody *body);
  201. /**
  202. * @js NA
  203. * @lua NA
  204. */
  205. virtual cpBody *getBody() const;
  206. #endif
  207. protected:
  208. /*
  209. * Used to create Bone internal
  210. * @js NA
  211. * @lua NA
  212. */
  213. Bone *createBone(const std::string& boneName );
  214. protected:
  215. ArmatureData *_armatureData;
  216. BatchNode *_batchNode;
  217. Bone *_parentBone;
  218. float _version;
  219. mutable bool _armatureTransformDirty;
  220. cocos2d::Map<std::string, Bone*> _boneDic; //! The dictionary of the bones, include all bones in the armature, no matter it is the direct bone or the indirect bone. It is different from m_pChindren.
  221. cocos2d::Vector<Bone*> _topBoneList;
  222. cocos2d::BlendFunc _blendFunc; //! It's required for CCTextureProtocol inheritance
  223. cocos2d::Vec2 _offsetPoint;
  224. cocos2d::Vec2 _realAnchorPointInPoints;
  225. ArmatureAnimation *_animation;
  226. #if ENABLE_PHYSICS_BOX2D_DETECT
  227. b2Body *_body;
  228. #elif ENABLE_PHYSICS_CHIPMUNK_DETECT
  229. cpBody *_body;
  230. #endif
  231. };
  232. }
  233. #endif /*__CCARMATURE_H__*/