Merge "Spatializer: Fix lost settings after reboot"

This commit is contained in:
Andy Hung 2022-09-08 20:56:32 +00:00 committed by Gerrit Code Review
commit eb72e5eec7
2 changed files with 11 additions and 7 deletions

View File

@ -9142,11 +9142,8 @@ public class AudioService extends IAudioService.Stub
Settings.Secure.SPATIAL_AUDIO_ENABLED, UserHandle.USER_CURRENT);
if (settings == null) {
Log.e(TAG, "error reading spatial audio device settings");
} else {
Log.v(TAG, "restoring spatial audio device settings: " + settings);
mSpatializerHelper.setSADeviceSettings(settings);
}
mSpatializerHelper.init(/*effectExpected*/ mHasSpatializerEffect);
mSpatializerHelper.init(/*effectExpected*/ mHasSpatializerEffect, settings);
mSpatializerHelper.setFeatureEnabled(mHasSpatializerEffect);
}

View File

@ -185,7 +185,7 @@ public class SpatializerHelper {
mTransauralSupported = hasTransaural;
}
synchronized void init(boolean effectExpected) {
synchronized void init(boolean effectExpected, @Nullable String settings) {
loglogi("init effectExpected=" + effectExpected);
if (!effectExpected) {
loglogi("init(): setting state to STATE_NOT_SUPPORTED due to effect not expected");
@ -288,6 +288,13 @@ public class SpatializerHelper {
mSACapableDeviceTypes.add(SPAT_MODE_FOR_DEVICE_TYPE.keyAt(i));
}
}
// When initialized from AudioService, the settings string will be non-null.
// Saved settings need to be applied after spatialization support is initialized above.
if (settings != null) {
setSADeviceSettings(settings);
}
// for both transaural / binaural, we are not forcing enablement as the init() method
// could have been called another time after boot in case of audioserver restart
addCompatibleAudioDevice(
@ -326,7 +333,7 @@ public class SpatializerHelper {
mState = STATE_UNINITIALIZED;
mSpatLevel = Spatializer.SPATIALIZER_IMMERSIVE_LEVEL_NONE;
mActualHeadTrackingMode = Spatializer.HEAD_TRACKING_MODE_UNSUPPORTED;
init(true);
init(true, null /* settings */);
setSpatializerEnabledInt(featureEnabled);
}
@ -752,7 +759,7 @@ public class SpatializerHelper {
return;
}
if (mState == STATE_UNINITIALIZED) {
init(true);
init(true, null /* settings */);
}
setSpatializerEnabledInt(true);
} else {