mirror of
https://github.com/overte-org/overte.git
synced 2025-08-11 00:53:17 +02:00
Merge pull request #4407 from birarda/windows-fixes
fix for out of bounds sound resampling
This commit is contained in:
commit
4b53cfb950
1 changed files with 22 additions and 11 deletions
|
@ -94,30 +94,41 @@ void Sound::downloadFinished(QNetworkReply* reply) {
|
||||||
|
|
||||||
void Sound::downSample(const QByteArray& rawAudioByteArray) {
|
void Sound::downSample(const QByteArray& rawAudioByteArray) {
|
||||||
// assume that this was a RAW file and is now an array of samples that are
|
// assume that this was a RAW file and is now an array of samples that are
|
||||||
// signed, 16-bit, 48Khz, mono
|
// signed, 16-bit, 48Khz
|
||||||
|
|
||||||
// we want to convert it to the format that the audio-mixer wants
|
// we want to convert it to the format that the audio-mixer wants
|
||||||
// which is signed, 16-bit, 24Khz, mono
|
// which is signed, 16-bit, 24Khz
|
||||||
|
|
||||||
_byteArray.resize(rawAudioByteArray.size() / 2);
|
|
||||||
|
|
||||||
int numSourceSamples = rawAudioByteArray.size() / sizeof(int16_t);
|
int numSourceSamples = rawAudioByteArray.size() / sizeof(int16_t);
|
||||||
|
|
||||||
|
int numDestinationBytes = rawAudioByteArray.size() / 2;
|
||||||
|
if (_isStereo && numSourceSamples % 4 != 0) {
|
||||||
|
numDestinationBytes += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
_byteArray.resize(numDestinationBytes);
|
||||||
|
|
||||||
|
|
||||||
int16_t* sourceSamples = (int16_t*) rawAudioByteArray.data();
|
int16_t* sourceSamples = (int16_t*) rawAudioByteArray.data();
|
||||||
int16_t* destinationSamples = (int16_t*) _byteArray.data();
|
int16_t* destinationSamples = (int16_t*) _byteArray.data();
|
||||||
|
|
||||||
|
|
||||||
if (_isStereo) {
|
if (_isStereo) {
|
||||||
for (int i = 0; i < numSourceSamples; i += 4) {
|
for (int i = 0; i < numSourceSamples; i += 4) {
|
||||||
destinationSamples[i / 2] = (sourceSamples[i] / 2) + (sourceSamples[i + 2] / 2);
|
if (i + 2 >= numSourceSamples) {
|
||||||
destinationSamples[(i / 2) + 1] = (sourceSamples[i + 1] / 2) + (sourceSamples[i + 3] / 2);
|
destinationSamples[i / 2] = sourceSamples[i];
|
||||||
|
destinationSamples[(i / 2) + 1] = sourceSamples[i + 1];
|
||||||
|
} else {
|
||||||
|
destinationSamples[i / 2] = (sourceSamples[i] + sourceSamples[i + 2]) / 2;
|
||||||
|
destinationSamples[(i / 2) + 1] = (sourceSamples[i + 1] + sourceSamples[i + 3]) / 2;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for (int i = 1; i < numSourceSamples; i += 2) {
|
for (int i = 1; i < numSourceSamples; i += 2) {
|
||||||
if (i + 1 >= numSourceSamples) {
|
if (i + 1 >= numSourceSamples) {
|
||||||
destinationSamples[(i - 1) / 2] = (sourceSamples[i - 1] / 2) + (sourceSamples[i] / 2);
|
destinationSamples[(i - 1) / 2] = (sourceSamples[i - 1] + sourceSamples[i]) / 2;
|
||||||
} else {
|
} else {
|
||||||
destinationSamples[(i - 1) / 2] = (sourceSamples[i - 1] / 4) + (sourceSamples[i] / 2)
|
destinationSamples[(i - 1) / 2] = ((sourceSamples[i - 1] + sourceSamples[i + 1]) / 4) + (sourceSamples[i] / 2);
|
||||||
+ (sourceSamples[i + 1] / 4);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue