2021-12-26 23:26:34 +08:00
|
|
|
/**
|
2020-10-18 00:27:23 +08:00
|
|
|
* The MIT License (MIT)
|
|
|
|
*
|
|
|
|
* Copyright (c) 2012-2018 DragonBones team and other contributors
|
|
|
|
*
|
|
|
|
* 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:
|
2021-12-25 10:04:45 +08:00
|
|
|
*
|
2020-10-18 00:27:23 +08:00
|
|
|
* The above copyright notice and this permission notice shall be included in all
|
|
|
|
* copies or substantial portions of the Software.
|
2021-12-25 10:04:45 +08:00
|
|
|
*
|
2020-10-18 00:27:23 +08:00
|
|
|
* 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 DRAGONBONES_ARMATURE_DATA_H
|
|
|
|
#define DRAGONBONES_ARMATURE_DATA_H
|
|
|
|
|
|
|
|
#include "../core/BaseObject.h"
|
|
|
|
#include "../geom/Matrix.h"
|
|
|
|
#include "../geom/Transform.h"
|
|
|
|
#include "../geom/ColorTransform.h"
|
|
|
|
#include "../geom/Rectangle.h"
|
|
|
|
|
|
|
|
DRAGONBONES_NAMESPACE_BEGIN
|
|
|
|
/**
|
|
|
|
* - The armature data.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 骨架数据。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
class ArmatureData : public BaseObject
|
|
|
|
{
|
|
|
|
BIND_CLASS_TYPE_B(ArmatureData);
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
ArmatureType type;
|
|
|
|
/**
|
|
|
|
* - The animation frame rate.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 动画帧率。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
unsigned frameRate;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
unsigned cacheFrameRate;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
float scale;
|
|
|
|
/**
|
|
|
|
* - The armature name.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 骨架名称。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
std::string name;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
Rectangle aabb;
|
|
|
|
/**
|
|
|
|
* - The names of all the animation data.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 所有的动画数据名称。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
std::vector<std::string> animationNames;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
std::vector<BoneData*> sortedBones;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
std::vector<SlotData*> sortedSlots;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
std::vector<ActionData*> defaultActions;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
std::vector<ActionData*> actions;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
2021-12-27 13:52:08 +08:00
|
|
|
hlookup::string_map<BoneData*> bones;
|
2020-10-18 00:27:23 +08:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
2021-12-27 13:52:08 +08:00
|
|
|
hlookup::string_map<SlotData*> slots;
|
2020-10-18 00:27:23 +08:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
2021-12-27 13:52:08 +08:00
|
|
|
hlookup::string_map<ConstraintData*> constraints;
|
2020-10-18 00:27:23 +08:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
2021-12-27 13:52:08 +08:00
|
|
|
hlookup::string_map<SkinData*> skins;
|
2020-10-18 00:27:23 +08:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
2021-12-27 13:52:08 +08:00
|
|
|
hlookup::string_map<AnimationData*> animations;
|
2020-10-18 00:27:23 +08:00
|
|
|
/**
|
|
|
|
* - The default skin data.
|
|
|
|
* @version DragonBones 4.5
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 默认插槽数据。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 4.5
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
SkinData* defaultSkin;
|
|
|
|
/**
|
|
|
|
* - The default animation data.
|
|
|
|
* @version DragonBones 4.5
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 默认动画数据。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 4.5
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
AnimationData* defaultAnimation;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
CanvasData* canvas;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
UserData* userData;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
DragonBonesData* parent;
|
2021-12-25 10:04:45 +08:00
|
|
|
ArmatureData() : canvas(nullptr), userData(nullptr) { _onClear(); }
|
|
|
|
~ArmatureData() { _onClear(); }
|
2020-10-18 00:27:23 +08:00
|
|
|
|
|
|
|
protected:
|
2021-12-25 10:04:45 +08:00
|
|
|
virtual void _onClear() override;
|
2020-10-18 00:27:23 +08:00
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void sortBones();
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void cacheFrames(unsigned frameRate);
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
int setCacheFrame(const Matrix& globalTransformMatrix, const Transform& transform);
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void getCacheFrame(Matrix& globalTransformMatrix, Transform& transform, unsigned arrayOffset) const;
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void addBone(BoneData* value);
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void addSlot(SlotData* value);
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void addConstraint(ConstraintData* value);
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void addSkin(SkinData* value);
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void addAnimation(AnimationData* value);
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void addAction(ActionData* value, bool isDefault);
|
|
|
|
/**
|
|
|
|
* - Get a specific done data.
|
|
|
|
* @param boneName - The bone name.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 获取特定的骨骼数据。
|
|
|
|
* @param boneName - 骨骼名称。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
2021-12-27 13:52:08 +08:00
|
|
|
inline BoneData* getBone(std::string_view boneName) const { return mapFind(bones, boneName); }
|
2020-10-18 00:27:23 +08:00
|
|
|
/**
|
|
|
|
* - Get a specific slot data.
|
|
|
|
* @param slotName - The slot name.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 获取特定的插槽数据。
|
|
|
|
* @param slotName - 插槽名称。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
2021-12-27 13:52:08 +08:00
|
|
|
inline SlotData* getSlot(std::string_view slotName) const { return mapFind(slots, slotName); }
|
2020-10-18 00:27:23 +08:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
2021-12-26 23:26:34 +08:00
|
|
|
inline ConstraintData* getConstraint(std::string_view constraintName) const
|
2020-10-18 00:27:23 +08:00
|
|
|
{
|
2021-12-27 13:52:08 +08:00
|
|
|
return mapFind(constraints, constraintName);
|
2020-10-18 00:27:23 +08:00
|
|
|
}
|
|
|
|
/**
|
|
|
|
* - Get a specific skin data.
|
|
|
|
* @param skinName - The skin name.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 获取特定皮肤数据。
|
|
|
|
* @param skinName - 皮肤名称。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
2021-12-26 23:26:34 +08:00
|
|
|
inline SkinData* getSkin(std::string_view skinName) const { return mapFind(skins, skinName); }
|
2020-10-18 00:27:23 +08:00
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
2021-12-28 11:07:12 +08:00
|
|
|
MeshDisplayData* getMesh(std::string_view skinName, std::string_view slotName, std::string_view meshName) const;
|
2020-10-18 00:27:23 +08:00
|
|
|
/**
|
|
|
|
* - Get a specific animation data.
|
|
|
|
* @param animationName - The animation animationName.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 获取特定的动画数据。
|
|
|
|
* @param animationName - 动画名称。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
2021-12-26 23:26:34 +08:00
|
|
|
inline AnimationData* getAnimation(std::string_view animationName) const
|
2020-10-18 00:27:23 +08:00
|
|
|
{
|
|
|
|
return mapFind(animations, animationName);
|
|
|
|
}
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
public: // For WebAssembly.
|
2020-10-18 00:27:23 +08:00
|
|
|
int getType() const { return (int)type; }
|
|
|
|
void setType(int value) { type = (ArmatureType)value; }
|
|
|
|
|
|
|
|
Rectangle* getAABB() { return &aabb; }
|
|
|
|
const std::vector<std::string>& getAnimationNames() const { return animationNames; }
|
|
|
|
const std::vector<BoneData*>& getSortedBones() const { return sortedBones; }
|
|
|
|
const std::vector<SlotData*>& getSortedSlots() const { return sortedSlots; }
|
|
|
|
const std::vector<ActionData*>& getDefaultActions() const { return defaultActions; }
|
|
|
|
const std::vector<ActionData*>& getActions() const { return actions; }
|
|
|
|
|
|
|
|
SkinData* getDefaultSkin() const { return defaultSkin; }
|
|
|
|
void setDefaultSkin(SkinData* value) { defaultSkin = value; }
|
|
|
|
|
|
|
|
AnimationData* getDefaultAnimation() const { return defaultAnimation; }
|
|
|
|
void setDefaultAnimation(AnimationData* value) { defaultAnimation = value; }
|
|
|
|
|
|
|
|
const UserData* getUserData() const { return userData; }
|
|
|
|
void setUserData(UserData* value) { userData = value; }
|
|
|
|
|
|
|
|
const DragonBonesData* getParent() const { return parent; }
|
|
|
|
void setParent(DragonBonesData* value) { parent = value; }
|
|
|
|
};
|
|
|
|
/**
|
|
|
|
* - The bone data.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 骨骼数据。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
class BoneData : public BaseObject
|
2020-10-18 00:27:23 +08:00
|
|
|
{
|
|
|
|
BIND_CLASS_TYPE_B(BoneData);
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
bool inheritTranslation;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
bool inheritRotation;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
bool inheritScale;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
bool inheritReflection;
|
|
|
|
/**
|
|
|
|
* - The bone length.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 骨骼长度。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
float length;
|
|
|
|
/**
|
|
|
|
* - The bone name.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 骨骼名称。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
std::string name;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
Transform transform;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
UserData* userData;
|
|
|
|
/**
|
|
|
|
* - The parent bone data.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 父骨骼数据。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
BoneData* parent;
|
2021-12-25 10:04:45 +08:00
|
|
|
BoneData() : userData(nullptr) { _onClear(); }
|
|
|
|
~BoneData() { _onClear(); }
|
2020-10-18 00:27:23 +08:00
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void _onClear() override;
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
public: // For WebAssembly.
|
2020-10-18 00:27:23 +08:00
|
|
|
Transform* getTransfrom() { return &transform; }
|
|
|
|
|
|
|
|
const UserData* getUserData() const { return userData; }
|
|
|
|
void setUserData(UserData* value) { userData = value; }
|
|
|
|
|
|
|
|
const BoneData* getParent() const { return parent; }
|
|
|
|
void setParent(BoneData* value) { parent = value; }
|
|
|
|
};
|
|
|
|
/**
|
|
|
|
* - The slot data.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 插槽数据。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
class SlotData : public BaseObject
|
|
|
|
{
|
|
|
|
BIND_CLASS_TYPE_B(SlotData);
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
static ColorTransform DEFAULT_COLOR;
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
static ColorTransform* createColor();
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
BlendMode blendMode;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
int displayIndex;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
int zOrder;
|
|
|
|
/**
|
|
|
|
* - The slot name.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 插槽名称。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
std::string name;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
ColorTransform* color;
|
|
|
|
/**
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
UserData* userData;
|
|
|
|
/**
|
|
|
|
* - The parent bone data.
|
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language en_US
|
|
|
|
*/
|
|
|
|
/**
|
2021-12-24 21:11:44 +08:00
|
|
|
* - 父骨骼数据。
|
2020-10-18 00:27:23 +08:00
|
|
|
* @version DragonBones 3.0
|
|
|
|
* @language zh_CN
|
|
|
|
*/
|
|
|
|
BoneData* parent;
|
2021-12-25 10:04:45 +08:00
|
|
|
SlotData() : color(nullptr), userData(nullptr) { _onClear(); }
|
|
|
|
~SlotData() { _onClear(); }
|
2020-10-18 00:27:23 +08:00
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void _onClear() override;
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
public: // For WebAssembly.
|
2020-10-18 00:27:23 +08:00
|
|
|
static ColorTransform* getDefaultColor() { return &DEFAULT_COLOR; }
|
|
|
|
|
|
|
|
int getBlendMode() const { return (int)blendMode; }
|
|
|
|
void setBlendMode(int value) { blendMode = (BlendMode)value; }
|
|
|
|
|
|
|
|
ColorTransform* getColor() const { return color; }
|
|
|
|
void setColor(ColorTransform* value) { color = value; }
|
|
|
|
|
|
|
|
const BoneData* getParent() const { return parent; }
|
|
|
|
void setParent(BoneData* value) { parent = value; }
|
|
|
|
|
|
|
|
const UserData* getUserData() const { return userData; }
|
|
|
|
void setUserData(UserData* value) { userData = value; }
|
|
|
|
};
|
|
|
|
|
|
|
|
DRAGONBONES_NAMESPACE_END
|
2021-12-25 10:04:45 +08:00
|
|
|
#endif // DRAGONBONES_ARMATURE_DATA_H
|