From 8e13e7e2874adc8982e16d1d2ed2e28d7480b45f Mon Sep 17 00:00:00 2001 From: chai <215380520@qq.com> Date: Sun, 19 May 2024 16:05:58 +0800 Subject: +1.57 --- .../I2.Loc/LocalizeTarget_UnityUI_Image.cs | 70 ++++++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 Thronefall_1_57/Decompile/I2.Loc/LocalizeTarget_UnityUI_Image.cs (limited to 'Thronefall_1_57/Decompile/I2.Loc/LocalizeTarget_UnityUI_Image.cs') diff --git a/Thronefall_1_57/Decompile/I2.Loc/LocalizeTarget_UnityUI_Image.cs b/Thronefall_1_57/Decompile/I2.Loc/LocalizeTarget_UnityUI_Image.cs new file mode 100644 index 0000000..4270743 --- /dev/null +++ b/Thronefall_1_57/Decompile/I2.Loc/LocalizeTarget_UnityUI_Image.cs @@ -0,0 +1,70 @@ +using UnityEngine; +using UnityEngine.UI; + +namespace I2.Loc; + +public class LocalizeTarget_UnityUI_Image : LocalizeTarget +{ + static LocalizeTarget_UnityUI_Image() + { + AutoRegister(); + } + + [RuntimeInitializeOnLoadMethod(RuntimeInitializeLoadType.BeforeSceneLoad)] + private static void AutoRegister() + { + LocalizationManager.RegisterTarget(new LocalizeTargetDesc_Type + { + Name = "Image", + Priority = 100 + }); + } + + public override bool CanUseSecondaryTerm() + { + return false; + } + + public override bool AllowMainTermToBeRTL() + { + return false; + } + + public override bool AllowSecondTermToBeRTL() + { + return false; + } + + public override eTermType GetPrimaryTermType(Localize cmp) + { + if (!(mTarget.sprite == null)) + { + return eTermType.Sprite; + } + return eTermType.Texture; + } + + public override eTermType GetSecondaryTermType(Localize cmp) + { + return eTermType.Text; + } + + public override void GetFinalTerms(Localize cmp, string Main, string Secondary, out string primaryTerm, out string secondaryTerm) + { + primaryTerm = (mTarget.mainTexture ? mTarget.mainTexture.name : ""); + if (mTarget.sprite != null && mTarget.sprite.name != primaryTerm) + { + primaryTerm = primaryTerm + "." + mTarget.sprite.name; + } + secondaryTerm = null; + } + + public override void DoLocalize(Localize cmp, string mainTranslation, string secondaryTranslation) + { + Sprite sprite = mTarget.sprite; + if (sprite == null || sprite.name != mainTranslation) + { + mTarget.sprite = cmp.FindTranslatedObject(mainTranslation); + } + } +} -- cgit v1.1-26-g67d0