2020-10-17 16:32:16 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2013-2017 Chukong Technologies Inc.
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-07-10 09:47:41 +08:00
|
|
|
https://axis-project.github.io/
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
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 __CCBONE_H__
|
|
|
|
#define __CCBONE_H__
|
|
|
|
|
2020-10-21 10:12:00 +08:00
|
|
|
#include "CCArmatureDefine.h"
|
|
|
|
#include "CCDatas.h"
|
|
|
|
#include "CCTween.h"
|
|
|
|
#include "CCDecorativeDisplay.h"
|
|
|
|
#include "CCDisplayManager.h"
|
|
|
|
#include "CocosStudioExport.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
#include "2d/CCNode.h"
|
|
|
|
#include "math/CCMath.h"
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
namespace cocostudio
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
class Armature;
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
class CCS_DLL Bone : public axis::Node
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Allocates and initializes a bone.
|
|
|
|
* @return A initialized bone which is marked as "autorelease".
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
static Bone* create();
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* Allocates and initializes a bone.
|
|
|
|
*
|
|
|
|
* @param name If name is not null, then set name to the bone's name
|
|
|
|
* @return A initialized bone which is marked as "autorelease".
|
|
|
|
*/
|
2021-12-31 12:12:40 +08:00
|
|
|
static Bone* create(std::string_view name);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @js ctor
|
|
|
|
*/
|
|
|
|
Bone();
|
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
2020-10-17 16:32:16 +08:00
|
|
|
virtual ~Bone(void);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Initializes an empty Bone with nothing init.
|
|
|
|
*/
|
|
|
|
virtual bool init() override;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initializes a Bone with the specified name
|
|
|
|
* @param name Bone's name.
|
|
|
|
*/
|
2021-12-31 12:12:40 +08:00
|
|
|
virtual bool init(std::string_view name);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add display and use displayData to init the display.
|
|
|
|
* If index already have a display, then replace it.
|
|
|
|
* If index is current display index, then also change display to _index
|
|
|
|
*
|
|
|
|
* @param displayData it include the display information, like DisplayType.
|
|
|
|
* If you want to create a sprite display, then create a SpriteDisplayData param
|
|
|
|
*
|
|
|
|
* @param index the index of the display you want to replace or add to
|
|
|
|
* -1 : append display from back
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void addDisplay(DisplayData* displayData, int index);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
void addDisplay(axis::Node* display, int index);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
void removeDisplay(int index);
|
|
|
|
|
|
|
|
CC_DEPRECATED_ATTRIBUTE void changeDisplayByIndex(int index, bool force);
|
2021-12-31 12:12:40 +08:00
|
|
|
CC_DEPRECATED_ATTRIBUTE void changeDisplayByName(std::string_view name, bool force);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
void changeDisplayWithIndex(int index, bool force);
|
2021-12-31 12:12:40 +08:00
|
|
|
void changeDisplayWithName(std::string_view name, bool force);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
2021-12-25 10:04:45 +08:00
|
|
|
* Add a child to this bone, and it will let this child call setParent(Bone *parent) function to set self to it's
|
|
|
|
* parent
|
2019-11-23 20:27:39 +08:00
|
|
|
* @param child the child you want to add
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void addChildBone(Bone* child);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set parent bone.
|
|
|
|
* If parent is null, then also remove this bone from armature.
|
2021-12-25 10:04:45 +08:00
|
|
|
* It will not set the Armature, if you want to add the bone to a Armature, you should use Armature::addBone(Bone
|
|
|
|
* *bone, const char* parentName).
|
2019-11-23 20:27:39 +08:00
|
|
|
*
|
|
|
|
* @param parent the parent bone.
|
|
|
|
* nullptr : remove this bone from armature
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void setParentBone(Bone* parent);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get parent bone
|
|
|
|
* @return parent bone
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
Bone* getParentBone();
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
using Node::removeFromParent;
|
|
|
|
/**
|
|
|
|
* Remove itself from its parent.
|
|
|
|
* @param recursion whether or not to remove childBone's display
|
|
|
|
*/
|
|
|
|
void removeFromParent(bool recursion);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes a child Bone
|
|
|
|
* @param bone the bone you want to remove
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void removeChildBone(Bone* bone, bool recursion);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
void update(float delta) override;
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
void updateDisplayedColor(const axis::Color3B& parentColor) override;
|
2019-11-25 01:35:26 +08:00
|
|
|
void updateDisplayedOpacity(uint8_t parentOpacity) override;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
//! Update color to render display
|
|
|
|
virtual void updateColor() override;
|
|
|
|
|
|
|
|
//! Update zorder
|
|
|
|
void updateZOrder();
|
|
|
|
|
|
|
|
virtual void setLocalZOrder(int zOrder) override;
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
Tween* getTween();
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Whether or not the bone's transform property changed. if true, the bone will update the transform.
|
|
|
|
*/
|
|
|
|
virtual void setTransformDirty(bool dirty) { _boneTransformDirty = dirty; }
|
|
|
|
virtual bool isTransformDirty() { return _boneTransformDirty; }
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
virtual axis::Mat4 getNodeToArmatureTransform() const;
|
|
|
|
virtual axis::Mat4 getNodeToWorldTransform() const override;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
axis::Node* getDisplayRenderNode();
|
2019-11-23 20:27:39 +08:00
|
|
|
DisplayType getDisplayRenderNodeType();
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Get the ColliderBody list in this bone. The object in the Array is ColliderBody.
|
|
|
|
*/
|
|
|
|
virtual ColliderDetector* getColliderDetector() const;
|
|
|
|
|
|
|
|
#if ENABLE_PHYSICS_BOX2D_DETECT || ENABLE_PHYSICS_CHIPMUNK_DETECT
|
2021-12-25 10:04:45 +08:00
|
|
|
virtual void setColliderFilter(ColliderFilter* filter);
|
|
|
|
virtual ColliderFilter* getColliderFilter();
|
2019-11-23 20:27:39 +08:00
|
|
|
#endif
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
virtual void setBoneData(BoneData* boneData);
|
|
|
|
virtual BoneData* getBoneData() const;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
virtual void setArmature(Armature* armature);
|
|
|
|
virtual Armature* getArmature() const;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
virtual void setChildArmature(Armature* childArmature);
|
|
|
|
virtual Armature* getChildArmature() const;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
virtual DisplayManager* getDisplayManager() const { return _displayManager; }
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* @lua NA
|
|
|
|
*/
|
|
|
|
virtual void setIgnoreMovementBoneData(bool ignore) { _ignoreMovementBoneData = ignore; }
|
|
|
|
virtual bool isIgnoreMovementBoneData() const { return _ignoreMovementBoneData; }
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This function is deprecated, please use isIgnoreMovementBoneData()
|
|
|
|
* @lua NA
|
|
|
|
*/
|
|
|
|
CC_DEPRECATED_ATTRIBUTE virtual bool getIgnoreMovementBoneData() const { return isIgnoreMovementBoneData(); }
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Set blend function
|
|
|
|
*/
|
2022-07-11 17:50:21 +08:00
|
|
|
virtual void setBlendFunc(const axis::BlendFunc& blendFunc);
|
|
|
|
virtual axis::BlendFunc getBlendFunc(void) { return _blendFunc; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/*
|
2021-12-25 10:04:45 +08:00
|
|
|
* Set if blend function is dirty
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
|
|
|
virtual void setBlendDirty(bool dirty) { _blendDirty = dirty; }
|
2020-10-17 16:32:16 +08:00
|
|
|
virtual bool isBlendDirty(void) { return _blendDirty; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
virtual FrameData* getTweenData() const { return _tweenData; }
|
|
|
|
|
|
|
|
virtual BaseData* getWorldInfo() const { return _worldInfo; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
protected:
|
2021-12-25 10:04:45 +08:00
|
|
|
void applyParentTransform(Bone* parent);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The origin state of the Bone. Display's state is effected by _boneData, m_pNode, _tweenData
|
|
|
|
* when call setData function, it will copy from the BoneData.
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
BoneData* _boneData;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
//! A weak reference to the Armature
|
2021-12-25 10:04:45 +08:00
|
|
|
Armature* _armature;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
//! A weak reference to the child Armature
|
2021-12-25 10:04:45 +08:00
|
|
|
Armature* _childArmature;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
DisplayManager* _displayManager;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/*
|
2021-12-25 10:04:45 +08:00
|
|
|
* When Armature play an animation, if there is not a MovementBoneData of this bone in this MovementData, this
|
|
|
|
* bone will be hidden. Set IgnoreMovementBoneData to true, then this bone will also be shown.
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
|
|
|
bool _ignoreMovementBoneData;
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
axis::BlendFunc _blendFunc;
|
2019-11-23 20:27:39 +08:00
|
|
|
bool _blendDirty;
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
Tween* _tween; //! Calculate tween effect
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
//! Used for making tween effect in every frame
|
2021-12-25 10:04:45 +08:00
|
|
|
FrameData* _tweenData;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
Bone* _parentBone; //! A weak reference to its parent
|
|
|
|
bool _boneTransformDirty; //! Whether or not transform dirty
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
//! self Transform, use this to change display's state
|
2022-07-11 17:50:21 +08:00
|
|
|
axis::Mat4 _worldTransform;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
BaseData* _worldInfo;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
//! Armature's parent bone
|
2021-12-25 10:04:45 +08:00
|
|
|
Bone* _armatureParentBone;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
//! Data version
|
|
|
|
float _dataVersion;
|
|
|
|
};
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
} // namespace cocostudio
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
#endif /*__CCBONE_H__*/
|