mirror of
https://github.com/tildearrow/furnace.git
synced 2025-01-03 22:21:09 +00:00
GUI: revamp instrument editor
This commit is contained in:
parent
7568f1a1b9
commit
325478e37a
4 changed files with 271 additions and 287 deletions
|
@ -180,18 +180,6 @@ bool DivEngine::isSTDSystem(DivSystem sys) {
|
||||||
return (sys!=DIV_SYSTEM_ARCADE && sys!=DIV_SYSTEM_YMU759);
|
return (sys!=DIV_SYSTEM_ARCADE && sys!=DIV_SYSTEM_YMU759);
|
||||||
}
|
}
|
||||||
|
|
||||||
int DivEngine::getWaveRes(DivSystem sys) {
|
|
||||||
switch (sys) {
|
|
||||||
case DIV_SYSTEM_GB:
|
|
||||||
return 15;
|
|
||||||
case DIV_SYSTEM_PCE:
|
|
||||||
return 31;
|
|
||||||
default:
|
|
||||||
return 31;
|
|
||||||
}
|
|
||||||
return 31;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char* chanNames[11][17]={
|
const char* chanNames[11][17]={
|
||||||
{"Channel 1", "Channel 2", "Channel 3", "Channel 4", "Channel 5", "Channel 6", "Channel 7", "Channel 8", "Channel 9", "Channel 10", "Channel 11", "Channel 12", "Channel 13", "Channel 14", "Channel 15", "Channel 16", "PCM"}, // YMU759
|
{"Channel 1", "Channel 2", "Channel 3", "Channel 4", "Channel 5", "Channel 6", "Channel 7", "Channel 8", "Channel 9", "Channel 10", "Channel 11", "Channel 12", "Channel 13", "Channel 14", "Channel 15", "Channel 16", "PCM"}, // YMU759
|
||||||
{"FM 1", "FM 2", "FM 3", "FM 4", "FM 5", "FM 6", "Square 1", "Square 2", "Square 3", "Noise"}, // Genesis
|
{"FM 1", "FM 2", "FM 3", "FM 4", "FM 5", "FM 6", "Square 1", "Square 2", "Square 3", "Noise"}, // Genesis
|
||||||
|
@ -353,45 +341,6 @@ int DivEngine::getChannelType(int chan) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: multi system support
|
|
||||||
int DivEngine::getMaxVolume() {
|
|
||||||
switch (song.system[0]) {
|
|
||||||
case DIV_SYSTEM_PCE:
|
|
||||||
return 31;
|
|
||||||
default:
|
|
||||||
return 15;
|
|
||||||
}
|
|
||||||
return 127;
|
|
||||||
}
|
|
||||||
|
|
||||||
int DivEngine::getMaxDuty() {
|
|
||||||
switch (song.system[0]) {
|
|
||||||
case DIV_SYSTEM_YM2610: case DIV_SYSTEM_YM2610_EXT:
|
|
||||||
return 31;
|
|
||||||
case DIV_SYSTEM_C64_6581: case DIV_SYSTEM_C64_8580:
|
|
||||||
return 8;
|
|
||||||
case DIV_SYSTEM_PCE:
|
|
||||||
return 0;
|
|
||||||
default:
|
|
||||||
return 3;
|
|
||||||
}
|
|
||||||
return 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
int DivEngine::getMaxWave() {
|
|
||||||
switch (song.system[0]) {
|
|
||||||
case DIV_SYSTEM_PCE: case DIV_SYSTEM_GB:
|
|
||||||
return 63;
|
|
||||||
case DIV_SYSTEM_YM2610: case DIV_SYSTEM_YM2610_EXT:
|
|
||||||
return 7;
|
|
||||||
case DIV_SYSTEM_C64_6581: case DIV_SYSTEM_C64_8580:
|
|
||||||
return 8;
|
|
||||||
default:
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool DivEngine::loadDMF(unsigned char* file, size_t len) {
|
bool DivEngine::loadDMF(unsigned char* file, size_t len) {
|
||||||
SafeReader reader=SafeReader(file,len);
|
SafeReader reader=SafeReader(file,len);
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -262,9 +262,6 @@ class DivEngine {
|
||||||
// is STD system
|
// is STD system
|
||||||
bool isSTDSystem(DivSystem sys);
|
bool isSTDSystem(DivSystem sys);
|
||||||
|
|
||||||
// get wave resolution
|
|
||||||
int getWaveRes(DivSystem sys);
|
|
||||||
|
|
||||||
// is channel muted
|
// is channel muted
|
||||||
bool isChannelMuted(int chan);
|
bool isChannelMuted(int chan);
|
||||||
|
|
||||||
|
@ -286,15 +283,6 @@ class DivEngine {
|
||||||
// get channel max volume
|
// get channel max volume
|
||||||
int getMaxVolumeChan(int chan);
|
int getMaxVolumeChan(int chan);
|
||||||
|
|
||||||
// get max STD volume
|
|
||||||
int getMaxVolume();
|
|
||||||
|
|
||||||
// get max STD duty
|
|
||||||
int getMaxDuty();
|
|
||||||
|
|
||||||
// get max STD wave
|
|
||||||
int getMaxWave();
|
|
||||||
|
|
||||||
// get current order
|
// get current order
|
||||||
unsigned char getOrder();
|
unsigned char getOrder();
|
||||||
|
|
||||||
|
|
491
src/gui/gui.cpp
491
src/gui/gui.cpp
|
@ -31,6 +31,7 @@
|
||||||
const int _ZERO=0;
|
const int _ZERO=0;
|
||||||
const int _ONE=1;
|
const int _ONE=1;
|
||||||
const int _THREE=3;
|
const int _THREE=3;
|
||||||
|
const int _FOUR=4;
|
||||||
const int _SEVEN=7;
|
const int _SEVEN=7;
|
||||||
const int _TEN=10;
|
const int _TEN=10;
|
||||||
const int _FIFTEEN=15;
|
const int _FIFTEEN=15;
|
||||||
|
@ -528,12 +529,31 @@ void FurnaceGUI::drawInsList() {
|
||||||
for (int i=0; i<(int)e->song.ins.size(); i++) {
|
for (int i=0; i<(int)e->song.ins.size(); i++) {
|
||||||
DivInstrument* ins=e->song.ins[i];
|
DivInstrument* ins=e->song.ins[i];
|
||||||
String name;
|
String name;
|
||||||
if (ins->mode) { // FM
|
switch (ins->type) {
|
||||||
ImGui::PushStyleColor(ImGuiCol_Text,uiColors[GUI_COLOR_INSTR_FM]);
|
case DIV_INS_FM:
|
||||||
name=fmt::sprintf(ICON_FA_AREA_CHART "%.2x: %s##_INS%d\n",i,ins->name,i);
|
ImGui::PushStyleColor(ImGuiCol_Text,uiColors[GUI_COLOR_INSTR_FM]);
|
||||||
} else { // STD
|
name=fmt::sprintf(ICON_FA_AREA_CHART " %.2x: %s##_INS%d\n",i,ins->name,i);
|
||||||
ImGui::PushStyleColor(ImGuiCol_Text,uiColors[GUI_COLOR_INSTR_STD]);
|
break;
|
||||||
name=fmt::sprintf(ICON_FA_BAR_CHART "%.2x: %s##_INS%d\n",i,ins->name,i);
|
case DIV_INS_STD:
|
||||||
|
ImGui::PushStyleColor(ImGuiCol_Text,uiColors[GUI_COLOR_INSTR_STD]);
|
||||||
|
name=fmt::sprintf(ICON_FA_BAR_CHART " %.2x: %s##_INS%d\n",i,ins->name,i);
|
||||||
|
break;
|
||||||
|
case DIV_INS_GB:
|
||||||
|
ImGui::PushStyleColor(ImGuiCol_Text,uiColors[GUI_COLOR_INSTR_GB]);
|
||||||
|
name=fmt::sprintf(ICON_FA_GAMEPAD " %.2x: %s##_INS%d\n",i,ins->name,i);
|
||||||
|
break;
|
||||||
|
case DIV_INS_C64:
|
||||||
|
ImGui::PushStyleColor(ImGuiCol_Text,uiColors[GUI_COLOR_INSTR_C64]);
|
||||||
|
name=fmt::sprintf(ICON_FA_KEYBOARD_O " %.2x: %s##_INS%d\n",i,ins->name,i);
|
||||||
|
break;
|
||||||
|
case DIV_INS_AMIGA:
|
||||||
|
ImGui::PushStyleColor(ImGuiCol_Text,uiColors[GUI_COLOR_INSTR_AMIGA]);
|
||||||
|
name=fmt::sprintf(ICON_FA_FUTBOL_O " %.2x: %s##_INS%d\n",i,ins->name,i);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
ImGui::PushStyleColor(ImGuiCol_Text,uiColors[GUI_COLOR_INSTR_UNKNOWN]);
|
||||||
|
name=fmt::sprintf(ICON_FA_QUESTION " %.2x: %s##_INS%d\n",i,ins->name,i);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
if (ImGui::Selectable(name.c_str(),curIns==i)) {
|
if (ImGui::Selectable(name.c_str(),curIns==i)) {
|
||||||
curIns=i;
|
curIns=i;
|
||||||
|
@ -554,6 +574,10 @@ int detuneTable[8]={
|
||||||
0, 1, 2, 3, 0, -3, -2, -1
|
0, 1, 2, 3, 0, -3, -2, -1
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const char* insTypes[5]={
|
||||||
|
"FM", "Standard", "Game Boy", "C64", "Amiga"
|
||||||
|
};
|
||||||
|
|
||||||
const char* ssgEnvTypes[8]={
|
const char* ssgEnvTypes[8]={
|
||||||
"Down Down Down", "Down.", "Down Up Down Up", "Down UP", "Up Up Up", "Up.", "Up Down Up Down", "Up DOWN"
|
"Down Down Down", "Down.", "Down Up Down Up", "Down UP", "Up Up Up", "Up.", "Up Down Up Down", "Up DOWN"
|
||||||
};
|
};
|
||||||
|
@ -566,44 +590,49 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
} else {
|
} else {
|
||||||
DivInstrument* ins=e->song.ins[curIns];
|
DivInstrument* ins=e->song.ins[curIns];
|
||||||
ImGui::InputText("Name",&ins->name);
|
ImGui::InputText("Name",&ins->name);
|
||||||
if (e->isFMSystem(e->song.system[0]) && e->isSTDSystem(e->song.system[0])) ImGui::Checkbox("FM",&ins->mode);
|
if (ins->type<0 || ins->type>4) ins->type=DIV_INS_FM;
|
||||||
|
if (ImGui::SliderScalar("Type",ImGuiDataType_U8,&ins->type,&_ZERO,&_FOUR,insTypes[ins->type])) {
|
||||||
|
ins->mode=(ins->type==DIV_INS_FM);
|
||||||
|
}
|
||||||
|
|
||||||
if (ins->mode) { // FM
|
if (ImGui::BeginTabBar("insEditTab")) {
|
||||||
ImGui::Columns(3,NULL,false);
|
if (ImGui::BeginTabItem("FM")) {
|
||||||
ImGui::SliderScalar("Algorithm",ImGuiDataType_U8,&ins->fm.alg,&_ZERO,&_SEVEN);
|
ImGui::Columns(3,NULL,false);
|
||||||
ImGui::NextColumn();
|
ImGui::SliderScalar("Algorithm",ImGuiDataType_U8,&ins->fm.alg,&_ZERO,&_SEVEN);
|
||||||
ImGui::SliderScalar("Feedback",ImGuiDataType_U8,&ins->fm.fb,&_ZERO,&_SEVEN);
|
ImGui::NextColumn();
|
||||||
ImGui::NextColumn();
|
ImGui::SliderScalar("Feedback",ImGuiDataType_U8,&ins->fm.fb,&_ZERO,&_SEVEN);
|
||||||
ImGui::Text("Algorithm here!");
|
ImGui::NextColumn();
|
||||||
ImGui::NextColumn();
|
ImGui::Text("Algorithm here!");
|
||||||
ImGui::SliderScalar("LFO > Freq",ImGuiDataType_U8,&ins->fm.fms,&_ZERO,&_SEVEN);
|
ImGui::NextColumn();
|
||||||
ImGui::NextColumn();
|
ImGui::SliderScalar("LFO > Freq",ImGuiDataType_U8,&ins->fm.fms,&_ZERO,&_SEVEN);
|
||||||
ImGui::SliderScalar("LFO > Amp",ImGuiDataType_U8,&ins->fm.ams,&_ZERO,&_THREE);
|
ImGui::NextColumn();
|
||||||
ImGui::Columns(1);
|
ImGui::SliderScalar("LFO > Amp",ImGuiDataType_U8,&ins->fm.ams,&_ZERO,&_THREE);
|
||||||
if (ImGui::BeginTable("FMOperators",2)) {
|
ImGui::Columns(1);
|
||||||
for (int i=0; i<4; i++) {
|
if (ImGui::BeginTable("FMOperators",2)) {
|
||||||
DivInstrumentFM::Operator& op=ins->fm.op[opOrder[i]];
|
for (int i=0; i<4; i++) {
|
||||||
if ((i+1)&1) ImGui::TableNextRow();
|
DivInstrumentFM::Operator& op=ins->fm.op[opOrder[i]];
|
||||||
ImGui::TableNextColumn();
|
if ((i+1)&1) ImGui::TableNextRow();
|
||||||
|
ImGui::TableNextColumn();
|
||||||
|
|
||||||
ImGui::PushID(fmt::sprintf("op%d",i).c_str());
|
ImGui::PushID(fmt::sprintf("op%d",i).c_str());
|
||||||
ImGui::Text("Operator %d",i+1);
|
ImGui::Text("Operator %d",i+1);
|
||||||
ImGui::SliderScalar("Level",ImGuiDataType_U8,&op.tl,&_ZERO,&_ONE_HUNDRED_TWENTY_SEVEN);
|
ImGui::SliderScalar("Level",ImGuiDataType_U8,&op.tl,&_ZERO,&_ONE_HUNDRED_TWENTY_SEVEN);
|
||||||
ImGui::SliderScalar("Attack",ImGuiDataType_U8,&op.ar,&_ZERO,&_THIRTY_ONE);
|
ImGui::SliderScalar("Attack",ImGuiDataType_U8,&op.ar,&_ZERO,&_THIRTY_ONE);
|
||||||
ImGui::SliderScalar("Decay",ImGuiDataType_U8,&op.dr,&_ZERO,&_THIRTY_ONE);
|
ImGui::SliderScalar("Decay",ImGuiDataType_U8,&op.dr,&_ZERO,&_THIRTY_ONE);
|
||||||
ImGui::SliderScalar("Sustain",ImGuiDataType_U8,&op.sl,&_ZERO,&_FIFTEEN);
|
ImGui::SliderScalar("Sustain",ImGuiDataType_U8,&op.sl,&_ZERO,&_FIFTEEN);
|
||||||
ImGui::SliderScalar("Decay 2",ImGuiDataType_U8,&op.d2r,&_ZERO,&_THIRTY_ONE);
|
ImGui::SliderScalar("Decay 2",ImGuiDataType_U8,&op.d2r,&_ZERO,&_THIRTY_ONE);
|
||||||
ImGui::SliderScalar("Release",ImGuiDataType_U8,&op.rr,&_ZERO,&_FIFTEEN);
|
ImGui::SliderScalar("Release",ImGuiDataType_U8,&op.rr,&_ZERO,&_FIFTEEN);
|
||||||
|
|
||||||
ImGui::SliderScalar("Multiplier",ImGuiDataType_U8,&op.mult,&_ZERO,&_FIFTEEN);
|
ImGui::SliderScalar("Multiplier",ImGuiDataType_U8,&op.mult,&_ZERO,&_FIFTEEN);
|
||||||
ImGui::SliderScalar("EnvScale",ImGuiDataType_U8,&op.rs,&_ZERO,&_THREE);
|
ImGui::SliderScalar("EnvScale",ImGuiDataType_U8,&op.rs,&_ZERO,&_THREE);
|
||||||
int detune=detuneTable[op.dt&7];
|
int detune=detuneTable[op.dt&7];
|
||||||
if (ImGui::SliderInt("Detune",&detune,-3,3)) {
|
if (ImGui::SliderInt("Detune",&detune,-3,3)) {
|
||||||
op.dt=detune&7;
|
op.dt=detune&7;
|
||||||
}
|
}
|
||||||
if (e->song.system[0]==DIV_SYSTEM_ARCADE) {
|
|
||||||
ImGui::SliderScalar("Detune 2",ImGuiDataType_U8,&op.dt2,&_ZERO,&_THREE);
|
ImGui::SliderScalar("Detune 2",ImGuiDataType_U8,&op.dt2,&_ZERO,&_THREE);
|
||||||
} else {
|
if (ImGui::IsItemHovered()) {
|
||||||
|
ImGui::SetTooltip("Only for Arcade platform");
|
||||||
|
}
|
||||||
bool ssgOn=op.ssgEnv&8;
|
bool ssgOn=op.ssgEnv&8;
|
||||||
unsigned char ssgEnv=op.ssgEnv&7;
|
unsigned char ssgEnv=op.ssgEnv&7;
|
||||||
if (ImGui::SliderScalar("SSG-EG",ImGuiDataType_U8,&ssgEnv,&_ZERO,&_SEVEN,ssgEnvTypes[ssgEnv])) {
|
if (ImGui::SliderScalar("SSG-EG",ImGuiDataType_U8,&ssgEnv,&_ZERO,&_SEVEN,ssgEnvTypes[ssgEnv])) {
|
||||||
|
@ -613,20 +642,190 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
if (ImGui::Checkbox("##SSGOn",&ssgOn)) {
|
if (ImGui::Checkbox("##SSGOn",&ssgOn)) {
|
||||||
op.ssgEnv=(op.ssgEnv&7)|(ssgOn<<3);
|
op.ssgEnv=(op.ssgEnv&7)|(ssgOn<<3);
|
||||||
}
|
}
|
||||||
|
if (ImGui::IsItemHovered()) {
|
||||||
|
ImGui::SetTooltip("Only for Genesis and Neo Geo platforms");
|
||||||
|
}
|
||||||
|
|
||||||
|
bool amOn=op.am;
|
||||||
|
if (ImGui::Checkbox("AM",&amOn)) op.am=amOn;
|
||||||
|
ImGui::PopID();
|
||||||
}
|
}
|
||||||
|
ImGui::EndTable();
|
||||||
bool amOn=op.am;
|
|
||||||
if (ImGui::Checkbox("AM",&amOn)) op.am=amOn;
|
|
||||||
ImGui::PopID();
|
|
||||||
}
|
}
|
||||||
ImGui::EndTable();
|
ImGui::EndTabItem();
|
||||||
}
|
}
|
||||||
} else { // STD
|
if (ImGui::BeginTabItem("Macros")) {
|
||||||
float asFloat[128];
|
float asFloat[128];
|
||||||
float loopIndicator[128];
|
float loopIndicator[128];
|
||||||
|
|
||||||
// GB specifics
|
// volume macro
|
||||||
if (e->song.system[0]==DIV_SYSTEM_GB) {
|
ImGui::Separator();
|
||||||
|
if (ins->type==DIV_INS_C64 && ins->c64.volIsCutoff) {
|
||||||
|
ImGui::Text("Relative Cutoff Macro");
|
||||||
|
} else {
|
||||||
|
ImGui::Text("Volume Macro");
|
||||||
|
}
|
||||||
|
for (int i=0; i<ins->std.volMacroLen; i++) {
|
||||||
|
if (ins->type==DIV_INS_C64 && ins->c64.volIsCutoff) {
|
||||||
|
asFloat[i]=ins->std.volMacro[i]-18;
|
||||||
|
} else {
|
||||||
|
asFloat[i]=ins->std.volMacro[i];
|
||||||
|
}
|
||||||
|
loopIndicator[i]=(ins->std.volMacroLoop!=-1 && i>=ins->std.volMacroLoop);
|
||||||
|
}
|
||||||
|
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
||||||
|
int volMax=15; // TODO: PCE
|
||||||
|
if (ins->type==DIV_INS_C64) {
|
||||||
|
if (ins->c64.volIsCutoff) volMax=36;
|
||||||
|
}
|
||||||
|
ImGui::PlotHistogram("##IVolMacro",asFloat,ins->std.volMacroLen,0,NULL,0,volMax,ImVec2(400.0f*dpiScale,200.0f*dpiScale));
|
||||||
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
||||||
|
macroDragStart=ImGui::GetItemRectMin();
|
||||||
|
macroDragAreaSize=ImVec2(400.0f*dpiScale,200.0f*dpiScale);
|
||||||
|
macroDragMin=0;
|
||||||
|
macroDragMax=volMax;
|
||||||
|
macroDragLen=ins->std.volMacroLen;
|
||||||
|
macroDragActive=true;
|
||||||
|
macroDragTarget=ins->std.volMacro;
|
||||||
|
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
||||||
|
}
|
||||||
|
ImGui::PlotHistogram("##IVolMacroLoop",loopIndicator,ins->std.volMacroLen,0,NULL,0,1,ImVec2(400.0f*dpiScale,16.0f*dpiScale));
|
||||||
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
||||||
|
macroLoopDragStart=ImGui::GetItemRectMin();
|
||||||
|
macroLoopDragAreaSize=ImVec2(400.0f*dpiScale,16.0f*dpiScale);
|
||||||
|
macroLoopDragLen=ins->std.volMacroLen;
|
||||||
|
macroLoopDragTarget=&ins->std.volMacroLoop;
|
||||||
|
macroLoopDragActive=true;
|
||||||
|
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
||||||
|
}
|
||||||
|
ImGui::PopStyleVar();
|
||||||
|
if (ImGui::InputScalar("Length##IVolMacroL",ImGuiDataType_U8,&ins->std.volMacroLen,&_ONE,&_THREE)) {
|
||||||
|
if (ins->std.volMacroLen>127) ins->std.volMacroLen=127;
|
||||||
|
}
|
||||||
|
|
||||||
|
// arp macro
|
||||||
|
ImGui::Separator();
|
||||||
|
ImGui::Text("Arpeggio Macro");
|
||||||
|
bool arpMode=ins->std.arpMacroMode;
|
||||||
|
for (int i=0; i<ins->std.arpMacroLen; i++) {
|
||||||
|
asFloat[i]=arpMode?ins->std.arpMacro[i]:(ins->std.arpMacro[i]-12);
|
||||||
|
loopIndicator[i]=(ins->std.arpMacroLoop!=-1 && i>=ins->std.arpMacroLoop);
|
||||||
|
}
|
||||||
|
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
||||||
|
ImGui::PlotHistogram("##IArpMacro",asFloat,ins->std.arpMacroLen,0,NULL,arpMode?arpMacroScroll:(arpMacroScroll-12),arpMacroScroll+(arpMode?24:12),ImVec2(400.0f*dpiScale,200.0f*dpiScale));
|
||||||
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
||||||
|
macroDragStart=ImGui::GetItemRectMin();
|
||||||
|
macroDragAreaSize=ImVec2(400.0f*dpiScale,200.0f*dpiScale);
|
||||||
|
macroDragMin=arpMacroScroll;
|
||||||
|
macroDragMax=arpMacroScroll+24;
|
||||||
|
macroDragLen=ins->std.arpMacroLen;
|
||||||
|
macroDragActive=true;
|
||||||
|
macroDragTarget=ins->std.arpMacro;
|
||||||
|
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
||||||
|
}
|
||||||
|
ImGui::SameLine();
|
||||||
|
ImGui::VSliderInt("##IArpMacroPos",ImVec2(20.0f*dpiScale,200.0f*dpiScale),&arpMacroScroll,arpMode?0:-80,70);
|
||||||
|
ImGui::PlotHistogram("##IArpMacroLoop",loopIndicator,ins->std.arpMacroLen,0,NULL,0,1,ImVec2(400.0f*dpiScale,16.0f*dpiScale));
|
||||||
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
||||||
|
macroLoopDragStart=ImGui::GetItemRectMin();
|
||||||
|
macroLoopDragAreaSize=ImVec2(400.0f*dpiScale,16.0f*dpiScale);
|
||||||
|
macroLoopDragLen=ins->std.arpMacroLen;
|
||||||
|
macroLoopDragTarget=&ins->std.arpMacroLoop;
|
||||||
|
macroLoopDragActive=true;
|
||||||
|
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
||||||
|
}
|
||||||
|
ImGui::PopStyleVar();
|
||||||
|
if (ImGui::InputScalar("Length##IArpMacroL",ImGuiDataType_U8,&ins->std.arpMacroLen,&_ONE,&_THREE)) {
|
||||||
|
if (ins->std.arpMacroLen>127) ins->std.arpMacroLen=127;
|
||||||
|
}
|
||||||
|
if (ImGui::Checkbox("Absolute",&arpMode)) {
|
||||||
|
ins->std.arpMacroMode=arpMode;
|
||||||
|
if (arpMode) {
|
||||||
|
if (arpMacroScroll<0) arpMacroScroll=0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// duty macro TODO
|
||||||
|
int dutyMax=31;
|
||||||
|
if (dutyMax>0) {
|
||||||
|
ImGui::Separator();
|
||||||
|
if (ins->type==DIV_INS_C64) {
|
||||||
|
ImGui::Text("Relative Duty Macro");
|
||||||
|
} else {
|
||||||
|
ImGui::Text("Duty/Noise Mode Macro");
|
||||||
|
}
|
||||||
|
for (int i=0; i<ins->std.dutyMacroLen; i++) {
|
||||||
|
asFloat[i]=ins->std.dutyMacro[i];
|
||||||
|
loopIndicator[i]=(ins->std.dutyMacroLoop!=-1 && i>=ins->std.dutyMacroLoop);
|
||||||
|
}
|
||||||
|
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
||||||
|
|
||||||
|
ImGui::PlotHistogram("##IDutyMacro",asFloat,ins->std.dutyMacroLen,0,NULL,0,dutyMax,ImVec2(400.0f*dpiScale,200.0f*dpiScale));
|
||||||
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
||||||
|
macroDragStart=ImGui::GetItemRectMin();
|
||||||
|
macroDragAreaSize=ImVec2(400.0f*dpiScale,200.0f*dpiScale);
|
||||||
|
macroDragMin=0;
|
||||||
|
macroDragMax=dutyMax;
|
||||||
|
macroDragLen=ins->std.dutyMacroLen;
|
||||||
|
macroDragActive=true;
|
||||||
|
macroDragTarget=ins->std.dutyMacro;
|
||||||
|
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
||||||
|
}
|
||||||
|
ImGui::PlotHistogram("##IDutyMacroLoop",loopIndicator,ins->std.dutyMacroLen,0,NULL,0,1,ImVec2(400.0f*dpiScale,16.0f*dpiScale));
|
||||||
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
||||||
|
macroLoopDragStart=ImGui::GetItemRectMin();
|
||||||
|
macroLoopDragAreaSize=ImVec2(400.0f*dpiScale,16.0f*dpiScale);
|
||||||
|
macroLoopDragLen=ins->std.dutyMacroLen;
|
||||||
|
macroLoopDragTarget=&ins->std.dutyMacroLoop;
|
||||||
|
macroLoopDragActive=true;
|
||||||
|
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
||||||
|
}
|
||||||
|
ImGui::PopStyleVar();
|
||||||
|
if (ImGui::InputScalar("Length##IDutyMacroL",ImGuiDataType_U8,&ins->std.dutyMacroLen,&_ONE,&_THREE)) {
|
||||||
|
if (ins->std.dutyMacroLen>127) ins->std.dutyMacroLen=127;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// wave macro
|
||||||
|
int waveMax=63;
|
||||||
|
if (ins->type==DIV_INS_C64) waveMax=8;
|
||||||
|
if (waveMax>0) {
|
||||||
|
ImGui::Separator();
|
||||||
|
ImGui::Text("Waveform Macro");
|
||||||
|
for (int i=0; i<ins->std.waveMacroLen; i++) {
|
||||||
|
asFloat[i]=ins->std.waveMacro[i];
|
||||||
|
loopIndicator[i]=(ins->std.waveMacroLoop!=-1 && i>=ins->std.waveMacroLoop);
|
||||||
|
}
|
||||||
|
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
||||||
|
|
||||||
|
ImGui::PlotHistogram("##IWaveMacro",asFloat,ins->std.waveMacroLen,0,NULL,0,waveMax,ImVec2(400.0f*dpiScale,200.0f*dpiScale));
|
||||||
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
||||||
|
macroDragStart=ImGui::GetItemRectMin();
|
||||||
|
macroDragAreaSize=ImVec2(400.0f*dpiScale,200.0f*dpiScale);
|
||||||
|
macroDragMin=0;
|
||||||
|
macroDragMax=waveMax;
|
||||||
|
macroDragLen=ins->std.waveMacroLen;
|
||||||
|
macroDragActive=true;
|
||||||
|
macroDragTarget=ins->std.waveMacro;
|
||||||
|
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
||||||
|
}
|
||||||
|
ImGui::PlotHistogram("##IWaveMacroLoop",loopIndicator,ins->std.waveMacroLen,0,NULL,0,1,ImVec2(400.0f*dpiScale,16.0f*dpiScale));
|
||||||
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
||||||
|
macroLoopDragStart=ImGui::GetItemRectMin();
|
||||||
|
macroLoopDragAreaSize=ImVec2(400.0f*dpiScale,16.0f*dpiScale);
|
||||||
|
macroLoopDragLen=ins->std.waveMacroLen;
|
||||||
|
macroLoopDragTarget=&ins->std.waveMacroLoop;
|
||||||
|
macroLoopDragActive=true;
|
||||||
|
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
||||||
|
}
|
||||||
|
ImGui::PopStyleVar();
|
||||||
|
if (ImGui::InputScalar("Length##IWaveMacroL",ImGuiDataType_U8,&ins->std.waveMacroLen,&_ONE,&_THREE)) {
|
||||||
|
if (ins->std.waveMacroLen>127) ins->std.waveMacroLen=127;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ImGui::EndTabItem();
|
||||||
|
}
|
||||||
|
if (ImGui::BeginTabItem("Game Boy")) {
|
||||||
ImGui::SliderScalar("Volume",ImGuiDataType_U8,&ins->gb.envVol,&_ZERO,&_FIFTEEN);
|
ImGui::SliderScalar("Volume",ImGuiDataType_U8,&ins->gb.envVol,&_ZERO,&_FIFTEEN);
|
||||||
ImGui::SliderScalar("Envelope Length",ImGuiDataType_U8,&ins->gb.envLen,&_ZERO,&_SEVEN);
|
ImGui::SliderScalar("Envelope Length",ImGuiDataType_U8,&ins->gb.envLen,&_ZERO,&_SEVEN);
|
||||||
ImGui::SliderScalar("Sound Length",ImGuiDataType_U8,&ins->gb.soundLen,&_ZERO,&_SIXTY_FOUR,ins->gb.soundLen>63?"Infinity":"%d");
|
ImGui::SliderScalar("Sound Length",ImGuiDataType_U8,&ins->gb.soundLen,&_ZERO,&_SIXTY_FOUR,ins->gb.soundLen>63?"Infinity":"%d");
|
||||||
|
@ -634,10 +833,9 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
if (ImGui::Checkbox("Up",&goesUp)) {
|
if (ImGui::Checkbox("Up",&goesUp)) {
|
||||||
ins->gb.envDir=goesUp;
|
ins->gb.envDir=goesUp;
|
||||||
}
|
}
|
||||||
|
ImGui::EndTabItem();
|
||||||
}
|
}
|
||||||
|
if (ImGui::BeginTabItem("C64")) {
|
||||||
// C64 specifics
|
|
||||||
if (e->song.system[0]==DIV_SYSTEM_C64_6581 || e->song.system[0]==DIV_SYSTEM_C64_8580) {
|
|
||||||
ImGui::Text("Waveform");
|
ImGui::Text("Waveform");
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
ImGui::PushStyleColor(ImGuiCol_Button,ImVec4(0.2f,(ins->c64.triOn)?0.6f:0.2f,0.2f,1.0f));
|
ImGui::PushStyleColor(ImGuiCol_Button,ImVec4(0.2f,(ins->c64.triOn)?0.6f:0.2f,0.2f,1.0f));
|
||||||
|
@ -708,176 +906,17 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
ImGui::PopStyleColor();
|
ImGui::PopStyleColor();
|
||||||
|
|
||||||
ImGui::Checkbox("Volume Macro is Cutoff Macro",&ins->c64.volIsCutoff);
|
ImGui::Checkbox("Volume Macro is Cutoff Macro",&ins->c64.volIsCutoff);
|
||||||
|
ImGui::EndTabItem();
|
||||||
}
|
}
|
||||||
|
if (ImGui::BeginTabItem("Amiga")) {
|
||||||
|
ImGui::EndTabItem();
|
||||||
|
}
|
||||||
|
ImGui::EndTabBar();
|
||||||
|
}
|
||||||
|
|
||||||
// volume macro
|
if (ins->mode) { // FM
|
||||||
if (e->song.system[0]!=DIV_SYSTEM_GB) {
|
|
||||||
ImGui::Separator();
|
} else { // STD
|
||||||
if ((e->song.system[0]==DIV_SYSTEM_C64_6581 || e->song.system[0]==DIV_SYSTEM_C64_8580) && ins->c64.volIsCutoff) {
|
|
||||||
ImGui::Text("Relative Cutoff Macro");
|
|
||||||
} else {
|
|
||||||
ImGui::Text("Volume Macro");
|
|
||||||
}
|
|
||||||
for (int i=0; i<ins->std.volMacroLen; i++) {
|
|
||||||
if ((e->song.system[0]==DIV_SYSTEM_C64_6581 || e->song.system[0]==DIV_SYSTEM_C64_8580) && ins->c64.volIsCutoff) {
|
|
||||||
asFloat[i]=ins->std.volMacro[i]-18;
|
|
||||||
} else {
|
|
||||||
asFloat[i]=ins->std.volMacro[i];
|
|
||||||
}
|
|
||||||
loopIndicator[i]=(ins->std.volMacroLoop!=-1 && i>=ins->std.volMacroLoop);
|
|
||||||
}
|
|
||||||
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
|
||||||
int volMax=e->getMaxVolume();
|
|
||||||
if (e->song.system[0]==DIV_SYSTEM_C64_6581 || e->song.system[0]==DIV_SYSTEM_C64_8580) {
|
|
||||||
if (ins->c64.volIsCutoff) volMax=36;
|
|
||||||
}
|
|
||||||
ImGui::PlotHistogram("##IVolMacro",asFloat,ins->std.volMacroLen,0,NULL,0,volMax,ImVec2(400.0f*dpiScale,200.0f*dpiScale));
|
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
|
||||||
macroDragStart=ImGui::GetItemRectMin();
|
|
||||||
macroDragAreaSize=ImVec2(400.0f*dpiScale,200.0f*dpiScale);
|
|
||||||
macroDragMin=0;
|
|
||||||
macroDragMax=volMax;
|
|
||||||
macroDragLen=ins->std.volMacroLen;
|
|
||||||
macroDragActive=true;
|
|
||||||
macroDragTarget=ins->std.volMacro;
|
|
||||||
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
|
||||||
}
|
|
||||||
ImGui::PlotHistogram("##IVolMacroLoop",loopIndicator,ins->std.volMacroLen,0,NULL,0,1,ImVec2(400.0f*dpiScale,16.0f*dpiScale));
|
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
|
||||||
macroLoopDragStart=ImGui::GetItemRectMin();
|
|
||||||
macroLoopDragAreaSize=ImVec2(400.0f*dpiScale,16.0f*dpiScale);
|
|
||||||
macroLoopDragLen=ins->std.volMacroLen;
|
|
||||||
macroLoopDragTarget=&ins->std.volMacroLoop;
|
|
||||||
macroLoopDragActive=true;
|
|
||||||
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
|
||||||
}
|
|
||||||
ImGui::PopStyleVar();
|
|
||||||
if (ImGui::InputScalar("Length##IVolMacroL",ImGuiDataType_U8,&ins->std.volMacroLen,&_ONE,&_THREE)) {
|
|
||||||
if (ins->std.volMacroLen>127) ins->std.volMacroLen=127;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// arp macro
|
|
||||||
ImGui::Separator();
|
|
||||||
ImGui::Text("Arpeggio Macro");
|
|
||||||
bool arpMode=ins->std.arpMacroMode;
|
|
||||||
for (int i=0; i<ins->std.arpMacroLen; i++) {
|
|
||||||
asFloat[i]=arpMode?ins->std.arpMacro[i]:(ins->std.arpMacro[i]-12);
|
|
||||||
loopIndicator[i]=(ins->std.arpMacroLoop!=-1 && i>=ins->std.arpMacroLoop);
|
|
||||||
}
|
|
||||||
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
|
||||||
ImGui::PlotHistogram("##IArpMacro",asFloat,ins->std.arpMacroLen,0,NULL,arpMode?arpMacroScroll:(arpMacroScroll-12),arpMacroScroll+(arpMode?24:12),ImVec2(400.0f*dpiScale,200.0f*dpiScale));
|
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
|
||||||
macroDragStart=ImGui::GetItemRectMin();
|
|
||||||
macroDragAreaSize=ImVec2(400.0f*dpiScale,200.0f*dpiScale);
|
|
||||||
macroDragMin=arpMacroScroll;
|
|
||||||
macroDragMax=arpMacroScroll+24;
|
|
||||||
macroDragLen=ins->std.arpMacroLen;
|
|
||||||
macroDragActive=true;
|
|
||||||
macroDragTarget=ins->std.arpMacro;
|
|
||||||
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
|
||||||
}
|
|
||||||
ImGui::SameLine();
|
|
||||||
ImGui::VSliderInt("##IArpMacroPos",ImVec2(20.0f*dpiScale,200.0f*dpiScale),&arpMacroScroll,arpMode?0:-80,70);
|
|
||||||
ImGui::PlotHistogram("##IArpMacroLoop",loopIndicator,ins->std.arpMacroLen,0,NULL,0,1,ImVec2(400.0f*dpiScale,16.0f*dpiScale));
|
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
|
||||||
macroLoopDragStart=ImGui::GetItemRectMin();
|
|
||||||
macroLoopDragAreaSize=ImVec2(400.0f*dpiScale,16.0f*dpiScale);
|
|
||||||
macroLoopDragLen=ins->std.arpMacroLen;
|
|
||||||
macroLoopDragTarget=&ins->std.arpMacroLoop;
|
|
||||||
macroLoopDragActive=true;
|
|
||||||
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
|
||||||
}
|
|
||||||
ImGui::PopStyleVar();
|
|
||||||
if (ImGui::InputScalar("Length##IArpMacroL",ImGuiDataType_U8,&ins->std.arpMacroLen,&_ONE,&_THREE)) {
|
|
||||||
if (ins->std.arpMacroLen>127) ins->std.arpMacroLen=127;
|
|
||||||
}
|
|
||||||
if (ImGui::Checkbox("Absolute",&arpMode)) {
|
|
||||||
ins->std.arpMacroMode=arpMode;
|
|
||||||
if (arpMode) {
|
|
||||||
if (arpMacroScroll<0) arpMacroScroll=0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// duty macro
|
|
||||||
int dutyMax=e->getMaxDuty();
|
|
||||||
if (dutyMax>0) {
|
|
||||||
ImGui::Separator();
|
|
||||||
if (e->song.system[0]==DIV_SYSTEM_C64_6581 || e->song.system[0]==DIV_SYSTEM_C64_8580) {
|
|
||||||
ImGui::Text("Relative Duty Macro");
|
|
||||||
} else if (e->song.system[0]==DIV_SYSTEM_YM2610 || e->song.system[0]==DIV_SYSTEM_YM2610_EXT) {
|
|
||||||
ImGui::Text("Noise Frequency Macro");
|
|
||||||
} else {
|
|
||||||
ImGui::Text("Duty/Noise Mode Macro");
|
|
||||||
}
|
|
||||||
for (int i=0; i<ins->std.dutyMacroLen; i++) {
|
|
||||||
asFloat[i]=ins->std.dutyMacro[i];
|
|
||||||
loopIndicator[i]=(ins->std.dutyMacroLoop!=-1 && i>=ins->std.dutyMacroLoop);
|
|
||||||
}
|
|
||||||
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
|
||||||
|
|
||||||
ImGui::PlotHistogram("##IDutyMacro",asFloat,ins->std.dutyMacroLen,0,NULL,0,dutyMax,ImVec2(400.0f*dpiScale,200.0f*dpiScale));
|
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
|
||||||
macroDragStart=ImGui::GetItemRectMin();
|
|
||||||
macroDragAreaSize=ImVec2(400.0f*dpiScale,200.0f*dpiScale);
|
|
||||||
macroDragMin=0;
|
|
||||||
macroDragMax=dutyMax;
|
|
||||||
macroDragLen=ins->std.dutyMacroLen;
|
|
||||||
macroDragActive=true;
|
|
||||||
macroDragTarget=ins->std.dutyMacro;
|
|
||||||
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
|
||||||
}
|
|
||||||
ImGui::PlotHistogram("##IDutyMacroLoop",loopIndicator,ins->std.dutyMacroLen,0,NULL,0,1,ImVec2(400.0f*dpiScale,16.0f*dpiScale));
|
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
|
||||||
macroLoopDragStart=ImGui::GetItemRectMin();
|
|
||||||
macroLoopDragAreaSize=ImVec2(400.0f*dpiScale,16.0f*dpiScale);
|
|
||||||
macroLoopDragLen=ins->std.dutyMacroLen;
|
|
||||||
macroLoopDragTarget=&ins->std.dutyMacroLoop;
|
|
||||||
macroLoopDragActive=true;
|
|
||||||
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
|
||||||
}
|
|
||||||
ImGui::PopStyleVar();
|
|
||||||
if (ImGui::InputScalar("Length##IDutyMacroL",ImGuiDataType_U8,&ins->std.dutyMacroLen,&_ONE,&_THREE)) {
|
|
||||||
if (ins->std.dutyMacroLen>127) ins->std.dutyMacroLen=127;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// wave macro
|
|
||||||
int waveMax=e->getMaxWave();
|
|
||||||
if (waveMax>0) {
|
|
||||||
ImGui::Separator();
|
|
||||||
ImGui::Text("Waveform Macro");
|
|
||||||
for (int i=0; i<ins->std.waveMacroLen; i++) {
|
|
||||||
asFloat[i]=ins->std.waveMacro[i];
|
|
||||||
loopIndicator[i]=(ins->std.waveMacroLoop!=-1 && i>=ins->std.waveMacroLoop);
|
|
||||||
}
|
|
||||||
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
|
||||||
|
|
||||||
ImGui::PlotHistogram("##IWaveMacro",asFloat,ins->std.waveMacroLen,0,NULL,0,waveMax,ImVec2(400.0f*dpiScale,200.0f*dpiScale));
|
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
|
||||||
macroDragStart=ImGui::GetItemRectMin();
|
|
||||||
macroDragAreaSize=ImVec2(400.0f*dpiScale,200.0f*dpiScale);
|
|
||||||
macroDragMin=0;
|
|
||||||
macroDragMax=waveMax;
|
|
||||||
macroDragLen=ins->std.waveMacroLen;
|
|
||||||
macroDragActive=true;
|
|
||||||
macroDragTarget=ins->std.waveMacro;
|
|
||||||
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
|
||||||
}
|
|
||||||
ImGui::PlotHistogram("##IWaveMacroLoop",loopIndicator,ins->std.waveMacroLen,0,NULL,0,1,ImVec2(400.0f*dpiScale,16.0f*dpiScale));
|
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
|
||||||
macroLoopDragStart=ImGui::GetItemRectMin();
|
|
||||||
macroLoopDragAreaSize=ImVec2(400.0f*dpiScale,16.0f*dpiScale);
|
|
||||||
macroLoopDragLen=ins->std.waveMacroLen;
|
|
||||||
macroLoopDragTarget=&ins->std.waveMacroLoop;
|
|
||||||
macroLoopDragActive=true;
|
|
||||||
processDrags(ImGui::GetMousePos().x,ImGui::GetMousePos().y);
|
|
||||||
}
|
|
||||||
ImGui::PopStyleVar();
|
|
||||||
if (ImGui::InputScalar("Length##IWaveMacroL",ImGuiDataType_U8,&ins->std.waveMacroLen,&_ONE,&_THREE)) {
|
|
||||||
if (ins->std.waveMacroLen>127) ins->std.waveMacroLen=127;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -925,7 +964,7 @@ void FurnaceGUI::drawWaveList() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
PlotNoLerp(fmt::sprintf("##_WAVEP%d",i).c_str(),wavePreview,wave->len+1,0,NULL,0,e->getWaveRes(e->song.system[0]));
|
PlotNoLerp(fmt::sprintf("##_WAVEP%d",i).c_str(),wavePreview,wave->len+1,0,NULL,0,wave->max);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ImGui::IsWindowFocused()) curWindow=GUI_WINDOW_WAVE_LIST;
|
if (ImGui::IsWindowFocused()) curWindow=GUI_WINDOW_WAVE_LIST;
|
||||||
|
@ -946,12 +985,12 @@ void FurnaceGUI::drawWaveEdit() {
|
||||||
if (wave->len>0) wavePreview[wave->len]=wave->data[wave->len-1];
|
if (wave->len>0) wavePreview[wave->len]=wave->data[wave->len-1];
|
||||||
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
ImGui::PushStyleVar(ImGuiStyleVar_FramePadding,ImVec2(0.0f,0.0f));
|
||||||
ImVec2 contentRegion=ImGui::GetContentRegionAvail();
|
ImVec2 contentRegion=ImGui::GetContentRegionAvail();
|
||||||
PlotNoLerp("##Waveform",wavePreview,wave->len+1,0,NULL,0,e->getWaveRes(e->song.system[0]),contentRegion);
|
PlotNoLerp("##Waveform",wavePreview,wave->len+1,0,NULL,0,wave->max,contentRegion);
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Left)) {
|
||||||
waveDragStart=ImGui::GetItemRectMin();
|
waveDragStart=ImGui::GetItemRectMin();
|
||||||
waveDragAreaSize=contentRegion;
|
waveDragAreaSize=contentRegion;
|
||||||
waveDragMin=0;
|
waveDragMin=0;
|
||||||
waveDragMax=e->getWaveRes(e->song.system[0]);
|
waveDragMax=wave->max;
|
||||||
waveDragLen=wave->len;
|
waveDragLen=wave->len;
|
||||||
waveDragActive=true;
|
waveDragActive=true;
|
||||||
waveDragTarget=wave->data;
|
waveDragTarget=wave->data;
|
||||||
|
@ -3140,6 +3179,10 @@ FurnaceGUI::FurnaceGUI():
|
||||||
uiColors[GUI_COLOR_FRAME_BACKGROUND]=ImVec4(0.0f,0.0f,0.0f,0.85f);
|
uiColors[GUI_COLOR_FRAME_BACKGROUND]=ImVec4(0.0f,0.0f,0.0f,0.85f);
|
||||||
uiColors[GUI_COLOR_INSTR_FM]=ImVec4(0.6f,0.9f,1.0f,1.0f);
|
uiColors[GUI_COLOR_INSTR_FM]=ImVec4(0.6f,0.9f,1.0f,1.0f);
|
||||||
uiColors[GUI_COLOR_INSTR_STD]=ImVec4(0.6f,1.0f,0.5f,1.0f);
|
uiColors[GUI_COLOR_INSTR_STD]=ImVec4(0.6f,1.0f,0.5f,1.0f);
|
||||||
|
uiColors[GUI_COLOR_INSTR_GB]=ImVec4(1.0f,1.0f,0.5f,1.0f);
|
||||||
|
uiColors[GUI_COLOR_INSTR_C64]=ImVec4(0.6f,0.5f,1.0f,1.0f);
|
||||||
|
uiColors[GUI_COLOR_INSTR_AMIGA]=ImVec4(1.0f,0.5f,0.5f,1.0f);
|
||||||
|
uiColors[GUI_COLOR_INSTR_UNKNOWN]=ImVec4(0.3f,0.3f,0.3f,1.0f);
|
||||||
uiColors[GUI_COLOR_CHANNEL_FM]=ImVec4(0.2f,0.8f,1.0f,1.0f);
|
uiColors[GUI_COLOR_CHANNEL_FM]=ImVec4(0.2f,0.8f,1.0f,1.0f);
|
||||||
uiColors[GUI_COLOR_CHANNEL_PULSE]=ImVec4(0.4f,1.0f,0.2f,1.0f);
|
uiColors[GUI_COLOR_CHANNEL_PULSE]=ImVec4(0.4f,1.0f,0.2f,1.0f);
|
||||||
uiColors[GUI_COLOR_CHANNEL_NOISE]=ImVec4(0.8f,0.8f,0.8f,1.0f);
|
uiColors[GUI_COLOR_CHANNEL_NOISE]=ImVec4(0.8f,0.8f,0.8f,1.0f);
|
||||||
|
|
|
@ -15,6 +15,10 @@ enum FurnaceGUIColors {
|
||||||
GUI_COLOR_ITEM_FOREGROUND,
|
GUI_COLOR_ITEM_FOREGROUND,
|
||||||
GUI_COLOR_INSTR_FM,
|
GUI_COLOR_INSTR_FM,
|
||||||
GUI_COLOR_INSTR_STD,
|
GUI_COLOR_INSTR_STD,
|
||||||
|
GUI_COLOR_INSTR_GB,
|
||||||
|
GUI_COLOR_INSTR_C64,
|
||||||
|
GUI_COLOR_INSTR_AMIGA,
|
||||||
|
GUI_COLOR_INSTR_UNKNOWN,
|
||||||
GUI_COLOR_CHANNEL_FM,
|
GUI_COLOR_CHANNEL_FM,
|
||||||
GUI_COLOR_CHANNEL_PULSE,
|
GUI_COLOR_CHANNEL_PULSE,
|
||||||
GUI_COLOR_CHANNEL_NOISE,
|
GUI_COLOR_CHANNEL_NOISE,
|
||||||
|
|
Loading…
Reference in a new issue