fix for borked ADP decoding upon playback

till now, Ongakukan ADPCM decoder worked by "samples filled" and "samples consumed" var from ongakukan_adp_decoder.c ("decoder code" henceforth) get values from ongakukan-adp_lib.c ("decoder lib code" henceforth). samples done was also not initialized to 0 in decoder code, which led to "stuttery" playback with ADP files when decoded sound data from those same files would endlessly repeat by about half-a-second till it reached duration.

this commit fixes this; ADP files are now decoded from beginning-to-end, and you'll be getting no "repeating" sounds literally every second. instead you'll be getting the sound data the way you'd listen to them in-game.
This commit is contained in:
modusc896d352 2024-07-17 18:22:38 -03:00
parent 1d2ab676ec
commit 2eef6b4535
2 changed files with 10 additions and 4 deletions

View File

@ -127,7 +127,7 @@ void seek_ongakukan_adpcm_pos(ongakukan_adp_t* handle, long int target_sample)
* and though they're fairly useless ATM, you pretty much want to leave them alone). */
/* anyway, we'll have to tell decoder that target_sample is calling and wants to go somewhere right now,
* so we'll have data_offset reposition itself to where sound data for that sample ought to be
* so we'll have data_offset reposition itself to where sound data for that sample ought to be
* and (as of now) reset basically all decode state up to this point so we can continue to decode all sample pairs without issue. */
handle->data_offset = handle->start_offset + ts_data_offset;
handle->sample_pair_is_decoded = 0;
@ -207,6 +207,11 @@ void decode_ongakukan_adp_data(ongakukan_adp_t* handle)
{
/* set samples_filled to 0 and have our decoder go through every sample that exists in the sound data.*/
handle->samples_filled = 0;
if (handle->sample_pair_is_decoded == 0)
{
handle->samples_filled = 0;
handle->samples_consumed = 0;
}
decode_ongakukan_adpcm_sample(handle, handle->sample_hist);
/* if setup is established for further decoding, switch gears and have the decoder use that setup for as long as possible. */
if (handle->sample_has_base_setup_from_the_start == 1)
@ -220,7 +225,6 @@ void decode_ongakukan_adp_data(ongakukan_adp_t* handle)
handle->data_offset++;
handle->alt_sample_work1 += 2;
handle->alt_sample_work2 -= 2;
handle->samples_consumed = 0;
handle->samples_filled = 2;
handle->sample_pair_is_decoded = 0;
}

View File

@ -28,6 +28,7 @@ ongakukan_adp_data* init_ongakukan_adp(STREAMFILE* sf, int32_t data_offset, int3
sample_needs_setup, sample_has_base_setup_from_the_start);
if (!data->handle) goto fail;
printf(" return data; \n");
return data;
fail:
free_ongakukan_adp(data);
@ -38,8 +39,9 @@ void decode_ongakukan_adp(VGMSTREAM* vgmstream, sample_t* outbuf, int32_t sample
{
ongakukan_adp_data* data = vgmstream->codec_data;
data->samples_filled = (int32_t)grab_samples_filled_from_ongakukan_adp(data->handle);
data->samples_consumed = (int32_t)grab_samples_consumed_from_ongakukan_adp(data->handle);
data->samples_done = 0;
data->samples_filled = 0;
data->samples_consumed = 0;
data->samples = (int16_t*)grab_sample_hist_from_ongakukan_adp(data->handle); /* this'll return a pointer from the handle containing the samples themselves. */
while (data->samples_done < samples_to_do)
{