diff options
| author | chai <215380520@qq.com> | 2024-05-19 16:05:58 +0800 |
|---|---|---|
| committer | chai <215380520@qq.com> | 2024-05-19 16:05:58 +0800 |
| commit | 8e13e7e2874adc8982e16d1d2ed2e28d7480b45f (patch) | |
| tree | 63ef85c460288891f5a593d69afeca16cba050b3 /Thronefall_1_57/Decompile/I2.Loc/TranslationJob_POST.cs | |
| parent | c5f145786f4c6d2fe4bea831dfc16e52228920a5 (diff) | |
+1.57
Diffstat (limited to 'Thronefall_1_57/Decompile/I2.Loc/TranslationJob_POST.cs')
| -rw-r--r-- | Thronefall_1_57/Decompile/I2.Loc/TranslationJob_POST.cs | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/Thronefall_1_57/Decompile/I2.Loc/TranslationJob_POST.cs b/Thronefall_1_57/Decompile/I2.Loc/TranslationJob_POST.cs new file mode 100644 index 0000000..561cb90 --- /dev/null +++ b/Thronefall_1_57/Decompile/I2.Loc/TranslationJob_POST.cs @@ -0,0 +1,51 @@ +using System.Collections.Generic; +using System.Text; +using UnityEngine; +using UnityEngine.Networking; + +namespace I2.Loc; + +public class TranslationJob_POST : TranslationJob_WWW +{ + private Dictionary<string, TranslationQuery> _requests; + + private GoogleTranslation.fnOnTranslationReady _OnTranslationReady; + + public TranslationJob_POST(Dictionary<string, TranslationQuery> requests, GoogleTranslation.fnOnTranslationReady OnTranslationReady) + { + _requests = requests; + _OnTranslationReady = OnTranslationReady; + List<string> list = GoogleTranslation.ConvertTranslationRequest(requests, encodeGET: false); + WWWForm wWWForm = new WWWForm(); + wWWForm.AddField("action", "Translate"); + wWWForm.AddField("list", list[0]); + www = UnityWebRequest.Post(LocalizationManager.GetWebServiceURL(), wWWForm); + I2Utils.SendWebRequest(www); + } + + public override eJobState GetState() + { + if (www != null && www.isDone) + { + ProcessResult(www.downloadHandler.data, www.error); + www.Dispose(); + www = null; + } + return mJobState; + } + + public void ProcessResult(byte[] bytes, string errorMsg) + { + if (!string.IsNullOrEmpty(errorMsg)) + { + mJobState = eJobState.Failed; + return; + } + errorMsg = GoogleTranslation.ParseTranslationResult(Encoding.UTF8.GetString(bytes, 0, bytes.Length), _requests); + if (_OnTranslationReady != null) + { + _OnTranslationReady(_requests, errorMsg); + } + mJobState = eJobState.Succeeded; + } +} |
