mirror of
https://github.com/tildearrow/furnace.git
synced 2025-01-01 04:21:44 +00:00
C64: add ring/sync macro
This commit is contained in:
parent
497c947513
commit
20ac87d256
2 changed files with 22 additions and 2 deletions
|
@ -122,6 +122,12 @@ void DivPlatformC64::tick() {
|
||||||
filtRes=chan[i].std.ex2&15;
|
filtRes=chan[i].std.ex2&15;
|
||||||
updateFilter();
|
updateFilter();
|
||||||
}
|
}
|
||||||
|
if (chan[i].std.hadEx3) {
|
||||||
|
chan[i].sync=chan[i].std.ex3&1;
|
||||||
|
chan[i].ring=chan[i].std.ex3&2;
|
||||||
|
chan[i].freqChanged=true;
|
||||||
|
}
|
||||||
|
|
||||||
if (chan[i].freqChanged || chan[i].keyOn || chan[i].keyOff) {
|
if (chan[i].freqChanged || chan[i].keyOn || chan[i].keyOff) {
|
||||||
chan[i].freq=parent->calcFreq(chan[i].baseFreq,chan[i].pitch,false,8);
|
chan[i].freq=parent->calcFreq(chan[i].baseFreq,chan[i].pitch,false,8);
|
||||||
if (chan[i].freq>0xffff) chan[i].freq=0xffff;
|
if (chan[i].freq>0xffff) chan[i].freq=0xffff;
|
||||||
|
|
|
@ -1363,6 +1363,10 @@ const char* filtModeBits[5]={
|
||||||
"low", "band", "high", "ch3off", NULL
|
"low", "band", "high", "ch3off", NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const char* c64SpecialBits[3]={
|
||||||
|
"sync", "ring", NULL
|
||||||
|
};
|
||||||
|
|
||||||
const int orderedOps[4]={
|
const int orderedOps[4]={
|
||||||
0, 2, 1, 3
|
0, 2, 1, 3
|
||||||
};
|
};
|
||||||
|
@ -1856,7 +1860,10 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
int ex1Max=(ins->type==DIV_INS_AY8930)?8:0;
|
int ex1Max=(ins->type==DIV_INS_AY8930)?8:0;
|
||||||
int ex2Max=(ins->type==DIV_INS_AY || ins->type==DIV_INS_AY8930)?4:0;
|
int ex2Max=(ins->type==DIV_INS_AY || ins->type==DIV_INS_AY8930)?4:0;
|
||||||
|
|
||||||
if (ins->type==DIV_INS_C64) ex1Max=4;
|
if (ins->type==DIV_INS_C64) {
|
||||||
|
ex1Max=4;
|
||||||
|
ex2Max=15;
|
||||||
|
}
|
||||||
if (ins->type==DIV_INS_SAA1099) ex1Max=8;
|
if (ins->type==DIV_INS_SAA1099) ex1Max=8;
|
||||||
|
|
||||||
if (settings.macroView==0) { // modern view
|
if (settings.macroView==0) { // modern view
|
||||||
|
@ -1879,7 +1886,14 @@ void FurnaceGUI::drawInsEdit() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ex2Max>0) {
|
if (ex2Max>0) {
|
||||||
NORMAL_MACRO(ins->std.ex2Macro,ins->std.ex2MacroLen,ins->std.ex2MacroLoop,0,ex2Max,"ex2","Envelope",64,ins->std.ex2MacroOpen,true,ayEnvBits,false,NULL,0,0,0,NULL,uiColors[GUI_COLOR_MACRO_OTHER],mmlString[5],0,ex2Max);
|
if (ins->type==DIV_INS_C64) {
|
||||||
|
NORMAL_MACRO(ins->std.ex2Macro,ins->std.ex2MacroLen,ins->std.ex2MacroLoop,0,ex2Max,"ex2","Resonance",64,ins->std.ex2MacroOpen,false,NULL,false,NULL,0,0,0,NULL,uiColors[GUI_COLOR_MACRO_OTHER],mmlString[5],0,ex2Max);
|
||||||
|
} else {
|
||||||
|
NORMAL_MACRO(ins->std.ex2Macro,ins->std.ex2MacroLen,ins->std.ex2MacroLoop,0,ex2Max,"ex2","Envelope",64,ins->std.ex2MacroOpen,true,ayEnvBits,false,NULL,0,0,0,NULL,uiColors[GUI_COLOR_MACRO_OTHER],mmlString[5],0,ex2Max);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (ins->type==DIV_INS_C64) {
|
||||||
|
NORMAL_MACRO(ins->std.ex3Macro,ins->std.ex3MacroLen,ins->std.ex3MacroLoop,0,2,"ex3","Special",32,ins->std.ex3MacroOpen,true,c64SpecialBits,false,NULL,0,0,0,NULL,uiColors[GUI_COLOR_MACRO_OTHER],mmlString[6],0,2);
|
||||||
}
|
}
|
||||||
if (ins->type==DIV_INS_AY || ins->type==DIV_INS_AY8930) {
|
if (ins->type==DIV_INS_AY || ins->type==DIV_INS_AY8930) {
|
||||||
NORMAL_MACRO(ins->std.ex3Macro,ins->std.ex3MacroLen,ins->std.ex3MacroLoop,0,15,"ex3","AutoEnv Num",96,ins->std.ex3MacroOpen,false,NULL,false,NULL,0,0,0,NULL,uiColors[GUI_COLOR_MACRO_OTHER],mmlString[6],0,15);
|
NORMAL_MACRO(ins->std.ex3Macro,ins->std.ex3MacroLen,ins->std.ex3MacroLoop,0,15,"ex3","AutoEnv Num",96,ins->std.ex3MacroOpen,false,NULL,false,NULL,0,0,0,NULL,uiColors[GUI_COLOR_MACRO_OTHER],mmlString[6],0,15);
|
||||||
|
|
Loading…
Reference in a new issue