public const string _automapControlPanelKey = "automapControlPanelKey";
private const string _statusTextKey = @"txtStatus";
private const string _noteTextKey = @"edtNote";
+ private const string _swAutostart = @"swAutostart";
+ private const string _btnRunKey = @"btnRun";
private ILogger Logger;
}
private uint totalShards, voidShards, changesThisTick;
- private RunState lastState;
+ private CommandType lastState;
- public AutomapGUIDialog(ICoreClientAPI capi, AutomapSystem ams) : base(capi)
+ public AutomapGUIDialog(ICoreClientAPI capi, AutomapSystem ams, PersistedConfiguration cfg) : base(capi)
{
Logger = capi.Logger;
}
+ public AutomapGUIDialog(ICoreClientAPI capi) : base(capi)
+ {
+ }
+
//Event for GUI status display
private void SetupDialog()
toggleBounds.fixedHeight = 24;
toggleBounds.fixedWidth = 64;
+ ElementBounds autostartBounds = toggleBounds.RightCopy(66, 0, 1, 1);
+ autostartBounds.fixedHeight = 24;
+ autostartBounds.fixedWidth = 80;
+
ElementBounds txtStatusBounds = textBounds.CopyOffsetedSibling(0, 26, 2, 4);
txtStatusBounds.fixedHeight = 16;
txtStatusBounds.percentWidth = 1;
.AddShadedDialogBG(bgBounds)
.AddDialogTitleBar("Automap Controls", OnTitleBarCloseClicked)
.AddStaticText("Configure Automap settings:", CairoFont.WhiteDetailText(), textBounds)
- .AddToggleButton("Run", CairoFont.ButtonText(), RunToggle, toggleBounds, "btnRun")
+ .AddToggleButton("Run", CairoFont.ButtonText(), RunToggle, toggleBounds, _btnRunKey)
+ .AddSwitch(AutostartChange,autostartBounds,_swAutostart)
+ .AddStaticText("Autostart",CairoFont.WhiteDetailText(),autostartBounds.RightCopy(16))
.AddDynamicText("Idle.", CairoFont.WhiteSmallText().WithFontSize(12), EnumTextOrientation.Left, txtStatusBounds, _statusTextKey)
.AddTextInput(txtNoteArea, null, CairoFont.WhiteMediumText().WithFontSize(16), _noteTextKey)
.AddButton("Note:", CreateNote, btnNoteArea, CairoFont.ButtonText())
.Compose();
- //Controls for ALL Block & Entity Designators (Enable/Disable)
+ //Controls for ALL Block & Entity Designators (Enable/Disable) <-- block edits while in 'Run' state
//_automapSystem.BlockID_Designators
//_automapSystem.Entity_Designators
//Renderer selection
//Message verbosity? Speed?
- //A Button to add POI - notes manually (when AM running)
+
}
if (toggle)
{
dashTickHandle = capi.Event.RegisterGameTickListener(UpdateDashDisplay, 6001);
- cmd = new CommandData(toggle ? RunState.Run : RunState.Stop, new bool[] { true, true, true, true, true });
+ cmd = new CommandData(toggle ? CommandType.Run : CommandType.Stop);
}
else
{
capi.Event.UnregisterGameTickListener(dashTickHandle);
- cmd = new CommandData(toggle ? RunState.Run : RunState.Stop);
+ cmd = new CommandData(toggle ? CommandType.Run : CommandType.Stop);
}
capi.Event.PushEvent(AutomapSystem.AutomapCommandEventKey, cmd);
private bool CreateNote()
{
- var noteCmd = new CommandData(RunState.Notation);
+ var noteCmd = new CommandData(CommandType.Notation);
var txtNote = this.SingleComposer.GetTextInput(_noteTextKey);
if (!String.IsNullOrWhiteSpace(txtNote.GetText()))
{
capi.Event.PushEvent(AutomapSystem.AutomapCommandEventKey, noteCmd);
}
- return false;//???
+ return true;//FINDOUT: What does this DO?
+ }
+
+ private void AutostartChange(bool startValue)
+ {
+
}
private void AutomapStatusMsg(string eventName, ref EnumHandling handling, IAttribute data)
voidShards = realData.VoidChunks;
changesThisTick = realData.Delta;
lastState = realData.CurrentState;
+
}
private void UpdateDashDisplay(float delay)
var statusText = this.SingleComposer.GetDynamicText(_statusTextKey);
statusText.SetNewText($"State: {lastState}, Total: {totalShards}, Delta: {changesThisTick} Nulls: {voidShards} ");
+ var btnRun = this.SingleComposer.GetToggleButton(_btnRunKey);
+ if (lastState == CommandType.Run) {
+ btnRun.SetValue(true);
+ }
+ else if (lastState == CommandType.Stop) {
+ btnRun.SetValue(false);
+ }
}