/****************************************************************************** * Spine Runtimes License Agreement * Last updated September 24, 2021. Replaces all prior versions. * * Copyright (c) 2013-2021, 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. *****************************************************************************/ #include "SpinePluginPrivatePCH.h" #include "spine/spine.h" #include #include #include #define LOCTEXT_NAMESPACE "Spine" using namespace spine; #if WITH_EDITORONLY_DATA void USpineAtlasAsset::SetAtlasFileName(const FName &AtlasFileName) { importData->UpdateFilenameOnly(AtlasFileName.ToString()); TArray files; importData->ExtractFilenames(files); if (files.Num() > 0) atlasFileName = FName(*files[0]); } void USpineAtlasAsset::PostInitProperties() { if (!HasAnyFlags(RF_ClassDefaultObject)) importData = NewObject(this, TEXT("AssetImportData")); Super::PostInitProperties(); } void USpineAtlasAsset::GetAssetRegistryTags(TArray &OutTags) const { if (importData) { OutTags.Add(FAssetRegistryTag(SourceFileTagName(), importData->GetSourceData().ToJson(), FAssetRegistryTag::TT_Hidden)); } Super::GetAssetRegistryTags(OutTags); } void USpineAtlasAsset::Serialize(FArchive &Ar) { Super::Serialize(Ar); if (Ar.IsLoading() && Ar.UE4Ver() < VER_UE4_ASSET_IMPORT_DATA_AS_JSON && !importData) importData = NewObject(this, TEXT("AssetImportData")); } #endif FName USpineAtlasAsset::GetAtlasFileName() const { #if WITH_EDITORONLY_DATA TArray files; if (importData) importData->ExtractFilenames(files); if (files.Num() > 0) return FName(*files[0]); else return atlasFileName; #else return atlasFileName; #endif } void USpineAtlasAsset::SetRawData(const FString &RawData) { this->rawData = RawData; if (atlas) { delete atlas; atlas = nullptr; } } void USpineAtlasAsset::BeginDestroy() { if (atlas) { delete atlas; atlas = nullptr; } Super::BeginDestroy(); } Atlas *USpineAtlasAsset::GetAtlas() { if (!atlas) { if (atlas) { delete atlas; atlas = nullptr; } std::string t = TCHAR_TO_UTF8(*rawData); atlas = new (__FILE__, __LINE__) Atlas(t.c_str(), strlen(t.c_str()), "", nullptr); Vector &pages = atlas->getPages(); for (size_t i = 0, n = pages.size(), j = 0; i < n; i++) { AtlasPage *page = pages[i]; if (atlasPages.Num() > 0 && atlasPages.Num() > (int32) i) page->setRendererObject(atlasPages[j++]); } } return this->atlas; } #undef LOCTEXT_NAMESPACE