mirror of
https://github.com/tildearrow/furnace.git
synced 2025-01-06 23:51:21 +00:00
Merge branch 'master' of https://github.com/tildearrow/furnace into x16
This commit is contained in:
commit
80e3148a43
2 changed files with 68 additions and 6 deletions
|
@ -85,6 +85,14 @@ const char* opllInsNames[17]={
|
||||||
"Drums"
|
"Drums"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const char* oplWaveforms[8]={
|
||||||
|
"Sine", "Half Sine", "Absolute Sine", "Quarter Sine", "Squished Sine", "Squished AbsSine", "Square", "Derived Square"
|
||||||
|
};
|
||||||
|
|
||||||
|
const char* opzWaveforms[8]={
|
||||||
|
"Sine", "Triangle", "Cut Sine", "Cut Triangle", "Squished Sine", "Squished Triangle", "Squished AbsSine", "Squished AbsTriangle"
|
||||||
|
};
|
||||||
|
|
||||||
enum FMParams {
|
enum FMParams {
|
||||||
FM_ALG=0,
|
FM_ALG=0,
|
||||||
FM_FB=1,
|
FM_FB=1,
|
||||||
|
@ -820,13 +828,19 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
break;
|
break;
|
||||||
case DIV_INS_OPL: {
|
case DIV_INS_OPL: {
|
||||||
bool fourOp=(ins->fm.ops==4);
|
bool fourOp=(ins->fm.ops==4);
|
||||||
|
bool drums=ins->fm.opllPreset==16;
|
||||||
|
int algMax=fourOp?3:1;
|
||||||
ImGui::TableNextColumn();
|
ImGui::TableNextColumn();
|
||||||
|
ins->fm.alg&=algMax;
|
||||||
P(ImGui::SliderScalar(FM_NAME(FM_FB),ImGuiDataType_U8,&ins->fm.fb,&_ZERO,&_SEVEN)); rightClickable
|
P(ImGui::SliderScalar(FM_NAME(FM_FB),ImGuiDataType_U8,&ins->fm.fb,&_ZERO,&_SEVEN)); rightClickable
|
||||||
if (ImGui::Checkbox("4-op",&fourOp)) { PARAMETER
|
if (ImGui::Checkbox("4-op",&fourOp)) { PARAMETER
|
||||||
ins->fm.ops=fourOp?4:2;
|
ins->fm.ops=fourOp?4:2;
|
||||||
}
|
}
|
||||||
ImGui::TableNextColumn();
|
ImGui::TableNextColumn();
|
||||||
P(ImGui::SliderScalar(FM_NAME(FM_ALG),ImGuiDataType_U8,&ins->fm.alg,&_ZERO,&_SEVEN)); rightClickable
|
P(ImGui::SliderScalar(FM_NAME(FM_ALG),ImGuiDataType_U8,&ins->fm.alg,&_ZERO,&algMax)); rightClickable
|
||||||
|
if (ImGui::Checkbox("Drums",&drums)) { PARAMETER
|
||||||
|
ins->fm.opllPreset=drums?16:0;
|
||||||
|
}
|
||||||
ImGui::TableNextColumn();
|
ImGui::TableNextColumn();
|
||||||
drawAlgorithm(ins->fm.alg&1,FM_ALGS_2OP_OPL,ImVec2(ImGui::GetContentRegionAvail().x,48.0*dpiScale));
|
drawAlgorithm(ins->fm.alg&1,FM_ALGS_2OP_OPL,ImVec2(ImGui::GetContentRegionAvail().x,48.0*dpiScale));
|
||||||
break;
|
break;
|
||||||
|
@ -978,13 +992,18 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
maxTl=63;
|
maxTl=63;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (ins->type==DIV_INS_OPL) {
|
||||||
|
maxTl=63;
|
||||||
|
}
|
||||||
int maxArDr=(ins->type==DIV_INS_FM || ins->type==DIV_INS_OPZ)?31:15;
|
int maxArDr=(ins->type==DIV_INS_FM || ins->type==DIV_INS_OPZ)?31:15;
|
||||||
|
|
||||||
bool ssgOn=op.ssgEnv&8;
|
bool ssgOn=op.ssgEnv&8;
|
||||||
bool ksrOn=op.ksr;
|
bool ksrOn=op.ksr;
|
||||||
bool vibOn=op.vib;
|
bool vibOn=op.vib;
|
||||||
|
bool susOn=op.sus; // don't you make fun of this one
|
||||||
unsigned char ssgEnv=op.ssgEnv&7;
|
unsigned char ssgEnv=op.ssgEnv&7;
|
||||||
if (ImGui::Checkbox((ins->type==DIV_INS_OPL || ins->type==DIV_INS_OPLL)?FM_NAME(FM_EGS):"SSG On",&ssgOn)) { PARAMETER
|
if (ins->type!=DIV_INS_OPL && ins->type!=DIV_INS_OPZ) {
|
||||||
|
if (ImGui::Checkbox((ins->type==DIV_INS_OPLL)?FM_NAME(FM_EGS):"SSG On",&ssgOn)) { PARAMETER
|
||||||
op.ssgEnv=(op.ssgEnv&7)|(ssgOn<<3);
|
op.ssgEnv=(op.ssgEnv&7)|(ssgOn<<3);
|
||||||
}
|
}
|
||||||
if (ins->type==DIV_INS_FM) {
|
if (ins->type==DIV_INS_FM) {
|
||||||
|
@ -992,6 +1011,13 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
ImGui::SetTooltip("Only for Genesis and Neo Geo systems");
|
ImGui::SetTooltip("Only for Genesis and Neo Geo systems");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ins->type==DIV_INS_OPL) {
|
||||||
|
if (ImGui::Checkbox(FM_NAME(FM_SUS),&susOn)) { PARAMETER
|
||||||
|
op.sus=susOn;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//52.0 controls vert scaling; default 96
|
//52.0 controls vert scaling; default 96
|
||||||
drawFMEnv(op.tl&maxTl,op.ar&maxArDr,op.dr&maxArDr,(ins->type==DIV_INS_OPL || ins->type==DIV_INS_OPLL)?((op.rr&15)*2):op.d2r&31,op.rr&15,op.sl&15,maxTl,maxArDr,ImVec2(ImGui::GetContentRegionAvail().x,52.0*dpiScale));
|
drawFMEnv(op.tl&maxTl,op.ar&maxArDr,op.dr&maxArDr,(ins->type==DIV_INS_OPL || ins->type==DIV_INS_OPLL)?((op.rr&15)*2):op.d2r&31,op.rr&15,op.sl&15,maxTl,maxArDr,ImVec2(ImGui::GetContentRegionAvail().x,52.0*dpiScale));
|
||||||
|
@ -1104,6 +1130,18 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
ImGui::Text("%s",FM_NAME(FM_SSG));
|
ImGui::Text("%s",FM_NAME(FM_SSG));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ins->type==DIV_INS_OPL || ins->type==DIV_INS_OPZ) {
|
||||||
|
ImGui::TableNextRow();
|
||||||
|
ImGui::TableNextColumn();
|
||||||
|
ImGui::SetNextItemWidth(ImGui::GetContentRegionAvail().x);
|
||||||
|
P(ImGui::SliderScalar("##WS",ImGuiDataType_U8,&op.ws,&_ZERO,&_SEVEN,(ins->type==DIV_INS_OPZ)?opzWaveforms[op.ws&7]:oplWaveforms[op.ws&7])); rightClickable
|
||||||
|
if (ins->type==DIV_INS_OPL && ImGui::IsItemHovered()) {
|
||||||
|
ImGui::SetTooltip("OPL2/3 only (last 4 waveforms are OPL3 only)");
|
||||||
|
}
|
||||||
|
ImGui::TableNextColumn();
|
||||||
|
ImGui::Text("%s",FM_NAME(FM_WS));
|
||||||
|
}
|
||||||
|
|
||||||
ImGui::EndTable();
|
ImGui::EndTable();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -332,6 +332,7 @@ void FurnaceGUI::drawPattern() {
|
||||||
}
|
}
|
||||||
if (!patternOpen) return;
|
if (!patternOpen) return;
|
||||||
|
|
||||||
|
bool inhibitMenu=false;
|
||||||
float scrollX=0;
|
float scrollX=0;
|
||||||
|
|
||||||
if (e->isPlaying() && followPattern) cursor.y=oldRow;
|
if (e->isPlaying() && followPattern) cursor.y=oldRow;
|
||||||
|
@ -411,6 +412,7 @@ void FurnaceGUI::drawPattern() {
|
||||||
}
|
}
|
||||||
if (ImGui::IsItemClicked(ImGuiMouseButton_Right)) {
|
if (ImGui::IsItemClicked(ImGuiMouseButton_Right)) {
|
||||||
fancyPattern=!fancyPattern;
|
fancyPattern=!fancyPattern;
|
||||||
|
inhibitMenu=true;
|
||||||
e->enableCommandStream(fancyPattern);
|
e->enableCommandStream(fancyPattern);
|
||||||
e->getCommandStream(cmdStream);
|
e->getCommandStream(cmdStream);
|
||||||
cmdStream.clear();
|
cmdStream.clear();
|
||||||
|
@ -481,6 +483,7 @@ void FurnaceGUI::drawPattern() {
|
||||||
if (muted) ImGui::PopStyleColor();
|
if (muted) ImGui::PopStyleColor();
|
||||||
ImGui::PopStyleColor(3);
|
ImGui::PopStyleColor(3);
|
||||||
if (settings.soloAction!=2) if (ImGui::IsItemClicked(ImGuiMouseButton_Right)) {
|
if (settings.soloAction!=2) if (ImGui::IsItemClicked(ImGuiMouseButton_Right)) {
|
||||||
|
inhibitMenu=true;
|
||||||
e->toggleSolo(i);
|
e->toggleSolo(i);
|
||||||
}
|
}
|
||||||
if (extraChannelButtons==2) {
|
if (extraChannelButtons==2) {
|
||||||
|
@ -807,6 +810,27 @@ void FurnaceGUI::drawPattern() {
|
||||||
ImGui::PopFont();
|
ImGui::PopFont();
|
||||||
}
|
}
|
||||||
ImGui::PopStyleVar();
|
ImGui::PopStyleVar();
|
||||||
|
if (patternOpen) {
|
||||||
|
if (!inhibitMenu && ImGui::IsItemClicked(ImGuiMouseButton_Right)) ImGui::OpenPopup("patternActionMenu");
|
||||||
|
if (ImGui::BeginPopup("patternActionMenu",ImGuiWindowFlags_AlwaysAutoResize|ImGuiWindowFlags_NoTitleBar|ImGuiWindowFlags_NoSavedSettings)) {
|
||||||
|
char id[4096];
|
||||||
|
ImGui::Selectable("cut");
|
||||||
|
ImGui::Selectable("copy");
|
||||||
|
ImGui::Selectable("paste");
|
||||||
|
if (ImGui::BeginMenu("change instrument...")) {
|
||||||
|
if (e->song.ins.empty()) {
|
||||||
|
ImGui::Text("no instruments available");
|
||||||
|
}
|
||||||
|
for (size_t i=0; i<e->song.ins.size(); i++) {
|
||||||
|
snprintf(id,4095,"%.2X: %s",(int)i,e->song.ins[i]->name.c_str());
|
||||||
|
if (ImGui::Selectable(id)) { // TODO
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ImGui::EndMenu();
|
||||||
|
}
|
||||||
|
ImGui::EndPopup();
|
||||||
|
}
|
||||||
|
}
|
||||||
if (ImGui::IsWindowFocused(ImGuiFocusedFlags_ChildWindows)) curWindow=GUI_WINDOW_PATTERN;
|
if (ImGui::IsWindowFocused(ImGuiFocusedFlags_ChildWindows)) curWindow=GUI_WINDOW_PATTERN;
|
||||||
ImGui::End();
|
ImGui::End();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue