/****************************************************************************** * Spine Runtimes License Agreement * Last updated May 1, 2019. Replaces all prior versions. * * Copyright (c) 2013-2019, 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. * * THIS SOFTWARE IS 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 THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *****************************************************************************/ #include "spine-creator-support/spine-cocos2dx.h" #include "base/Data.h" #include "middleware-adapter.h" #include "platform/FileUtils.h" #include "spine-creator-support/AttachmentVertices.h" namespace spine { static CustomTextureLoader customTextureLoader = nullptr; void spAtlasPage_setCustomTextureLoader(CustomTextureLoader texLoader) { customTextureLoader = texLoader; } static SpineObjectDisposeCallback spineObjectDisposeCallback = nullptr; void setSpineObjectDisposeCallback(SpineObjectDisposeCallback callback) { spineObjectDisposeCallback = callback; } } // namespace spine USING_NS_MW; // NOLINT(google-build-using-namespace) using namespace cc; // NOLINT(google-build-using-namespace) using namespace spine; // NOLINT(google-build-using-namespace) static void deleteAttachmentVertices(void *vertices) { delete static_cast(vertices); } static uint16_t quadTriangles[6] = {0, 1, 2, 2, 3, 0}; static void setAttachmentVertices(RegionAttachment *attachment) { auto *region = static_cast(attachment->getRendererObject()); auto *attachmentVertices = new AttachmentVertices(static_cast(region->page->getRendererObject()), 4, quadTriangles, 6); V3F_T2F_C4B *vertices = attachmentVertices->_triangles->verts; for (int i = 0, ii = 0; i < 4; ++i, ii += 2) { vertices[i].texCoord.u = attachment->getUVs()[ii]; vertices[i].texCoord.v = attachment->getUVs()[ii + 1]; } attachment->setRendererObject(attachmentVertices, deleteAttachmentVertices); } static void setAttachmentVertices(MeshAttachment *attachment) { auto *region = static_cast(attachment->getRendererObject()); auto *attachmentVertices = new AttachmentVertices(static_cast(region->page->getRendererObject()), static_cast(attachment->getWorldVerticesLength() >> 1), attachment->getTriangles().buffer(), static_cast(attachment->getTriangles().size())); V3F_T2F_C4B *vertices = attachmentVertices->_triangles->verts; for (size_t i = 0, ii = 0, nn = attachment->getWorldVerticesLength(); ii < nn; ++i, ii += 2) { vertices[i].texCoord.u = attachment->getUVs()[ii]; vertices[i].texCoord.v = attachment->getUVs()[ii + 1]; } attachment->setRendererObject(attachmentVertices, deleteAttachmentVertices); } Cocos2dAtlasAttachmentLoader::Cocos2dAtlasAttachmentLoader(Atlas *atlas) : AtlasAttachmentLoader(atlas) { } Cocos2dAtlasAttachmentLoader::~Cocos2dAtlasAttachmentLoader() = default; void Cocos2dAtlasAttachmentLoader::configureAttachment(Attachment *attachment) { if (attachment->getRTTI().isExactly(RegionAttachment::rtti)) { setAttachmentVertices(dynamic_cast(attachment)); } else if (attachment->getRTTI().isExactly(MeshAttachment::rtti)) { setAttachmentVertices(dynamic_cast(attachment)); } } uint32_t wrap(TextureWrap wrap) { return static_cast(wrap); } uint32_t filter(TextureFilter filter) { return static_cast(filter); } Cocos2dTextureLoader::Cocos2dTextureLoader() = default; Cocos2dTextureLoader::~Cocos2dTextureLoader() = default; void Cocos2dTextureLoader::load(AtlasPage &page, const spine::String &path) { middleware::Texture2D *texture = nullptr; if (spine::customTextureLoader) { texture = spine::customTextureLoader(path.buffer()); } CC_ASSERT_NOT_NULL(texture); if (texture) { texture->addRef(); middleware::Texture2D::TexParams textureParams = {filter(page.minFilter), filter(page.magFilter), wrap(page.uWrap), wrap(page.vWrap)}; texture->setTexParameters(textureParams); page.setRendererObject(texture); page.width = texture->getPixelsWide(); page.height = texture->getPixelsHigh(); } } void Cocos2dTextureLoader::unload(void *texture) { if (texture) { (static_cast(texture))->release(); } } Cocos2dExtension::Cocos2dExtension() = default; Cocos2dExtension::~Cocos2dExtension() = default; char *Cocos2dExtension::_readFile(const spine::String &path, int *length) { *length = 0; Data data = FileUtils::getInstance()->getDataFromFile(FileUtils::getInstance()->fullPathForFilename(path.buffer())); if (data.isNull()) return nullptr; char *ret = static_cast(malloc(sizeof(unsigned char) * data.getSize())); memcpy(ret, reinterpret_cast(data.getBytes()), data.getSize()); *length = static_cast(data.getSize()); return ret; } SpineExtension *spine::getDefaultExtension() { return new Cocos2dExtension(); } void Cocos2dExtension::_free(void *mem, const char *file, int line) { spineObjectDisposeCallback(mem); DefaultSpineExtension::_free(mem, file, line); }