You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
152 lines
6.4 KiB
152 lines
6.4 KiB
/******************************************************************************
|
|
* 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<AttachmentVertices *>(vertices);
|
|
}
|
|
|
|
static uint16_t quadTriangles[6] = {0, 1, 2, 2, 3, 0};
|
|
|
|
static void setAttachmentVertices(RegionAttachment *attachment) {
|
|
auto *region = static_cast<AtlasRegion *>(attachment->getRendererObject());
|
|
auto *attachmentVertices = new AttachmentVertices(static_cast<middleware::Texture2D *>(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<AtlasRegion *>(attachment->getRendererObject());
|
|
auto *attachmentVertices = new AttachmentVertices(static_cast<middleware::Texture2D *>(region->page->getRendererObject()),
|
|
static_cast<int32_t>(attachment->getWorldVerticesLength() >> 1), attachment->getTriangles().buffer(), static_cast<int32_t>(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<RegionAttachment *>(attachment));
|
|
} else if (attachment->getRTTI().isExactly(MeshAttachment::rtti)) {
|
|
setAttachmentVertices(dynamic_cast<MeshAttachment *>(attachment));
|
|
}
|
|
}
|
|
|
|
uint32_t wrap(TextureWrap wrap) {
|
|
return static_cast<uint32_t>(wrap);
|
|
}
|
|
|
|
uint32_t filter(TextureFilter filter) {
|
|
return static_cast<uint32_t>(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<middleware::Texture2D *>(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<char *>(malloc(sizeof(unsigned char) * data.getSize()));
|
|
memcpy(ret, reinterpret_cast<char *>(data.getBytes()), data.getSize());
|
|
*length = static_cast<int>(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);
|
|
}
|
|
|