more preparation
This commit is contained in:
parent
3c12c6079d
commit
b0db9b8ff7
|
@ -804,6 +804,7 @@ src/gui/grooves.cpp
|
||||||
src/gui/insEdit.cpp
|
src/gui/insEdit.cpp
|
||||||
src/gui/intro.cpp
|
src/gui/intro.cpp
|
||||||
src/gui/log.cpp
|
src/gui/log.cpp
|
||||||
|
src/gui/memory.cpp
|
||||||
src/gui/mixer.cpp
|
src/gui/mixer.cpp
|
||||||
src/gui/midiMap.cpp
|
src/gui/midiMap.cpp
|
||||||
src/gui/newSong.cpp
|
src/gui/newSong.cpp
|
||||||
|
|
|
@ -313,6 +313,9 @@ void FurnaceGUI::doAction(int what) {
|
||||||
case GUI_ACTION_WINDOW_XY_OSC:
|
case GUI_ACTION_WINDOW_XY_OSC:
|
||||||
nextWindow=GUI_WINDOW_XY_OSC;
|
nextWindow=GUI_WINDOW_XY_OSC;
|
||||||
break;
|
break;
|
||||||
|
case GUI_ACTION_WINDOW_MEMORY:
|
||||||
|
nextWindow=GUI_WINDOW_MEMORY;
|
||||||
|
break;
|
||||||
|
|
||||||
case GUI_ACTION_COLLAPSE_WINDOW:
|
case GUI_ACTION_COLLAPSE_WINDOW:
|
||||||
collapseWindow=true;
|
collapseWindow=true;
|
||||||
|
@ -412,6 +415,9 @@ void FurnaceGUI::doAction(int what) {
|
||||||
case GUI_WINDOW_XY_OSC:
|
case GUI_WINDOW_XY_OSC:
|
||||||
xyOscOpen=false;
|
xyOscOpen=false;
|
||||||
break;
|
break;
|
||||||
|
case GUI_WINDOW_MEMORY:
|
||||||
|
memoryOpen=false;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3464,6 +3464,7 @@ bool FurnaceGUI::loop() {
|
||||||
DECLARE_METRIC(settings)
|
DECLARE_METRIC(settings)
|
||||||
DECLARE_METRIC(debug)
|
DECLARE_METRIC(debug)
|
||||||
DECLARE_METRIC(stats)
|
DECLARE_METRIC(stats)
|
||||||
|
DECLARE_METRIC(memory)
|
||||||
DECLARE_METRIC(compatFlags)
|
DECLARE_METRIC(compatFlags)
|
||||||
DECLARE_METRIC(piano)
|
DECLARE_METRIC(piano)
|
||||||
DECLARE_METRIC(notes)
|
DECLARE_METRIC(notes)
|
||||||
|
@ -4044,6 +4045,7 @@ bool FurnaceGUI::loop() {
|
||||||
IMPORT_CLOSE(speedOpen);
|
IMPORT_CLOSE(speedOpen);
|
||||||
IMPORT_CLOSE(groovesOpen);
|
IMPORT_CLOSE(groovesOpen);
|
||||||
IMPORT_CLOSE(xyOscOpen);
|
IMPORT_CLOSE(xyOscOpen);
|
||||||
|
IMPORT_CLOSE(memoryOpen);
|
||||||
} else if (pendingLayoutImportStep==1) {
|
} else if (pendingLayoutImportStep==1) {
|
||||||
// let the UI settle
|
// let the UI settle
|
||||||
} else if (pendingLayoutImportStep==2) {
|
} else if (pendingLayoutImportStep==2) {
|
||||||
|
@ -4415,6 +4417,7 @@ bool FurnaceGUI::loop() {
|
||||||
if (ImGui::MenuItem("register view",BIND_FOR(GUI_ACTION_WINDOW_REGISTER_VIEW),regViewOpen)) regViewOpen=!regViewOpen;
|
if (ImGui::MenuItem("register view",BIND_FOR(GUI_ACTION_WINDOW_REGISTER_VIEW),regViewOpen)) regViewOpen=!regViewOpen;
|
||||||
if (ImGui::MenuItem("log viewer",BIND_FOR(GUI_ACTION_WINDOW_LOG),logOpen)) logOpen=!logOpen;
|
if (ImGui::MenuItem("log viewer",BIND_FOR(GUI_ACTION_WINDOW_LOG),logOpen)) logOpen=!logOpen;
|
||||||
if (ImGui::MenuItem("statistics",BIND_FOR(GUI_ACTION_WINDOW_STATS),statsOpen)) statsOpen=!statsOpen;
|
if (ImGui::MenuItem("statistics",BIND_FOR(GUI_ACTION_WINDOW_STATS),statsOpen)) statsOpen=!statsOpen;
|
||||||
|
if (ImGui::MenuItem("memory composition",BIND_FOR(GUI_ACTION_WINDOW_MEMORY),memoryOpen)) memoryOpen=!memoryOpen;
|
||||||
if (spoilerOpen) if (ImGui::MenuItem("spoiler",NULL,spoilerOpen)) spoilerOpen=!spoilerOpen;
|
if (spoilerOpen) if (ImGui::MenuItem("spoiler",NULL,spoilerOpen)) spoilerOpen=!spoilerOpen;
|
||||||
|
|
||||||
ImGui::EndMenu();
|
ImGui::EndMenu();
|
||||||
|
@ -4636,6 +4639,7 @@ bool FurnaceGUI::loop() {
|
||||||
MEASURE(volMeter,drawVolMeter());
|
MEASURE(volMeter,drawVolMeter());
|
||||||
MEASURE(grooves,drawGrooves());
|
MEASURE(grooves,drawGrooves());
|
||||||
MEASURE(regView,drawRegView());
|
MEASURE(regView,drawRegView());
|
||||||
|
MEASURE(memory,drawMemory());
|
||||||
} else {
|
} else {
|
||||||
globalWinFlags=0;
|
globalWinFlags=0;
|
||||||
ImGui::DockSpaceOverViewport(NULL,lockLayout?(ImGuiDockNodeFlags_NoWindowMenuButton|ImGuiDockNodeFlags_NoMove|ImGuiDockNodeFlags_NoResize|ImGuiDockNodeFlags_NoCloseButton|ImGuiDockNodeFlags_NoDocking|ImGuiDockNodeFlags_NoDockingSplitMe|ImGuiDockNodeFlags_NoDockingSplitOther):0);
|
ImGui::DockSpaceOverViewport(NULL,lockLayout?(ImGuiDockNodeFlags_NoWindowMenuButton|ImGuiDockNodeFlags_NoMove|ImGuiDockNodeFlags_NoResize|ImGuiDockNodeFlags_NoCloseButton|ImGuiDockNodeFlags_NoDocking|ImGuiDockNodeFlags_NoDockingSplitMe|ImGuiDockNodeFlags_NoDockingSplitOther):0);
|
||||||
|
@ -4666,6 +4670,7 @@ bool FurnaceGUI::loop() {
|
||||||
MEASURE(settings,drawSettings());
|
MEASURE(settings,drawSettings());
|
||||||
MEASURE(debug,drawDebug());
|
MEASURE(debug,drawDebug());
|
||||||
MEASURE(stats,drawStats());
|
MEASURE(stats,drawStats());
|
||||||
|
MEASURE(memory,drawMemory());
|
||||||
MEASURE(compatFlags,drawCompatFlags());
|
MEASURE(compatFlags,drawCompatFlags());
|
||||||
MEASURE(piano,drawPiano());
|
MEASURE(piano,drawPiano());
|
||||||
MEASURE(notes,drawNotes());
|
MEASURE(notes,drawNotes());
|
||||||
|
@ -6562,6 +6567,7 @@ bool FurnaceGUI::init() {
|
||||||
oscOpen=e->getConfBool("oscOpen",true);
|
oscOpen=e->getConfBool("oscOpen",true);
|
||||||
chanOscOpen=e->getConfBool("chanOscOpen",false);
|
chanOscOpen=e->getConfBool("chanOscOpen",false);
|
||||||
xyOscOpen=e->getConfBool("xyOscOpen",false);
|
xyOscOpen=e->getConfBool("xyOscOpen",false);
|
||||||
|
memoryOpen=e->getConfBool("memoryOpen",false);
|
||||||
volMeterOpen=e->getConfBool("volMeterOpen",true);
|
volMeterOpen=e->getConfBool("volMeterOpen",true);
|
||||||
statsOpen=e->getConfBool("statsOpen",false);
|
statsOpen=e->getConfBool("statsOpen",false);
|
||||||
compatFlagsOpen=e->getConfBool("compatFlagsOpen",false);
|
compatFlagsOpen=e->getConfBool("compatFlagsOpen",false);
|
||||||
|
@ -7124,6 +7130,7 @@ void FurnaceGUI::commitState() {
|
||||||
e->setConf("oscOpen",oscOpen);
|
e->setConf("oscOpen",oscOpen);
|
||||||
e->setConf("chanOscOpen",chanOscOpen);
|
e->setConf("chanOscOpen",chanOscOpen);
|
||||||
e->setConf("xyOscOpen",xyOscOpen);
|
e->setConf("xyOscOpen",xyOscOpen);
|
||||||
|
e->setConf("memoryOpen",memoryOpen);
|
||||||
e->setConf("volMeterOpen",volMeterOpen);
|
e->setConf("volMeterOpen",volMeterOpen);
|
||||||
e->setConf("statsOpen",statsOpen);
|
e->setConf("statsOpen",statsOpen);
|
||||||
e->setConf("compatFlagsOpen",compatFlagsOpen);
|
e->setConf("compatFlagsOpen",compatFlagsOpen);
|
||||||
|
@ -7487,6 +7494,7 @@ FurnaceGUI::FurnaceGUI():
|
||||||
speedOpen(true),
|
speedOpen(true),
|
||||||
groovesOpen(false),
|
groovesOpen(false),
|
||||||
xyOscOpen(false),
|
xyOscOpen(false),
|
||||||
|
memoryOpen(false),
|
||||||
shortIntro(false),
|
shortIntro(false),
|
||||||
insListDir(false),
|
insListDir(false),
|
||||||
waveListDir(false),
|
waveListDir(false),
|
||||||
|
|
|
@ -457,6 +457,7 @@ enum FurnaceGUIWindows {
|
||||||
GUI_WINDOW_GROOVES,
|
GUI_WINDOW_GROOVES,
|
||||||
GUI_WINDOW_XY_OSC,
|
GUI_WINDOW_XY_OSC,
|
||||||
GUI_WINDOW_INTRO_MON,
|
GUI_WINDOW_INTRO_MON,
|
||||||
|
GUI_WINDOW_MEMORY,
|
||||||
GUI_WINDOW_SPOILER
|
GUI_WINDOW_SPOILER
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -647,6 +648,7 @@ enum FurnaceGUIActions {
|
||||||
GUI_ACTION_WINDOW_CLOCK,
|
GUI_ACTION_WINDOW_CLOCK,
|
||||||
GUI_ACTION_WINDOW_GROOVES,
|
GUI_ACTION_WINDOW_GROOVES,
|
||||||
GUI_ACTION_WINDOW_XY_OSC,
|
GUI_ACTION_WINDOW_XY_OSC,
|
||||||
|
GUI_ACTION_WINDOW_MEMORY,
|
||||||
|
|
||||||
GUI_ACTION_COLLAPSE_WINDOW,
|
GUI_ACTION_COLLAPSE_WINDOW,
|
||||||
GUI_ACTION_CLOSE_WINDOW,
|
GUI_ACTION_CLOSE_WINDOW,
|
||||||
|
@ -2042,7 +2044,7 @@ class FurnaceGUI {
|
||||||
bool mixerOpen, debugOpen, inspectorOpen, oscOpen, volMeterOpen, statsOpen, compatFlagsOpen;
|
bool mixerOpen, debugOpen, inspectorOpen, oscOpen, volMeterOpen, statsOpen, compatFlagsOpen;
|
||||||
bool pianoOpen, notesOpen, channelsOpen, regViewOpen, logOpen, effectListOpen, chanOscOpen;
|
bool pianoOpen, notesOpen, channelsOpen, regViewOpen, logOpen, effectListOpen, chanOscOpen;
|
||||||
bool subSongsOpen, findOpen, spoilerOpen, patManagerOpen, sysManagerOpen, clockOpen, speedOpen;
|
bool subSongsOpen, findOpen, spoilerOpen, patManagerOpen, sysManagerOpen, clockOpen, speedOpen;
|
||||||
bool groovesOpen, xyOscOpen;
|
bool groovesOpen, xyOscOpen, memoryOpen;
|
||||||
|
|
||||||
bool shortIntro;
|
bool shortIntro;
|
||||||
bool insListDir, waveListDir, sampleListDir;
|
bool insListDir, waveListDir, sampleListDir;
|
||||||
|
@ -2539,6 +2541,7 @@ class FurnaceGUI {
|
||||||
void drawChanOsc();
|
void drawChanOsc();
|
||||||
void drawVolMeter();
|
void drawVolMeter();
|
||||||
void drawStats();
|
void drawStats();
|
||||||
|
void drawMemory();
|
||||||
void drawCompatFlags();
|
void drawCompatFlags();
|
||||||
void drawPiano();
|
void drawPiano();
|
||||||
void drawNotes();
|
void drawNotes();
|
||||||
|
|
|
@ -605,6 +605,7 @@ const FurnaceGUIActionDef guiActions[GUI_ACTION_MAX]={
|
||||||
D("WINDOW_CLOCK", "Clock", 0),
|
D("WINDOW_CLOCK", "Clock", 0),
|
||||||
D("WINDOW_GROOVES", "Grooves", 0),
|
D("WINDOW_GROOVES", "Grooves", 0),
|
||||||
D("WINDOW_XY_OSC", "Oscilloscope (X-Y)", 0),
|
D("WINDOW_XY_OSC", "Oscilloscope (X-Y)", 0),
|
||||||
|
D("WINDOW_MEMORY", "Memory Compositiom", 0),
|
||||||
|
|
||||||
D("COLLAPSE_WINDOW", "Collapse/expand current window", 0),
|
D("COLLAPSE_WINDOW", "Collapse/expand current window", 0),
|
||||||
D("CLOSE_WINDOW", "Close current window", FURKMOD_SHIFT|SDLK_ESCAPE),
|
D("CLOSE_WINDOW", "Close current window", FURKMOD_SHIFT|SDLK_ESCAPE),
|
||||||
|
|
36
src/gui/memory.cpp
Normal file
36
src/gui/memory.cpp
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
/**
|
||||||
|
* Furnace Tracker - multi-system chiptune tracker
|
||||||
|
* Copyright (C) 2021-2024 tildearrow and contributors
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "gui.h"
|
||||||
|
#include <fmt/printf.h>
|
||||||
|
#include <imgui.h>
|
||||||
|
|
||||||
|
void FurnaceGUI::drawMemory() {
|
||||||
|
if (nextWindow==GUI_WINDOW_MEMORY) {
|
||||||
|
memoryOpen=true;
|
||||||
|
ImGui::SetNextWindowFocus();
|
||||||
|
nextWindow=GUI_WINDOW_NOTHING;
|
||||||
|
}
|
||||||
|
if (!memoryOpen) return;
|
||||||
|
if (ImGui::Begin("Memory Composition",&memoryOpen,globalWinFlags)) {
|
||||||
|
ImGui::Text("Contents here...");
|
||||||
|
}
|
||||||
|
if (ImGui::IsWindowFocused(ImGuiFocusedFlags_ChildWindows)) curWindow=GUI_WINDOW_MEMORY;
|
||||||
|
ImGui::End();
|
||||||
|
}
|
|
@ -1750,11 +1750,13 @@ void FurnaceGUI::drawSettings() {
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_PIANO);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_PIANO);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_OSCILLOSCOPE);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_OSCILLOSCOPE);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_CHAN_OSC);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_CHAN_OSC);
|
||||||
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_XY_OSC);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_VOL_METER);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_VOL_METER);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_CLOCK);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_CLOCK);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_REGISTER_VIEW);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_REGISTER_VIEW);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_LOG);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_LOG);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_STATS);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_STATS);
|
||||||
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_MEMORY);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_EFFECT_LIST);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_EFFECT_LIST);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_DEBUG);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_DEBUG);
|
||||||
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_ABOUT);
|
UI_KEYBIND_CONFIG(GUI_ACTION_WINDOW_ABOUT);
|
||||||
|
|
Loading…
Reference in a new issue