mirror of
https://github.com/tildearrow/furnace.git
synced 2025-01-03 22:21:09 +00:00
try to unglitch the sample loops again
this time it works better but it slightly moves the song clock... will look at it when i wake up
This commit is contained in:
parent
e8163b71e2
commit
b527fc06b2
1 changed files with 41 additions and 16 deletions
|
@ -2497,35 +2497,60 @@ SafeWriter* DivEngine::saveVGM() {
|
||||||
loopTimer[i]-=(loopFreq[i]/44100.0)*(double)totalWait;
|
loopTimer[i]-=(loopFreq[i]/44100.0)*(double)totalWait;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
bool haveNegatives=false;
|
||||||
for (int i=0; i<streamID; i++) {
|
for (int i=0; i<streamID; i++) {
|
||||||
if (loopSample[i]>=0) {
|
if (loopSample[i]>=0) {
|
||||||
if (loopTimer[i]<0) {
|
if (loopTimer[i]<0) {
|
||||||
double waitTime=totalWait+(loopTimer[i]*(44100.0/loopFreq[i]));
|
haveNegatives=true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (haveNegatives) {
|
||||||
|
// finish all negatives
|
||||||
|
int nextToTouch=-1;
|
||||||
|
for (int i=0; i<streamID; i++) {
|
||||||
|
if (loopSample[i]>=0) {
|
||||||
|
if (loopTimer[i]<0) {
|
||||||
|
if (nextToTouch>=0) {
|
||||||
|
if (loopTimer[nextToTouch]>loopTimer[i]) nextToTouch=i;
|
||||||
|
} else {
|
||||||
|
nextToTouch=i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (nextToTouch>=0) {
|
||||||
|
double waitTime=totalWait+(loopTimer[nextToTouch]*(44100.0/loopFreq[nextToTouch]));
|
||||||
|
if (waitTime>0) {
|
||||||
w->writeC(0x61);
|
w->writeC(0x61);
|
||||||
w->writeS(waitTime);
|
w->writeS(waitTime);
|
||||||
printf("wait is: %f\n",waitTime);
|
printf("wait is: %f\n",waitTime);
|
||||||
totalWait-=waitTime;
|
totalWait-=waitTime;
|
||||||
tickCount+=waitTime;
|
tickCount+=waitTime;
|
||||||
if (loopSample[i]<song.sampleLen) {
|
}
|
||||||
DivSample* sample=song.sample[loopSample[i]];
|
if (loopSample[nextToTouch]<song.sampleLen) {
|
||||||
|
DivSample* sample=song.sample[loopSample[nextToTouch]];
|
||||||
// insert loop
|
// insert loop
|
||||||
if (sample->loopStart<(int)sample->rendLength) {
|
if (sample->loopStart<(int)sample->rendLength) {
|
||||||
w->writeC(0x93);
|
w->writeC(0x93);
|
||||||
w->writeC(i);
|
w->writeC(nextToTouch);
|
||||||
w->writeI(sample->rendOffContiguous+sample->loopStart);
|
w->writeI(sample->rendOffContiguous+sample->loopStart);
|
||||||
w->writeC(0x81);
|
w->writeC(0x81);
|
||||||
w->writeI(sample->rendLength-sample->loopStart);
|
w->writeI(sample->rendLength-sample->loopStart);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
loopSample[i]=-1;
|
loopSample[nextToTouch]=-1;
|
||||||
}
|
} else {
|
||||||
|
haveNegatives=false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// write wait
|
// write wait
|
||||||
|
if (totalWait>0) {
|
||||||
w->writeC(0x61);
|
w->writeC(0x61);
|
||||||
w->writeS(totalWait);
|
w->writeS(totalWait);
|
||||||
tickCount+=totalWait;
|
tickCount+=totalWait;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for (int i=0; i<song.systemLen; i++) {
|
for (int i=0; i<song.systemLen; i++) {
|
||||||
disCont[i].dispatch->toggleRegisterDump(false);
|
disCont[i].dispatch->toggleRegisterDump(false);
|
||||||
|
|
Loading…
Reference in a new issue