123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285 |
- using System.Collections.Generic;
- using System.Threading.Tasks;
- namespace WS
- {
-
- public class ModuleComponent : WSComponent
- {
- private ProcessManager process;
-
- private ProcessManager Process
- {
- get
- {
- if (process == null)
- process = (ProcessManager)Parent;
- return process;
- }
- }
-
- public int Id { get { return Data.Id; } }
-
- public string Name { get { return Data.Name; } }
-
- public bool NoTaskbar { get { return Data.NoTaskbar; } }
-
- public bool NoOrder { get { return Data.NoOrder; } }
-
- public int VTaskId { get { return CurrentVTask.Id; } }
-
- public float Score;
-
- public bool IsComplete;
-
- public Module Data;
-
- private List<WSTaskComponent> VTasks = new List<WSTaskComponent>();
-
- private WSTaskComponent CurrentVTask;
- public void Update()
- {
- if (NoOrder)
- {
- for (int i = 0; i < VTasks.Count; i++)
- {
- if (!VTasks[i].IsComplete)
- VTasks[i].Update();
- }
- OnComplete();
- }
- else
- {
- if (CurrentVTask != null)
- {
- if (!CurrentVTask.IsComplete)
- CurrentVTask.Update();
- else
- SwitchVTask(CurrentVTask.Id + 1);
- }
- }
- }
-
- private void OnComplete()
- {
- bool complete = !VTasks.Exists(v => v.IsComplete == false);
- IsComplete = complete;
- if (IsComplete)
- {
- Settlement();
- }
- }
-
- public void StartModule()
- {
- #if UNITY_EDITOR || DEBUG_MODEL
- Log.LogDebug($"进入模块:{Name} ID:{Id}", WSLogType.橙);
- #endif
- List<int> performids = new List<int>();
- for (int i = 0; i < Data.WSTasks.Count; i++)
- {
- if (Data.WSTasks[i].Perform)
- {
- performids.Add(Data.WSTasks[i].PerformId);
- }
- }
- for (int i = 0; i < Data.WSTasks.Count; i++)
- {
- WSTaskComponent vtask = ComponentFactory.CreateWithParent<WSTaskComponent>(this);
- vtask.Data = Data.WSTasks[i];
- VTasks.Add(vtask);
- if (NoOrder)
- {
- if (!performids.Exists(l => l == Data.WSTasks[i].Id))
- vtask.StartVTask();
- }
- if (!NoTaskbar)
- {
- WSTaskRecord record = new WSTaskRecord { Id = VTasks[i].Id, Score = VTasks[i].Score, Module = Name, Name = VTasks[i].Name ,IsEnd =false};
- Process.AddVTaskRecord(record);
- }
- }
- if (!NoOrder)
- SwitchVTask(VTasks[0].Id);
- }
-
- public async Task NextModule()
- {
- try
- {
- for (int i = 0; i < VTasks.Count; i++)
- {
- if (NoOrder)
- {
- if (!VTasks[i].IsComplete)
- await VTasks[i].JumpVTask(false);
- }
- else
- {
- if (VTasks[i].Id >= VTaskId)
- await VTasks[i].JumpVTask(false);
- }
- }
- }
- catch (System.Exception ex)
- {
- Log.LogError(ex);
- }
- }
-
-
-
- public async Task<bool> JumpVTask(int Id, bool invertedorder)
- {
- bool exists = false;
- try
- {
- exists = VTasks.Exists(t => t.Id == Id);
- if (!invertedorder)
- {
- for (int i = CurrentVTask.Id - 1; i < VTasks.Count; i++)
- {
- if (VTasks[i].Id < Id)
- await VTasks[i].JumpVTask(invertedorder);
- }
- }
- else
- {
- for (int i = CurrentVTask.Id - 1; i >= 0; i--)
- {
- if (VTasks[i].Id >= Id)
- await VTasks[i].JumpVTask(invertedorder);
- }
- }
- if (exists)
- SwitchVTask(Id);
- else
- IsComplete = true;
- }
- catch (System.Exception ex)
- {
- Log.LogError(ex);
- }
- return exists;
- }
-
-
- public async Task<bool> LastVTask(bool newmd)
- {
- try
- {
- if (newmd)
- {
- WSTaskComponent vTask = VTasks[VTasks.Count - 1];
- await vTask.JumpVTask(true);
- SwitchVTask(vTask.Id - 1);
- }
- else
- {
- await CurrentVTask.JumpVTask(true);
- int index = VTasks.FindIndex(v => v == CurrentVTask);
- if (index == 0)
- {
- IsComplete = false;
- return false;
- }
- else
- {
- WSTaskComponent vTask = VTasks.Find(t => t.Id == CurrentVTask.Id - 1);
- if (vTask!=null)
- await vTask.JumpVTask(true);
- SwitchVTask(CurrentVTask.Id - 1);
- }
- }
- }
- catch (System.Exception ex)
- {
- Log.LogError(ex);
- }
- return true;
- }
-
- public async Task NextVTask()
- {
- try
- {
- await CurrentVTask.JumpVTask(false);
- SwitchVTask(CurrentVTask.Id + 1);
- }
- catch (System.Exception ex)
- {
- Log.LogError(ex);
- }
- }
-
- public void Settlement()
- {
- for (int i = 0; i < VTasks.Count; i++)
- {
- if (VTasks[i].IsComplete)
- {
- if (!VTasks[i].IsError)
- Score += VTasks[i].Score;
- }
- else
- {
- if (!NoTaskbar)
- {
- WSTaskRecord record = Process.GetVTaskRecord(VTasks[i].Id);
- record.IsError = true;
- }
- }
- }
- }
-
- public WSTaskComponent GetVTask(int vtaskid)
- {
- return VTasks.Find(t => t.Id == vtaskid);
- }
-
- public void Prompt()
- {
- CurrentVTask.Prompt();
- }
-
- private void SwitchVTask(int id)
- {
- WSTaskComponent vTask = VTasks.Find(t => t.Id == id);
- if (vTask != null)
- {
- CurrentVTask = vTask;
- CurrentVTask.StartVTask();
- }
- else
- {
- Settlement();
- IsComplete = true;
- }
- }
- public override void Dispose()
- {
- base.Dispose();
-
- IsComplete = false;
- Data = null;
- for (int i = 0; i < VTasks.Count; i++)
- {
- VTasks[i].Dispose();
- }
- VTasks.Clear();
- CurrentVTask = null;
- }
- }
- }
|