memory composition, part 2
This commit is contained in:
parent
7a41461883
commit
2d48390eab
3 changed files with 68 additions and 10 deletions
|
|
@ -22,6 +22,9 @@
|
|||
#include "imgui.h"
|
||||
#include "imgui_internal.h"
|
||||
|
||||
#define CENTER_TEXT(text) \
|
||||
ImGui::SetCursorPosX(ImGui::GetCursorPosX()+0.5*(ImGui::GetContentRegionAvail().x-ImGui::CalcTextSize(text).x));
|
||||
|
||||
void FurnaceGUI::drawMemory() {
|
||||
if (nextWindow==GUI_WINDOW_MEMORY) {
|
||||
memoryOpen=true;
|
||||
|
|
@ -33,18 +36,20 @@ void FurnaceGUI::drawMemory() {
|
|||
ImDrawList* dl=ImGui::GetWindowDrawList();
|
||||
ImGuiWindow* window=ImGui::GetCurrentWindow();
|
||||
char tempID[1024];
|
||||
bool have=false;
|
||||
|
||||
for (int i=0; i<e->song.systemLen; i++) {
|
||||
DivDispatch* dispatch=e->getDispatch(i);
|
||||
for (int j=0; j<4; j++) {
|
||||
const DivMemoryComposition* mc=dispatch->getMemCompo(j);
|
||||
if (mc==NULL) break;
|
||||
have=true;
|
||||
|
||||
ImGui::Text("%s: %s",e->getSystemName(e->song.system[i]),mc->name.c_str());
|
||||
ImGui::SameLine();
|
||||
ImGui::Text("%d/%d",(int)mc->used,(int)mc->capacity);
|
||||
ImGui::Text("%d/%d (%.1f%%)",(int)mc->used,(int)mc->capacity,100.0*(double)mc->used/(double)mc->capacity);
|
||||
|
||||
ImVec2 size=ImVec2(ImGui::GetContentRegionAvail().x,48.0f*dpiScale);
|
||||
ImVec2 size=ImVec2(ImGui::GetContentRegionAvail().x,36.0f*dpiScale);
|
||||
ImVec2 minArea=window->DC.CursorPos;
|
||||
ImVec2 maxArea=ImVec2(
|
||||
minArea.x+size.x,
|
||||
|
|
@ -57,15 +62,54 @@ void FurnaceGUI::drawMemory() {
|
|||
if (ImGui::ItemAdd(rect,ImGui::GetID(tempID))) {
|
||||
dl->AddRectFilled(rect.Min,rect.Max,ImGui::GetColorU32(uiColors[GUI_COLOR_MEMORY_BG]));
|
||||
|
||||
int curHover=-1;
|
||||
int kIndex=0;
|
||||
if (mc->capacity>0) for (const DivMemoryEntry& k: mc->entries) {
|
||||
ImVec2 pos1=ImLerp(rect.Min,rect.Max,ImVec2((double)k.begin/(double)mc->capacity,0.0f));
|
||||
ImVec2 pos2=ImLerp(rect.Min,rect.Max,ImVec2((double)k.end/(double)mc->capacity,1.0f));
|
||||
ImVec2 linePos=pos1;
|
||||
linePos.y=rect.Max.y;
|
||||
|
||||
dl->AddRectFilled(pos1,pos2,ImGui::GetColorU32(uiColors[GUI_COLOR_MEMORY_FREE+(int)k.type]));
|
||||
dl->AddLine(pos1,linePos,ImGui::GetColorU32(ImGuiCol_Border),dpiScale);
|
||||
|
||||
if (ImGui::GetMousePos().x>=pos1.x && ImGui::GetMousePos().x<=pos2.x) {
|
||||
curHover=kIndex;
|
||||
}
|
||||
kIndex++;
|
||||
}
|
||||
|
||||
if (ImGui::ItemHoverable(rect,ImGui::GetID(tempID),0)) {
|
||||
if (curHover>=0 && curHover<(int)mc->entries.size()) {
|
||||
const DivMemoryEntry& entry=mc->entries[curHover];
|
||||
if (ImGui::BeginTooltip()) {
|
||||
switch (entry.type) {
|
||||
case DIV_MEMORY_SAMPLE: {
|
||||
DivSample* sample=e->getSample(entry.asset);
|
||||
ImGui::Text("%d: %s",curHover,sample->name.c_str());
|
||||
ImGui::Text("%d-%d ($%x-$%x): %d bytes ($%x)",(int)entry.begin,(int)entry.end-1,(int)entry.begin,(int)entry.end-1,(int)(entry.end-entry.begin),(int)(entry.end-entry.begin));
|
||||
ImGui::Text("click to open sample editor");
|
||||
break;
|
||||
}
|
||||
default:
|
||||
ImGui::Text("%d: %s",curHover,entry.name.c_str());
|
||||
ImGui::Text("%d-%d ($%x-$%x): %d bytes ($%x)",(int)entry.begin,(int)entry.end-1,(int)entry.begin,(int)entry.end-1,(int)(entry.end-entry.begin),(int)(entry.end-entry.begin));
|
||||
break;
|
||||
}
|
||||
|
||||
ImGui::EndTooltip();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!have) {
|
||||
ImGui::SetCursorPosY(ImGui::GetCursorPosY()+(ImGui::GetContentRegionAvail().y-ImGui::GetFrameHeight()+ImGui::GetStyle().ItemSpacing.y)*0.5f);
|
||||
CENTER_TEXT("no chips with memory");
|
||||
ImGui::Text("no chips with memory");
|
||||
}
|
||||
}
|
||||
if (ImGui::IsWindowFocused(ImGuiFocusedFlags_ChildWindows)) curWindow=GUI_WINDOW_MEMORY;
|
||||
ImGui::End();
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue