Merge "Make volume dialog pick up on theme changes" into oc-dev
This commit is contained in:
@@ -14,9 +14,6 @@
|
|||||||
|
|
||||||
package com.android.systemui.statusbar.policy;
|
package com.android.systemui.statusbar.policy;
|
||||||
|
|
||||||
import com.android.systemui.Dependency;
|
|
||||||
import com.android.systemui.plugins.Plugin;
|
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
import java.util.function.Supplier;
|
import java.util.function.Supplier;
|
||||||
@@ -32,6 +29,11 @@ public interface ExtensionController {
|
|||||||
interface Extension<T> {
|
interface Extension<T> {
|
||||||
T get();
|
T get();
|
||||||
void destroy();
|
void destroy();
|
||||||
|
/**
|
||||||
|
* Triggers the extension to cycle through each of the sources again because something
|
||||||
|
* (like configuration) may have changed.
|
||||||
|
*/
|
||||||
|
T reload();
|
||||||
}
|
}
|
||||||
|
|
||||||
interface ExtensionBuilder<T> {
|
interface ExtensionBuilder<T> {
|
||||||
|
|||||||
@@ -126,6 +126,12 @@ public class ExtensionControllerImpl implements ExtensionController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public T reload() {
|
||||||
|
notifyChanged();
|
||||||
|
return get();
|
||||||
|
}
|
||||||
|
|
||||||
private void notifyChanged() {
|
private void notifyChanged() {
|
||||||
for (int i = 0; i < mProducers.size(); i++) {
|
for (int i = 0; i < mProducers.size(); i++) {
|
||||||
final T item = mProducers.get(i).get();
|
final T item = mProducers.get(i).get();
|
||||||
|
|||||||
@@ -18,26 +18,25 @@ package com.android.systemui.volume;
|
|||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.content.pm.ActivityInfo;
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.media.AudioManager;
|
import android.media.AudioManager;
|
||||||
import android.media.VolumePolicy;
|
import android.media.VolumePolicy;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.view.WindowManager;
|
|
||||||
import android.view.WindowManager.LayoutParams;
|
import android.view.WindowManager.LayoutParams;
|
||||||
|
|
||||||
|
import com.android.settingslib.applications.InterestingConfigChanges;
|
||||||
import com.android.systemui.plugins.ActivityStarter;
|
import com.android.systemui.plugins.ActivityStarter;
|
||||||
import com.android.systemui.Dependency;
|
import com.android.systemui.Dependency;
|
||||||
import com.android.systemui.SystemUI;
|
import com.android.systemui.SystemUI;
|
||||||
import com.android.systemui.keyguard.KeyguardViewMediator;
|
import com.android.systemui.keyguard.KeyguardViewMediator;
|
||||||
import com.android.systemui.plugins.PluginDependency;
|
|
||||||
import com.android.systemui.plugins.PluginDependencyProvider;
|
import com.android.systemui.plugins.PluginDependencyProvider;
|
||||||
import com.android.systemui.plugins.PluginManager;
|
|
||||||
import com.android.systemui.plugins.VolumeDialog;
|
import com.android.systemui.plugins.VolumeDialog;
|
||||||
import com.android.systemui.plugins.VolumeDialogController;
|
import com.android.systemui.plugins.VolumeDialogController;
|
||||||
import com.android.systemui.qs.tiles.DndTile;
|
import com.android.systemui.qs.tiles.DndTile;
|
||||||
import com.android.systemui.statusbar.policy.ExtensionController;
|
import com.android.systemui.statusbar.policy.ExtensionController;
|
||||||
import com.android.systemui.statusbar.policy.ZenModeController;
|
import com.android.systemui.statusbar.policy.ExtensionController.Extension;
|
||||||
import com.android.systemui.tuner.TunerService;
|
import com.android.systemui.tuner.TunerService;
|
||||||
|
|
||||||
import java.io.FileDescriptor;
|
import java.io.FileDescriptor;
|
||||||
@@ -60,6 +59,9 @@ public class VolumeDialogComponent implements VolumeComponent, TunerService.Tuna
|
|||||||
private final SystemUI mSysui;
|
private final SystemUI mSysui;
|
||||||
private final Context mContext;
|
private final Context mContext;
|
||||||
private final VolumeDialogControllerImpl mController;
|
private final VolumeDialogControllerImpl mController;
|
||||||
|
private final InterestingConfigChanges mConfigChanges = new InterestingConfigChanges(
|
||||||
|
ActivityInfo.CONFIG_FONT_SCALE);
|
||||||
|
private final Extension mExtension;
|
||||||
private VolumeDialog mDialog;
|
private VolumeDialog mDialog;
|
||||||
private VolumePolicy mVolumePolicy = new VolumePolicy(
|
private VolumePolicy mVolumePolicy = new VolumePolicy(
|
||||||
DEFAULT_VOLUME_DOWN_TO_ENTER_SILENT, // volumeDownToEnterSilent
|
DEFAULT_VOLUME_DOWN_TO_ENTER_SILENT, // volumeDownToEnterSilent
|
||||||
@@ -76,7 +78,7 @@ public class VolumeDialogComponent implements VolumeComponent, TunerService.Tuna
|
|||||||
// Allow plugins to reference the VolumeDialogController.
|
// Allow plugins to reference the VolumeDialogController.
|
||||||
Dependency.get(PluginDependencyProvider.class)
|
Dependency.get(PluginDependencyProvider.class)
|
||||||
.allowPluginDependency(VolumeDialogController.class);
|
.allowPluginDependency(VolumeDialogController.class);
|
||||||
Dependency.get(ExtensionController.class).newExtension(VolumeDialog.class)
|
mExtension = Dependency.get(ExtensionController.class).newExtension(VolumeDialog.class)
|
||||||
.withPlugin(VolumeDialog.class)
|
.withPlugin(VolumeDialog.class)
|
||||||
.withDefault(this::createDefault)
|
.withDefault(this::createDefault)
|
||||||
.withCallback(dialog -> {
|
.withCallback(dialog -> {
|
||||||
@@ -148,7 +150,9 @@ public class VolumeDialogComponent implements VolumeComponent, TunerService.Tuna
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onConfigurationChanged(Configuration newConfig) {
|
public void onConfigurationChanged(Configuration newConfig) {
|
||||||
// noop
|
if (mConfigChanges.applyNewConfig(mContext.getResources())) {
|
||||||
|
mExtension.reload();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -97,5 +97,10 @@ public class FakeExtensionController implements ExtensionController {
|
|||||||
public void destroy() {
|
public void destroy() {
|
||||||
mTracker.getLeakInfo(mAllocation).clearAllocations();
|
mTracker.getLeakInfo(mAllocation).clearAllocations();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public T reload() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user