/****************************************************************************** * Spine Runtimes License Agreement * Last updated April 5, 2025. Replaces all prior versions. * * Copyright (c) 2013-2025, Esoteric Software LLC * * Integration of the Spine Runtimes into software or otherwise creating * derivative works of the Spine Runtimes is permitted under the terms and * conditions of Section 2 of the Spine Editor License Agreement: * http://esotericsoftware.com/spine-editor-license * * Otherwise, it is permitted to integrate the Spine Runtimes into software * or otherwise create derivative works of the Spine Runtimes (collectively, * "Products"), provided that each user of the Products must obtain their own * Spine Editor license and redistribution of the Products in any form must * include this license and copyright notice. * * THE SPINE RUNTIMES ARE PROVIDED BY ESOTERIC SOFTWARE LLC "AS IS" AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL ESOTERIC SOFTWARE LLC BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, * BUSINESS INTERRUPTION, OR LOSS OF USE, DATA, OR PROFITS) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THE SPINE RUNTIMES, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *****************************************************************************/ #ifndef Spine_RegionAttachment_h #define Spine_RegionAttachment_h #include #include #include #include #include #include namespace spine { class Bone; class Slot; /// Attachment that displays a texture region. class SP_API RegionAttachment : public Attachment { friend class SkeletonBinary; friend class SkeletonJson; friend class AtlasAttachmentLoader; RTTI_DECL public: explicit RegionAttachment(const String &name); virtual ~RegionAttachment(); void updateRegion(); /// Transforms the attachment's four vertices to world coordinates. /// @param slot The parent slot. /// @param worldVertices The output world vertices. Must have a length greater than or equal to offset + 8. /// @param offset The worldVertices index to begin writing values. /// @param stride The number of worldVertices entries between the value pairs written. void computeWorldVertices(Slot &slot, float *worldVertices, size_t offset, size_t stride = 2); void computeWorldVertices(Slot &slot, Array &worldVertices, size_t offset, size_t stride = 2); float getX(); void setX(float inValue); float getY(); void setY(float inValue); float getRotation(); void setRotation(float inValue); float getScaleX(); void setScaleX(float inValue); float getScaleY(); void setScaleY(float inValue); float getWidth(); void setWidth(float inValue); float getHeight(); void setHeight(float inValue); Color &getColor(); const String &getPath(); void setPath(const String &inValue); TextureRegion *getRegion(); void setRegion(TextureRegion *region); Sequence *getSequence(); void setSequence(Sequence *sequence); Array &getOffset(); Array &getUVs(); virtual Attachment ©() override; private: static const int BLX; static const int BLY; static const int ULX; static const int ULY; static const int URX; static const int URY; static const int BRX; static const int BRY; TextureRegion *_region; String _path; float _x, _y, _scaleX, _scaleY, _rotation, _width, _height; Array _uvs; Array _offset; Color _color; Sequence *_sequence; }; } #endif /* Spine_RegionAttachment_h */