From 6df7b920799bf772655db38b9a176a12b0591cb0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=8D=97=E6=B2=A2=E5=93=8D=E4=B9=9F?= <72963826+Hibiya615@users.noreply.github.com> Date: Mon, 3 Mar 2025 02:57:19 +0800 Subject: [PATCH] =?UTF-8?q?=E5=BB=BA=E7=AB=8BFate=E6=A8=A1=E6=9D=BF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Fate/Archaeotania.cs | 238 +++++++++++++++++++ Fate/Chi.cs | 328 ++++++++++++++++++++++++++ Fate/Daivadipa.cs | 319 +++++++++++++++++++++++++ Fate/Formidable.cs | 311 +++++++++++++++++++++++++ Fate/Mica_the_MagicalMu.cs | 189 +++++++++++++++ Fate/Ttokrrone.cs | 464 +++++++++++++++++++++++++++++++++++++ 6 files changed, 1849 insertions(+) create mode 100644 Fate/Archaeotania.cs create mode 100644 Fate/Chi.cs create mode 100644 Fate/Daivadipa.cs create mode 100644 Fate/Formidable.cs create mode 100644 Fate/Mica_the_MagicalMu.cs create mode 100644 Fate/Ttokrrone.cs diff --git a/Fate/Archaeotania.cs b/Fate/Archaeotania.cs new file mode 100644 index 0000000..6bf6efc --- /dev/null +++ b/Fate/Archaeotania.cs @@ -0,0 +1,238 @@ +using System; +using System.ComponentModel; +using System.Linq; +using System.Numerics; +using System.Collections.Generic; +using System.Text.RegularExpressions; +using Dalamud.Game.ClientState.Objects.Types; +using Newtonsoft.Json; +using Dalamud.Utility.Numerics; +using KodakkuAssist.Script; +using KodakkuAssist.Module.GameEvent; +using KodakkuAssist.Module.Draw; +using ECommons; +using ECommons.DalamudServices; +using ECommons.GameFunctions; +using ECommons.MathHelpers; + +namespace TheHead_theTail_theWholeDamnedThing; + +[ScriptType(guid: "f11c3069-d163-41dd-904e-b016cfcf089c", name: "灾厄的古塔尼亚之深海讨伐战", territorys: [818], + version: "0.0.0.1", author: "Tetora", note: noteStr)] + +public class Archaeotania +{ + const string noteStr = + """ + v0.0.0.1: + LV80 特殊Fate 绘制 + 灾厄的古塔尼亚之深海讨伐战 + """; + + // Todo. + // 龙卷前进方向线 + + [ScriptMethod(name: "迷失连线", eventType: EventTypeEnum.AddCombatant, eventCondition: ["DataId:regex:^758[67]$"])] + public void 迷失连线(Event @event, ScriptAccessory accessory) + { + // Data ID 7586: 迷失少女 ;7587:迷失者 + accessory.Method.TextInfo("迷失出现", duration: 5000, true); + accessory.Method.TTS("迷失出现"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "迷失连线"; + dp.Owner = accessory.Data.Me; + dp.Color = accessory.Data.DefaultSafeColor; + dp.ScaleMode |= ScaleMode.YByDistance; + dp.TargetObject = @event.SourceId(); + dp.Scale = new(1); + dp.DestoryAt = 900000; + accessory.Method.SendDraw(DrawModeEnum.Imgui, DrawTypeEnum.Displacement, dp); + } + + [ScriptMethod(name: "迷失连线销毁", eventType: EventTypeEnum.Death, eventCondition: ["DataId:regex:^758[67]$"], userControl: false)] + public void 迷失连线销毁(Event @event, ScriptAccessory accessory) + { + accessory.Method.RemoveDraw("迷失连线"); + } + + [ScriptMethod(name: "文明毁灭(直线)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^(16441|17089)$"])] + public void 文明毁灭(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "文明毁灭"; + dp.Scale = new (15, 62f); + dp.Owner = @event.SourceId(); + dp.Color = accessory.Data.DefaultDangerColor; + dp.DestoryAt = 4000; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Rect, dp); + } + + [ScriptMethod(name: "巨浪 击退连线", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:16452"])] + public void 巨浪连线(Event @event, ScriptAccessory accessory) + { + accessory.Method.TextInfo("靠近水柱击退(百分比真伤)", duration: 8200, true); + accessory.Method.TTS("靠近水柱击退"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "巨浪连线"; + dp.Owner = accessory.Data.Me; + dp.Color = accessory.Data.DefaultSafeColor; + dp.ScaleMode |= ScaleMode.YByDistance; + dp.TargetObject = @event.SourceId(); + dp.Scale = new(1); + dp.DestoryAt = 8200; + accessory.Method.SendDraw(DrawModeEnum.Imgui, DrawTypeEnum.Displacement, dp); + } + + [ScriptMethod(name: "龙卷_暴风圈", eventType: EventTypeEnum.AddCombatant, eventCondition: ["NPCId:8935"])] + public void 龙卷(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "龙卷"; + dp.Color = new Vector4(1f, 0f, 0f, 1.2f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(5f); + dp.DestoryAt = long.MaxValue; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp); + } + + [ScriptMethod(name: "龙卷销毁", eventType: EventTypeEnum.RemoveCombatant, eventCondition: ["NPCId:8935"], userControl: false)] + public void 龙卷销毁(Event @event, ScriptAccessory accessory) + { + accessory.Method.RemoveDraw("龙卷"); + } + +} + + + +public static class EventExtensions +{ + private static bool ParseHexId(string? idStr, out uint id) + { + id = 0; + if (string.IsNullOrEmpty(idStr)) return false; + try + { + var idStr2 = idStr.Replace("0x", ""); + id = uint.Parse(idStr2, System.Globalization.NumberStyles.HexNumber); + return true; + } + catch (Exception) + { + return false; + } + } + + public static uint ActionId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["ActionId"]); + } + + public static uint SourceId(this Event @event) + { + return ParseHexId(@event["SourceId"], out var id) ? id : 0; + } + + public static uint SourceDataId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceDataId"]); + } + + public static uint Command(this Event @event) + { + return ParseHexId(@event["Command"], out var cid) ? cid : 0; + } + + public static uint DurationMilliseconds(this Event @event) + { + return JsonConvert.DeserializeObject(@event["DurationMilliseconds"]); + } + + public static float SourceRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceRotation"]); + } + + public static float TargetRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetRotation"]); + } + + public static byte Index(this Event @event) + { + return (byte)(ParseHexId(@event["Index"], out var index) ? index : 0); + } + + public static uint State(this Event @event) + { + return ParseHexId(@event["State"], out var state) ? state : 0; + } + + public static string SourceName(this Event @event) + { + return @event["SourceName"]; + } + + public static string TargetName(this Event @event) + { + return @event["TargetName"]; + } + + public static uint TargetId(this Event @event) + { + return ParseHexId(@event["TargetId"], out var id) ? id : 0; + } + + public static Vector3 SourcePosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourcePosition"]); + } + + public static Vector3 TargetPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetPosition"]); + } + + public static Vector3 EffectPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["EffectPosition"]); + } + + public static uint DirectorId(this Event @event) + { + return ParseHexId(@event["DirectorId"], out var id) ? id : 0; + } + + public static uint StatusId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StatusId"]); + } + + public static uint StackCount(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StackCount"]); + } + + public static uint Param(this Event @event) + { + return JsonConvert.DeserializeObject(@event["Param"]); + } +} + + +public static class Extensions +{ + public static void TTS(this ScriptAccessory accessory, string text, bool isTTS, bool isDRTTS) + { + if (isDRTTS) + { + accessory.Method.SendChat($"/pdr tts {text}"); + } + else if (isTTS) + { + accessory.Method.TTS(text); + } + } +} diff --git a/Fate/Chi.cs b/Fate/Chi.cs new file mode 100644 index 0000000..5dbbaab --- /dev/null +++ b/Fate/Chi.cs @@ -0,0 +1,328 @@ +using System; +using System.ComponentModel; +using System.Linq; +using System.Numerics; +using System.Collections.Generic; +using System.Text.RegularExpressions; +using Dalamud.Game.ClientState.Objects.Types; +using Newtonsoft.Json; +using Dalamud.Utility.Numerics; +using KodakkuAssist.Script; +using KodakkuAssist.Module.GameEvent; +using KodakkuAssist.Module.Draw; +using ECommons; +using ECommons.DalamudServices; +using ECommons.GameFunctions; +using ECommons.MathHelpers; + +namespace Omicron_Recall_Killing_Order; + +[ScriptType(guid: "b73d07ef-aa90-45a9-ab4b-fc3ccce8791b", name: "侵略兵器召回指令:破坏侵略兵器希", territorys: [960], + version: "0.0.0.1", author: "Tetora", note: noteStr)] + +public class Chi +{ + const string noteStr = + """ + v0.0.0.1: + LV90 特殊Fate 绘制 + 侵略兵器召回指令:破坏侵略兵器希 + """; + + [ScriptMethod(name: "迷失连线", eventType: EventTypeEnum.AddCombatant, eventCondition: ["DataId:regex:^758[67]$"])] + public void 迷失连线(Event @event, ScriptAccessory accessory) + { + // Data ID 7586: 迷失少女 ;7587:迷失者 + accessory.Method.TextInfo("迷失出现", duration: 5000, true); + accessory.Method.TTS("迷失出现"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "迷失连线"; + dp.Owner = accessory.Data.Me; + dp.Color = accessory.Data.DefaultSafeColor; + dp.ScaleMode |= ScaleMode.YByDistance; + dp.TargetObject = @event.SourceId(); + dp.Scale = new(1); + dp.DestoryAt = 900000; + accessory.Method.SendDraw(DrawModeEnum.Imgui, DrawTypeEnum.Displacement, dp); + } + + [ScriptMethod(name: "迷失连线销毁", eventType: EventTypeEnum.Death, eventCondition: ["DataId:regex:^758[67]$"], userControl: false)] + public void 迷失连线销毁(Event @event, ScriptAccessory accessory) + { + accessory.Method.RemoveDraw("迷失连线"); + } + + [ScriptMethod(name: "终端攻击(月环)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^(25172|2595[356])$"])] + public void 月环(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "月环"; + dp.Color = new Vector4(1f, 1f, 0f, 0.8f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(60f); + dp.InnerScale = new Vector2(16f); + dp.Radian = float.Pi * 2; + dp.DestoryAt = @event.ActionId() == 25953 ? 4700 : 7700; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Donut, dp); + } + + [ScriptMethod(name: "终端攻击(直线)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^(25173|2595[478])$"])] + public void 直线(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "直线"; + dp.Owner = @event.SourceId(); + dp.Color = new Vector4(1f, 1f, 0f, 0.8f); + dp.Scale = new(32f, 120f); + dp.DestoryAt = @event.ActionId() == 25954 ? 4700 : 7700; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Straight, dp); + } + + [ScriptMethod(name: "前方扫荡 & 后方扫射", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^(25959|2596[023]|2652[34])$"])] + public void 半场扇形(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + + dp.Color = new Vector4(1f, 1f, 0f, 0.8f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(45); + dp.Radian = 180f.DegToRad(); + dp.DestoryAt = 5700; + + switch (@event.ActionId()) + { + case 26523: + case 25959: + case 25960: // 前方扫荡·零式后方扫射 + dp.Name = "前方扫荡"; + dp.Rotation = 0f.DegToRad(); + break; + + case 26524: + case 25962: + case 25963: // 后方扫射·零式前方扫荡 + dp.Name = "后方扫射"; + dp.Rotation = 180f.DegToRad(); + break; + } + + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Fan, dp); + } + + [ScriptMethod(name: "零式前方扫荡 & 后方扫射", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^(2595[5-8]|2596[03])$"])] + public void 零式半场扇形(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + + dp.Color = new Vector4(1f, 1f, 0f, 0.8f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(45); + dp.Radian = 180f.DegToRad(); + + switch (@event.ActionId()) + { + case 25955: //终端攻击·零式前方扫荡 直接显示 + case 25957: + dp.Name = "前方扫荡"; + dp.Rotation = 0f.DegToRad(); + dp.DestoryAt = 12200; + break; + + case 25956: //终端攻击·零式后方扫射 直接显示 + case 25958: + dp.Name = "后方扫射"; + dp.Rotation = 180f.DegToRad(); + dp.DestoryAt = 12200; + break; + + // 画第二刀 方向相反 , 第一刀跟前面的普通画一起了 + case 25960: //前方扫荡·零式后方扫荡 + dp.Name = "后方扫射"; + dp.Rotation = 180f.DegToRad(); + dp.Delay = 5800; + dp.DestoryAt = 4400; + break; + + case 25963: //后方扫射·零式前方扫荡 + dp.Name = "前方扫荡"; + dp.Rotation = 0f.DegToRad(); + dp.Delay = 5800; + dp.DestoryAt = 4400; + break; + } + + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Fan, dp); + } + + [ScriptMethod(name: "地下贯通爆弹(三穿一)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:25101"])] + public void 地下贯通爆弹1(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "地下贯通爆弹1"; + dp.Owner = @event.SourceId(); + dp.Color = new Vector4(1f, 0f, 0f, 1f); + dp.Scale = new(20f, 20f); + dp.Delay = 7700; + dp.DestoryAt = 2000; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Straight, dp); + } + + [ScriptMethod(name: "地下贯通爆弹(随机)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:25976"])] + public void 地下贯通爆弹2(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "地下贯通爆弹2"; + dp.Owner = @event.SourceId(); + dp.Color = new Vector4(1f, 0f, 0f, 1f); + dp.Scale = new(20f, 20f); + dp.Delay = 9800; + dp.DestoryAt = 2000; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Straight, dp); + } + + [ScriptMethod(name: "地下贯通爆弹(随机)提前一炸显示", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:25976"])] + public void 地下贯通爆弹3(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "地下贯通爆弹3"; + dp.Owner = @event.SourceId(); + dp.Color = new Vector4(1f, 1f, 0f, 0.2f); + dp.Scale = new(20f, 20f); + dp.Delay = 8800; + dp.DestoryAt = 1000; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Straight, dp); + } +} + + + +public static class EventExtensions +{ + private static bool ParseHexId(string? idStr, out uint id) + { + id = 0; + if (string.IsNullOrEmpty(idStr)) return false; + try + { + var idStr2 = idStr.Replace("0x", ""); + id = uint.Parse(idStr2, System.Globalization.NumberStyles.HexNumber); + return true; + } + catch (Exception) + { + return false; + } + } + + public static uint ActionId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["ActionId"]); + } + + public static uint SourceId(this Event @event) + { + return ParseHexId(@event["SourceId"], out var id) ? id : 0; + } + + public static uint SourceDataId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceDataId"]); + } + + public static uint Command(this Event @event) + { + return ParseHexId(@event["Command"], out var cid) ? cid : 0; + } + + public static uint DurationMilliseconds(this Event @event) + { + return JsonConvert.DeserializeObject(@event["DurationMilliseconds"]); + } + + public static float SourceRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceRotation"]); + } + + public static float TargetRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetRotation"]); + } + + public static byte Index(this Event @event) + { + return (byte)(ParseHexId(@event["Index"], out var index) ? index : 0); + } + + public static uint State(this Event @event) + { + return ParseHexId(@event["State"], out var state) ? state : 0; + } + + public static string SourceName(this Event @event) + { + return @event["SourceName"]; + } + + public static string TargetName(this Event @event) + { + return @event["TargetName"]; + } + + public static uint TargetId(this Event @event) + { + return ParseHexId(@event["TargetId"], out var id) ? id : 0; + } + + public static Vector3 SourcePosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourcePosition"]); + } + + public static Vector3 TargetPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetPosition"]); + } + + public static Vector3 EffectPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["EffectPosition"]); + } + + public static uint DirectorId(this Event @event) + { + return ParseHexId(@event["DirectorId"], out var id) ? id : 0; + } + + public static uint StatusId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StatusId"]); + } + + public static uint StackCount(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StackCount"]); + } + + public static uint Param(this Event @event) + { + return JsonConvert.DeserializeObject(@event["Param"]); + } +} + + +public static class Extensions +{ + public static void TTS(this ScriptAccessory accessory, string text, bool isTTS, bool isDRTTS) + { + if (isDRTTS) + { + accessory.Method.SendChat($"/pdr tts {text}"); + } + else if (isTTS) + { + accessory.Method.TTS(text); + } + } +} diff --git a/Fate/Daivadipa.cs b/Fate/Daivadipa.cs new file mode 100644 index 0000000..32d9234 --- /dev/null +++ b/Fate/Daivadipa.cs @@ -0,0 +1,319 @@ +using System; +using System.ComponentModel; +using System.Linq; +using System.Numerics; +using System.Collections.Generic; +using System.Text.RegularExpressions; +using Dalamud.Game.ClientState.Objects.Types; +using Newtonsoft.Json; +using Dalamud.Utility.Numerics; +using KodakkuAssist.Script; +using KodakkuAssist.Module.GameEvent; +using KodakkuAssist.Module.Draw; +using ECommons; +using ECommons.DalamudServices; +using ECommons.GameFunctions; +using ECommons.MathHelpers; + +namespace DevoutPilgrimsVSDaivadipa; + +[ScriptType(guid: "da82aeb0-9635-4f13-a1c1-39a0c859f596", name: "兽道诸神信仰:伪神降临", territorys: [957], + version: "0.0.0.1", author: "Tetora", note: noteStr)] + +public class Daivadipa +{ + const string noteStr = + """ + v0.0.0.1: + LV90 特殊Fate 绘制 + 兽道诸神信仰:伪神降临 + """; + + [ScriptMethod(name: "迷失连线", eventType: EventTypeEnum.AddCombatant, eventCondition: ["DataId:regex:^758[67]$"])] + public void 迷失连线(Event @event, ScriptAccessory accessory) + { + // Data ID 7586: 迷失少女 ;7587:迷失者 + accessory.Method.TextInfo("迷失出现", duration: 5000, true); + accessory.Method.TTS("迷失出现"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "迷失连线"; + dp.Owner = accessory.Data.Me; + dp.Color = accessory.Data.DefaultSafeColor; + dp.ScaleMode |= ScaleMode.YByDistance; + dp.TargetObject = @event.SourceId(); + dp.Scale = new(1); + dp.DestoryAt = 900000; + accessory.Method.SendDraw(DrawModeEnum.Imgui, DrawTypeEnum.Displacement, dp); + } + + [ScriptMethod(name: "迷失连线销毁", eventType: EventTypeEnum.Death, eventCondition: ["DataId:regex:^758[67]$"], userControl: false)] + public void 迷失连线销毁(Event @event, ScriptAccessory accessory) + { + accessory.Method.RemoveDraw("迷失连线"); + } + + [ScriptMethod(name: "操焰仪 弹窗提示", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^2649[89]$"])] + public void 操焰仪提示(Event @event, ScriptAccessory accessory) + { + switch (@event.ActionId()) + { + case 26498: + accessory.Method.TextInfo("先蓝色安全", duration: 5000, false); + break; + + case 26499: + accessory.Method.TextInfo("先红色安全", duration: 5000, true); + break; + } + } + + [ScriptMethod(name: "左侧三叉戟 & 右侧圣战斧", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^2650[89]$"])] + public void 半场扇形(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + + dp.Color = accessory.Data.DefaultDangerColor; + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(65); + dp.Radian = 180f.DegToRad(); + dp.DestoryAt = 6700; + + switch (@event.ActionId()) + { + case 26508: + dp.Name = "左侧三叉戟"; + dp.Rotation = 90f.DegToRad(); + break; + + case 26509: + dp.Name = "右侧圣战斧"; + dp.Rotation = 270f.DegToRad(); + break; + } + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Fan, dp); + } + + public static class IbcHelper + { + public static IBattleChara? GetById(uint id) + { + return (IBattleChara?)Svc.Objects.SearchByEntityId(id); + } + + public static IEnumerable GetByDataId(uint dataId) + { + return Svc.Objects.Where(x => x.DataId == dataId); + } + } + + [ScriptMethod(name: "圣火猛击(直线)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^2649[89]$"])] + public void 圣火猛击(Event @event, ScriptAccessory accessory) + { + // 26497 空华焰 生成焰宝珠 :DataID 13679 红色 ;13680 蓝色 + // 操焰仪:26498 红色先炸 ; 26499 蓝色先炸 + // 技能ID 26500 红色 ; 26501 蓝色 + + var dp = accessory.Data.GetDefaultDrawProperties(); + + dp.Color = accessory.Data.DefaultDangerColor; + dp.Scale = new(10f, 50f); + dp.DestoryAt = 2700; + + switch (@event.ActionId()) + { + case 26498: + foreach (var item in IbcHelper.GetByDataId(13679)) + { + dp.Name = "圣火猛击红"; + dp.Owner = item.EntityId; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Rect, dp); + } + + foreach (var item in IbcHelper.GetByDataId(13680)) + { + dp.Name = "圣火猛击蓝"; + dp.Owner = item.EntityId; + dp.Delay = 3000; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Rect, dp); + } + break; + + case 26499: + foreach (var item in IbcHelper.GetByDataId(13680)) + { + dp.Name = "圣火猛击蓝"; + dp.Owner = item.EntityId; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Rect, dp); + } + break; + } + } + + [ScriptMethod(name: "燃烧(钢铁)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^2649[89]$"])] + public void 燃烧(Event @event, ScriptAccessory accessory) + { + // 26502 26503 爆炎招来 生成爆宝珠 :DataID 13681 红色 ;13682 蓝色 + // 操焰仪:26498 红色先炸 ; 26499 蓝色先炸 + // 技能ID 26506 红色 ; 26507 蓝色 + var dp = accessory.Data.GetDefaultDrawProperties(); + + dp.Color = accessory.Data.DefaultDangerColor; + dp.Scale = new Vector2(10f); + dp.DestoryAt = 2700; + + switch (@event.ActionId()) + { + case 26498: + foreach (var item in IbcHelper.GetByDataId(13681)) + { + dp.Name = "燃烧红"; + dp.Owner = item.EntityId; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp); + } + break; + + case 26499: + foreach (var item in IbcHelper.GetByDataId(13682)) + { + dp.Name = "燃烧蓝"; + dp.Owner = item.EntityId; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp); + } + break; + } + } + +} + + + +public static class EventExtensions +{ + private static bool ParseHexId(string? idStr, out uint id) + { + id = 0; + if (string.IsNullOrEmpty(idStr)) return false; + try + { + var idStr2 = idStr.Replace("0x", ""); + id = uint.Parse(idStr2, System.Globalization.NumberStyles.HexNumber); + return true; + } + catch (Exception) + { + return false; + } + } + + public static uint ActionId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["ActionId"]); + } + + public static uint SourceId(this Event @event) + { + return ParseHexId(@event["SourceId"], out var id) ? id : 0; + } + + public static uint SourceDataId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceDataId"]); + } + + public static uint Command(this Event @event) + { + return ParseHexId(@event["Command"], out var cid) ? cid : 0; + } + + public static uint DurationMilliseconds(this Event @event) + { + return JsonConvert.DeserializeObject(@event["DurationMilliseconds"]); + } + + public static float SourceRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceRotation"]); + } + + public static float TargetRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetRotation"]); + } + + public static byte Index(this Event @event) + { + return (byte)(ParseHexId(@event["Index"], out var index) ? index : 0); + } + + public static uint State(this Event @event) + { + return ParseHexId(@event["State"], out var state) ? state : 0; + } + + public static string SourceName(this Event @event) + { + return @event["SourceName"]; + } + + public static string TargetName(this Event @event) + { + return @event["TargetName"]; + } + + public static uint TargetId(this Event @event) + { + return ParseHexId(@event["TargetId"], out var id) ? id : 0; + } + + public static Vector3 SourcePosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourcePosition"]); + } + + public static Vector3 TargetPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetPosition"]); + } + + public static Vector3 EffectPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["EffectPosition"]); + } + + public static uint DirectorId(this Event @event) + { + return ParseHexId(@event["DirectorId"], out var id) ? id : 0; + } + + public static uint StatusId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StatusId"]); + } + + public static uint StackCount(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StackCount"]); + } + + public static uint Param(this Event @event) + { + return JsonConvert.DeserializeObject(@event["Param"]); + } +} + + +public static class Extensions +{ + public static void TTS(this ScriptAccessory accessory, string text, bool isTTS, bool isDRTTS) + { + if (isDRTTS) + { + accessory.Method.SendChat($"/pdr tts {text}"); + } + else if (isTTS) + { + accessory.Method.TTS(text); + } + } +} diff --git a/Fate/Formidable.cs b/Fate/Formidable.cs new file mode 100644 index 0000000..13c748c --- /dev/null +++ b/Fate/Formidable.cs @@ -0,0 +1,311 @@ +using System; +using System.ComponentModel; +using System.Linq; +using System.Numerics; +using System.Collections.Generic; +using System.Text.RegularExpressions; +using Dalamud.Game.ClientState.Objects.Types; +using Newtonsoft.Json; +using Dalamud.Utility.Numerics; +using KodakkuAssist.Script; +using KodakkuAssist.Module.GameEvent; +using KodakkuAssist.Module.Draw; +using ECommons; +using ECommons.DalamudServices; +using ECommons.GameFunctions; +using ECommons.MathHelpers; +using System.Threading.Tasks; + + +namespace A_Finale_Most_Formidable; + +[ScriptType(guid: "5f55a121-1fcc-48ce-a0e8-b6fbd4ce8489", name: "激斗畏惧装甲之秘密武器", territorys: [814], + version: "0.0.0.1", author: "Tetora", note: noteStr)] + +public class Formidable +{ + const string noteStr = + """ + v0.0.0.1: + LV80 特殊Fate 绘制 + 激斗畏惧装甲之秘密武器 + """; + + [ScriptMethod(name: "迷失连线", eventType: EventTypeEnum.AddCombatant, eventCondition: ["DataId:regex:^758[67]$"])] + public void 迷失连线(Event @event, ScriptAccessory accessory) + { + // Data ID 7586: 迷失少女 ;7587:迷失者 + accessory.Method.TextInfo("迷失出现", duration: 5000, true); + accessory.Method.TTS("迷失出现"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "迷失连线"; + dp.Owner = accessory.Data.Me; + dp.Color = accessory.Data.DefaultSafeColor; + dp.ScaleMode |= ScaleMode.YByDistance; + dp.TargetObject = @event.SourceId(); + dp.Scale = new(1); + dp.DestoryAt = 900000; + accessory.Method.SendDraw(DrawModeEnum.Imgui, DrawTypeEnum.Displacement, dp); + } + + [ScriptMethod(name: "迷失连线销毁", eventType: EventTypeEnum.Death, eventCondition: ["DataId:regex:^758[67]$"], userControl: false)] + public void 迷失连线销毁(Event @event, ScriptAccessory accessory) + { + accessory.Method.RemoveDraw("迷失连线"); + } + + [ScriptMethod(name: "护卫自走人偶 击杀提示", eventType: EventTypeEnum.AddCombatant, eventCondition: ["DataId:10868"])] + public void 护卫自走人偶(Event @event, ScriptAccessory accessory) + { + accessory.Method.TextInfo("击杀 <护卫自走人偶>", duration: 5000, true); + accessory.Method.TTS("击杀小怪"); + } + + [ScriptMethod(name: "格鲁格之火 吸引范围", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:17395"])] + public void 格鲁格之火Inhale(Event @event, ScriptAccessory accessory) + { + accessory.Method.TextInfo("靠近BOSS脚下,不要出圈", duration: 5000, true); + accessory.Method.TTS("靠近BOSS脚下"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "格鲁格之火Inhale"; + dp.Color = new Vector4(1f, 0f, 1f, 0.6f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(50f); + dp.InnerScale = new Vector2(10f); + dp.Radian = float.Pi * 2; + dp.DestoryAt = 22800; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Donut, dp); + } + + /* + [ScriptMethod(name: "格鲁格之火 月环范围", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:17395"])] + public void 格鲁格之火Donut(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "格鲁格之火Donut"; + dp.Color = new Vector4(1f, 0f, 0f, 1f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(20f); + dp.InnerScale = new Vector2(10f); + dp.Radian = float.Pi * 2; + dp.DestoryAt = 22800; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Donut, dp); + } + */ + + [ScriptMethod(name: "大型炸弹 爆炸(扩大钢铁)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:17411"])] + public void 爆炸(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "爆炸"; + dp.Color = accessory.Data.DefaultDangerColor; + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(12f); + dp.DestoryAt = 11700; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp); + } + + // 矮人式导弹 高亮 + + [ScriptMethod(name: "矮人雷击弹(钢铁)", eventType: EventTypeEnum.AddCombatant, eventCondition: ["DataId:11228"])] + public void 矮人雷击弹钢铁(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "矮人雷击弹钢铁"; + dp.Color = accessory.Data.DefaultDangerColor; + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(8f); + dp.DestoryAt = 7700; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp); + } + + [ScriptMethod(name: "矮人雷击弹(月环)", eventType: EventTypeEnum.AddCombatant, eventCondition: ["DataId:10908"])] + public void 矮人雷击弹月环(Event @event, ScriptAccessory accessory) + { + accessory.Method.TextInfo("靠近紫球月环", duration: 5000, true); + accessory.Method.TTS("靠近紫球月环"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "矮人雷击弹月环"; + dp.Color = new Vector4(1f, 0f, 1f, 0.4f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(60f); + dp.InnerScale = new Vector2(8.5f); + dp.Radian = float.Pi * 2; + dp.DestoryAt = 6200; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Donut, dp); + + var dp1 = accessory.Data.GetDefaultDrawProperties(); + dp1.Name = "月环连线"; + dp1.Owner = accessory.Data.Me; + dp1.Color = accessory.Data.DefaultSafeColor; + dp1.ScaleMode |= ScaleMode.YByDistance; + dp1.TargetObject = @event.SourceId(); + dp1.Scale = new(1); + dp1.DestoryAt = 6200; + accessory.Method.SendDraw(DrawModeEnum.Imgui, DrawTypeEnum.Displacement, dp1); + + } + + [ScriptMethod(name: "蒸汽喷发 击退", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:17394"])] + public void 蒸汽喷发(Event @event, ScriptAccessory accessory) + { + accessory.Method.TTS("击退"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = $"蒸汽喷发"; + dp.Scale = new(1.5f, 15); + dp.Color = accessory.Data.DefaultSafeColor; + dp.Owner = accessory.Data.Me; + dp.TargetPosition = @event.TargetPosition(); + dp.Rotation = float.Pi; + dp.DestoryAt = 2700; + accessory.Method.SendDraw(DrawModeEnum.Imgui, DrawTypeEnum.Displacement, dp); + } + + + [ScriptMethod(name: "运动体探知干扰器 提示", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:17407"])] + public async void 运动体探知干扰器(Event @event, ScriptAccessory accessory) + { + await Task.Delay(6500); + + accessory.Method.TextInfo("停止行动", duration: 1500, true); + accessory.Method.TTS("停止行动"); + } + + +} + + + +public static class EventExtensions +{ + private static bool ParseHexId(string? idStr, out uint id) + { + id = 0; + if (string.IsNullOrEmpty(idStr)) return false; + try + { + var idStr2 = idStr.Replace("0x", ""); + id = uint.Parse(idStr2, System.Globalization.NumberStyles.HexNumber); + return true; + } + catch (Exception) + { + return false; + } + } + + public static uint ActionId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["ActionId"]); + } + + public static uint SourceId(this Event @event) + { + return ParseHexId(@event["SourceId"], out var id) ? id : 0; + } + + public static uint SourceDataId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceDataId"]); + } + + public static uint Command(this Event @event) + { + return ParseHexId(@event["Command"], out var cid) ? cid : 0; + } + + public static uint DurationMilliseconds(this Event @event) + { + return JsonConvert.DeserializeObject(@event["DurationMilliseconds"]); + } + + public static float SourceRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceRotation"]); + } + + public static float TargetRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetRotation"]); + } + + public static byte Index(this Event @event) + { + return (byte)(ParseHexId(@event["Index"], out var index) ? index : 0); + } + + public static uint State(this Event @event) + { + return ParseHexId(@event["State"], out var state) ? state : 0; + } + + public static string SourceName(this Event @event) + { + return @event["SourceName"]; + } + + public static string TargetName(this Event @event) + { + return @event["TargetName"]; + } + + public static uint TargetId(this Event @event) + { + return ParseHexId(@event["TargetId"], out var id) ? id : 0; + } + + public static Vector3 SourcePosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourcePosition"]); + } + + public static Vector3 TargetPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetPosition"]); + } + + public static Vector3 EffectPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["EffectPosition"]); + } + + public static uint DirectorId(this Event @event) + { + return ParseHexId(@event["DirectorId"], out var id) ? id : 0; + } + + public static uint StatusId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StatusId"]); + } + + public static uint StackCount(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StackCount"]); + } + + public static uint Param(this Event @event) + { + return JsonConvert.DeserializeObject(@event["Param"]); + } +} + + +public static class Extensions +{ + public static void TTS(this ScriptAccessory accessory, string text, bool isTTS, bool isDRTTS) + { + if (isDRTTS) + { + accessory.Method.SendChat($"/pdr tts {text}"); + } + else if (isTTS) + { + accessory.Method.TTS(text); + } + } +} diff --git a/Fate/Mica_the_MagicalMu.cs b/Fate/Mica_the_MagicalMu.cs new file mode 100644 index 0000000..718bcfd --- /dev/null +++ b/Fate/Mica_the_MagicalMu.cs @@ -0,0 +1,189 @@ +using System; +using System.ComponentModel; +using System.Linq; +using System.Numerics; +using System.Collections.Generic; +using System.Text.RegularExpressions; +using Dalamud.Game.ClientState.Objects.Types; +using Newtonsoft.Json; +using Dalamud.Utility.Numerics; +using KodakkuAssist.Script; +using KodakkuAssist.Module.GameEvent; +using KodakkuAssist.Module.Draw; +using ECommons; +using ECommons.DalamudServices; +using ECommons.GameFunctions; +using ECommons.MathHelpers; + + +namespace Mascot_Murder; + +[ScriptType(guid: "22134617-0ca4-463e-a40d-675ef1c20cf2", name: "亩鼠米卡:盛装巡游皆大欢喜", territorys: [1192], + version: "0.0.0.1", author: "Tetora", note: noteStr)] + +public class Mica_the_Magical_Mu +{ + const string noteStr = + """ + v0.0.0.1: + LV100 特殊Fate 绘制 + 亩鼠米卡:盛装巡游皆大欢喜 + """; + + [ScriptMethod(name: "迷失连线", eventType: EventTypeEnum.AddCombatant, eventCondition: ["DataId:regex:^758[67]$"])] + public void 迷失连线(Event @event, ScriptAccessory accessory) + { + // Data ID 7586: 迷失少女 ;7587:迷失者 + accessory.Method.TextInfo("迷失出现", duration: 5000, true); + accessory.Method.TTS("迷失出现"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "迷失连线"; + dp.Owner = accessory.Data.Me; + dp.Color = accessory.Data.DefaultSafeColor; + dp.ScaleMode |= ScaleMode.YByDistance; + dp.TargetObject = @event.SourceId(); + dp.Scale = new(1); + dp.DestoryAt = 900000; + accessory.Method.SendDraw(DrawModeEnum.Imgui, DrawTypeEnum.Displacement, dp); + } + + [ScriptMethod(name: "迷失连线销毁", eventType: EventTypeEnum.Death, eventCondition: ["DataId:regex:^758[67]$"], userControl: false)] + public void 迷失连线销毁(Event @event, ScriptAccessory accessory) + { + accessory.Method.RemoveDraw("迷失连线"); + } + +} + + + +public static class EventExtensions +{ + private static bool ParseHexId(string? idStr, out uint id) + { + id = 0; + if (string.IsNullOrEmpty(idStr)) return false; + try + { + var idStr2 = idStr.Replace("0x", ""); + id = uint.Parse(idStr2, System.Globalization.NumberStyles.HexNumber); + return true; + } + catch (Exception) + { + return false; + } + } + + public static uint ActionId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["ActionId"]); + } + + public static uint SourceId(this Event @event) + { + return ParseHexId(@event["SourceId"], out var id) ? id : 0; + } + + public static uint SourceDataId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceDataId"]); + } + + public static uint Command(this Event @event) + { + return ParseHexId(@event["Command"], out var cid) ? cid : 0; + } + + public static uint DurationMilliseconds(this Event @event) + { + return JsonConvert.DeserializeObject(@event["DurationMilliseconds"]); + } + + public static float SourceRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceRotation"]); + } + + public static float TargetRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetRotation"]); + } + + public static byte Index(this Event @event) + { + return (byte)(ParseHexId(@event["Index"], out var index) ? index : 0); + } + + public static uint State(this Event @event) + { + return ParseHexId(@event["State"], out var state) ? state : 0; + } + + public static string SourceName(this Event @event) + { + return @event["SourceName"]; + } + + public static string TargetName(this Event @event) + { + return @event["TargetName"]; + } + + public static uint TargetId(this Event @event) + { + return ParseHexId(@event["TargetId"], out var id) ? id : 0; + } + + public static Vector3 SourcePosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourcePosition"]); + } + + public static Vector3 TargetPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetPosition"]); + } + + public static Vector3 EffectPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["EffectPosition"]); + } + + public static uint DirectorId(this Event @event) + { + return ParseHexId(@event["DirectorId"], out var id) ? id : 0; + } + + public static uint StatusId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StatusId"]); + } + + public static uint StackCount(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StackCount"]); + } + + public static uint Param(this Event @event) + { + return JsonConvert.DeserializeObject(@event["Param"]); + } +} + + +public static class Extensions +{ + public static void TTS(this ScriptAccessory accessory, string text, bool isTTS, bool isDRTTS) + { + if (isDRTTS) + { + accessory.Method.SendChat($"/pdr tts {text}"); + } + else if (isTTS) + { + accessory.Method.TTS(text); + } + } +} diff --git a/Fate/Ttokrrone.cs b/Fate/Ttokrrone.cs new file mode 100644 index 0000000..08d4f69 --- /dev/null +++ b/Fate/Ttokrrone.cs @@ -0,0 +1,464 @@ +using System; +using System.ComponentModel; +using System.Linq; +using System.Numerics; +using System.Collections.Generic; +using System.Text.RegularExpressions; +using Dalamud.Game.ClientState.Objects.Types; +using Newtonsoft.Json; +using Dalamud.Utility.Numerics; +using KodakkuAssist.Script; +using KodakkuAssist.Module.GameEvent; +using KodakkuAssist.Module.Draw; +using ECommons; +using ECommons.DalamudServices; +using ECommons.GameFunctions; +using ECommons.MathHelpers; + +namespace The_Serpentlord_Seethes; + +[ScriptType(guid: "ab67129e-880f-48e8-852e-f92b4afa68e5", name: "蛇王得酷热涅:荒野的死斗", territorys: [1190], + version: "0.0.0.1", author: "Tetora", note: noteStr)] + +public class Ttokrrone +{ + const string noteStr = + """ + v0.0.0.1: + LV100 特殊Fate 绘制 + 蛇王得酷热涅:荒野的死斗 + """; + + [ScriptMethod(name: "迷失连线", eventType: EventTypeEnum.AddCombatant, eventCondition: ["DataId:regex:^758[67]$"])] + public void 迷失连线(Event @event, ScriptAccessory accessory) + { + // Data ID 7586: 迷失少女 ;7587:迷失者 + accessory.Method.TextInfo("迷失出现", duration: 5000, true); + accessory.Method.TTS("迷失出现"); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "迷失连线"; + dp.Owner = accessory.Data.Me; + dp.Color = accessory.Data.DefaultSafeColor; + dp.ScaleMode |= ScaleMode.YByDistance; + dp.TargetObject = @event.SourceId(); + dp.Scale = new(1); + dp.DestoryAt = 900000; + accessory.Method.SendDraw(DrawModeEnum.Imgui, DrawTypeEnum.Displacement, dp); + } + + [ScriptMethod(name: "迷失连线销毁", eventType: EventTypeEnum.Death, eventCondition: ["DataId:regex:^758[67]$"], userControl: false)] + public void 迷失连线销毁(Event @event, ScriptAccessory accessory) + { + accessory.Method.RemoveDraw("迷失连线"); + } + + [ScriptMethod(name: "单侧沙暴", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^3731[3-6]$"])] + public void 单侧沙暴(Event @event, ScriptAccessory accessory) + { + // 37313 前方沙暴 ; 37314 后方沙暴 ; 37315 右方沙暴 ; 37316 左方沙暴 + // 可达鸭的旋转为逆时针,所以左刀为90°,右刀为270° + accessory.Method.TextInfo("出目标圈", duration: 4900, true); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "单侧沙暴"; + dp.Color = new Vector4(1f, 1f, 0f, 1f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(60); + dp.Radian = 90f.DegToRad(); + dp.DestoryAt = 4900; + + switch (@event.ActionId()) + { + case 37313: // 前方沙暴 + dp.Rotation = 0f.DegToRad(); + break; + case 37314: // 后方沙暴 + dp.Rotation = 180f.DegToRad(); + break; + case 37315: // 右方沙暴 + dp.Rotation = 270f.DegToRad(); + break; + case 37316: // 左方沙暴 + dp.Rotation = 90f.DegToRad(); + break; + } + + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Fan, dp); + + var dp1 = accessory.Data.GetDefaultDrawProperties(); + dp1.Name = "砂砾钢铁"; + dp1.Color = new Vector4(1f, 1f, 0f, 1.2f); + dp1.Owner = @event.SourceId(); + dp1.Scale = new Vector2(13f); + dp1.DestoryAt = 4900; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp1); + } + + [ScriptMethod(name: "回旋沙暴", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^(3731[78]|3732[12])$"])] + public void 回旋沙暴(Event @event, ScriptAccessory accessory) + { + // 【前方回旋沙暴】 37317 顺时针、37321 逆时针 ;【后方回旋沙暴】 37318 顺时针 、37322 逆时针 + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(60); + dp.Radian = 90f.DegToRad(); + dp.Color = accessory.Data.DefaultDangerColor; + dp.DestoryAt = 24700; + + switch (@event.ActionId()) + { + case 37317: // 顺时针 + case 37321: // 逆时针 + dp.Name = "前方回旋沙暴F"; + dp.Rotation = 0f.DegToRad(); + break; + + case 37318: // 顺时针 + case 37322: // 逆时针 + dp.Name = "后方回旋沙暴B"; + dp.Rotation = 180f.DegToRad(); + break; + } + + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Fan, dp); + + // 画旋转方向预测 + var dp1 = accessory.Data.GetDefaultDrawProperties(); + dp1.Owner = @event.SourceId(); + dp1.Scale = new Vector2(60); + dp1.Radian = 90f.DegToRad(); + dp1.Color = new Vector4(1f, 0f, 0f, 1f); + dp1.DestoryAt = 22700; + + switch (@event.ActionId()) + { + case 37317: // 前方 顺时针 + dp1.Name = "前方回旋沙暴FR"; + dp1.Rotation = 270f.DegToRad(); + accessory.Method.RemoveDraw($"后方回旋沙暴B(L|R)?{@event.SourceId()}"); + accessory.Method.RemoveDraw($"前方回旋沙暴FL{@event.SourceId()}"); + break; + + case 37321: // 前方 逆时针 + dp1.Name = "前方回旋沙暴FL"; + dp1.Rotation = 90f.DegToRad(); + accessory.Method.RemoveDraw($"后方回旋沙暴B(L|R)?{@event.SourceId()}"); + accessory.Method.RemoveDraw($"前方回旋沙暴FR{@event.SourceId()}"); + break; + + case 37318: // 后方 顺时针 + dp1.Name = "后方回旋沙暴BR"; + dp1.Rotation = 90f.DegToRad(); + accessory.Method.RemoveDraw($"前方回旋沙暴F(L|R)?{@event.SourceId()}"); + accessory.Method.RemoveDraw($"后方回旋沙暴BL{@event.SourceId()}"); + break; + + case 37322: // 后方 逆时针 + dp1.Name = "后方回旋沙暴BL"; + dp1.Rotation = 270f.DegToRad(); + accessory.Method.RemoveDraw($"前方回旋沙暴F(L|R)?{@event.SourceId()}"); + accessory.Method.RemoveDraw($"后方回旋沙暴BR{@event.SourceId()}"); + break; + } + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Fan, dp1); + + } + + + [ScriptMethod(name: "回旋沙暴销毁", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:37327"], userControl: false)] + public void 回旋沙暴销毁(Event @event, ScriptAccessory accessory) + { + // 因每次旋转的持续时间不固定,所以需要根据技能释放方式提前销毁绘制 ,已知回旋完可能接捕食,也可能接一次反向回旋 (待证实:是方向相反 或 顺逆时针相反) + // 需在 37327 捕食 读条时销毁全部绘制 , 在 37317 37321 读条前方回旋时 销毁后方绘制 , 在 31318 37322 读条后方回旋时 销毁前方绘制 + + accessory.Method.RemoveDraw(".*"); + + /* + //["ActionId:regex:^(37327|3731[78]|3732[12])$"], + switch (@event.ActionId()) + { + case 37327: + accessory.Method.RemoveDraw(".*"); + break; + + case 37317: // 前方 顺时针 + case 37321: // 前方 逆时针 + accessory.Method.RemoveDraw($"后方回旋沙暴B(L|R)?{@event.SourceId()}"); + break; + + case 37318: // 后方 顺时针 + case 37322: // 后方 逆时针 + accessory.Method.RemoveDraw($"前方回旋沙暴F(L|R)?{@event.SourceId()}"); + break; + } + */ + } + + + [ScriptMethod(name: "回旋沙暴_砂砾(持续钢铁)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^(3731[78]|3732[12])$"])] + public void 砂砾(Event @event, ScriptAccessory accessory) + { + accessory.Method.TextInfo("出目标圈", duration: 24700, true); + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "砂砾预兆"; + dp.Color = new Vector4(1f, 1f, 0f, 1.2f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(13f); + dp.DestoryAt = 6900; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp); + + var dp1 = accessory.Data.GetDefaultDrawProperties(); + dp1.Name = "砂砾持续"; + dp1.Color = new Vector4(1f, 0f, 0f, 1.5f); + dp1.Owner = @event.SourceId(); + dp1.Scale = new Vector2(13f); + dp1.Delay = 6900; + dp1.DestoryAt = 17800; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp1); + } + + [ScriptMethod(name: "飞沙(钢铁月环)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^3733[1-4]$"])] + public void 飞沙(Event @event, ScriptAccessory accessory) + { + // 37331 钢铁 ; 37332 月环 ; 37333 左半钢铁 + 右半月环 ; 37334 左半月环 + 右半钢铁 + + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Color = new Vector4(1f, 1f, 0f, 1f); + dp.Owner = @event.SourceId(); + dp.DestoryAt = 7000; + + switch (@event.ActionId()) + { + case 37331: // 钢铁 + dp.Name = "飞沙钢铁"; + dp.Scale = new Vector2(19f); + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp); + break; + + case 37332: // 月环 + dp.Name = "飞沙月环"; + dp.Scale = new Vector2(60f); + dp.InnerScale = new Vector2(14f); + dp.Radian = float.Pi * 2; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Donut, dp); + break; + + case 37333: // 左半钢铁 + 右半月环 + dp.Name = "飞沙左半钢铁"; + dp.Scale = new Vector2(19); + dp.Radian = 180f.DegToRad(); + dp.Rotation = 90f.DegToRad(); + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Fan, dp); + + var dp1 = accessory.Data.GetDefaultDrawProperties(); + dp1.Name = "飞沙右半月环"; + dp1.Color = accessory.Data.DefaultDangerColor; + dp1.Owner = @event.SourceId(); + dp1.Scale = new Vector2(60); + dp1.InnerScale = new Vector2(14); + dp1.Radian = 180f.DegToRad(); + dp1.Rotation = 270f.DegToRad(); + dp1.DestoryAt = 7000; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Donut, dp1); + break; + + case 37334: // 右半钢铁 + 左半月环 + dp.Name = "飞沙右半钢铁"; + dp.Scale = new Vector2(19); + dp.Radian = 180f.DegToRad(); + dp.Rotation = 270f.DegToRad(); + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Fan, dp); + + var dp2 = accessory.Data.GetDefaultDrawProperties(); + dp2.Name = "飞沙左半月环"; + dp2.Color = accessory.Data.DefaultDangerColor; + dp2.Owner = @event.SourceId(); + dp2.Scale = new Vector2(60); + dp2.InnerScale = new Vector2(14); + dp2.Radian = 180f.DegToRad(); + dp2.Rotation = 90f.DegToRad(); + dp2.DestoryAt = 7000; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Donut, dp2); + break; + } + } + + [ScriptMethod(name: "沙球_大爆炸(钢铁)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^3924[56]$"])] + public void 大爆炸(Event @event, ScriptAccessory accessory) + { + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "大爆炸"; + dp.Color = new Vector4(1f, 1f, 0f, 1f); + dp.Owner = @event.SourceId(); + dp.Scale = new Vector2(12f); + dp.DestoryAt = @event.ActionId() == 39245 ? 7700 : 5700; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Circle, dp); + } + + [ScriptMethod(name: "吞地巨蛇(直线)", eventType: EventTypeEnum.StartCasting, eventCondition: ["ActionId:regex:^(3757[89]|3758[0-3])$"])] + public void 吞地巨蛇(Event @event, ScriptAccessory accessory) + { + /* + 37578 预警1,13.8s,宽14m,22m长 + 37579 预警2,14.8s,宽14m,22m长 + 37580 预警3,16.2s,宽14m,22m长 + 37581 预警4,17.6s,宽14m,22m长 + 37582 预警5,19.0s,宽14m,22m长 + 37583 预警6,20.4s,宽14m,22m长 + + 38642 施放1,14.0s,宽38m,27m长 + 38645 施放2,无读条,宽50m,27m长 + 38644 施放3,无读条,宽68m,27m长 + 38646 施放4,无读条,宽63m,27m长 + */ + var dp = accessory.Data.GetDefaultDrawProperties(); + dp.Name = "吞地巨蛇"; + dp.Scale = new (27, 68f); + dp.Owner = @event.SourceId(); + dp.Color = new Vector4(1f, 1f, 0f, 0.8f); + dp.DestoryAt = @event.DurationMilliseconds() + 1400; + accessory.Method.SendDraw(DrawModeEnum.Default, DrawTypeEnum.Rect, dp); + } + + [ScriptMethod(name: "蛇王死亡销毁", eventType: EventTypeEnum.Death, eventCondition: ["DataId:16933"], userControl: false)] + public void 蛇王死亡销毁(Event @event, ScriptAccessory accessory) + { + accessory.Method.RemoveDraw(".*"); + } + +} + + + +public static class EventExtensions +{ + private static bool ParseHexId(string? idStr, out uint id) + { + id = 0; + if (string.IsNullOrEmpty(idStr)) return false; + try + { + var idStr2 = idStr.Replace("0x", ""); + id = uint.Parse(idStr2, System.Globalization.NumberStyles.HexNumber); + return true; + } + catch (Exception) + { + return false; + } + } + + public static uint ActionId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["ActionId"]); + } + + public static uint SourceId(this Event @event) + { + return ParseHexId(@event["SourceId"], out var id) ? id : 0; + } + + public static uint SourceDataId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceDataId"]); + } + + public static uint Command(this Event @event) + { + return ParseHexId(@event["Command"], out var cid) ? cid : 0; + } + + public static uint DurationMilliseconds(this Event @event) + { + return JsonConvert.DeserializeObject(@event["DurationMilliseconds"]); + } + + public static float SourceRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourceRotation"]); + } + + public static float TargetRotation(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetRotation"]); + } + + public static byte Index(this Event @event) + { + return (byte)(ParseHexId(@event["Index"], out var index) ? index : 0); + } + + public static uint State(this Event @event) + { + return ParseHexId(@event["State"], out var state) ? state : 0; + } + + public static string SourceName(this Event @event) + { + return @event["SourceName"]; + } + + public static string TargetName(this Event @event) + { + return @event["TargetName"]; + } + + public static uint TargetId(this Event @event) + { + return ParseHexId(@event["TargetId"], out var id) ? id : 0; + } + + public static Vector3 SourcePosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["SourcePosition"]); + } + + public static Vector3 TargetPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["TargetPosition"]); + } + + public static Vector3 EffectPosition(this Event @event) + { + return JsonConvert.DeserializeObject(@event["EffectPosition"]); + } + + public static uint DirectorId(this Event @event) + { + return ParseHexId(@event["DirectorId"], out var id) ? id : 0; + } + + public static uint StatusId(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StatusId"]); + } + + public static uint StackCount(this Event @event) + { + return JsonConvert.DeserializeObject(@event["StackCount"]); + } + + public static uint Param(this Event @event) + { + return JsonConvert.DeserializeObject(@event["Param"]); + } +} + + +public static class Extensions +{ + public static void TTS(this ScriptAccessory accessory, string text, bool isTTS, bool isDRTTS) + { + if (isDRTTS) + { + accessory.Method.SendChat($"/pdr tts {text}"); + } + else if (isTTS) + { + accessory.Method.TTS(text); + } + } +}