Merge "Make volume dialog pick up on theme changes" into oc-dev

am: 1ec5d85a41

Change-Id: I9b2e6dbe789bb6e1ff113e5ad015813e1062c6b4
This commit is contained in:
Jason Monk
2017-05-26 19:08:22 +00:00
committed by android-build-merger
4 changed files with 26 additions and 9 deletions

View File

@@ -14,9 +14,6 @@
package com.android.systemui.statusbar.policy;
import com.android.systemui.Dependency;
import com.android.systemui.plugins.Plugin;
import java.util.Map;
import java.util.function.Consumer;
import java.util.function.Supplier;
@@ -32,6 +29,11 @@ public interface ExtensionController {
interface Extension<T> {
T get();
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> {

View File

@@ -126,6 +126,12 @@ public class ExtensionControllerImpl implements ExtensionController {
}
}
@Override
public T reload() {
notifyChanged();
return get();
}
private void notifyChanged() {
for (int i = 0; i < mProducers.size(); i++) {
final T item = mProducers.get(i).get();

View File

@@ -18,26 +18,25 @@ package com.android.systemui.volume;
import android.content.Context;
import android.content.Intent;
import android.content.pm.ActivityInfo;
import android.content.res.Configuration;
import android.media.AudioManager;
import android.media.VolumePolicy;
import android.os.Bundle;
import android.os.Handler;
import android.view.WindowManager;
import android.view.WindowManager.LayoutParams;
import com.android.settingslib.applications.InterestingConfigChanges;
import com.android.systemui.plugins.ActivityStarter;
import com.android.systemui.Dependency;
import com.android.systemui.SystemUI;
import com.android.systemui.keyguard.KeyguardViewMediator;
import com.android.systemui.plugins.PluginDependency;
import com.android.systemui.plugins.PluginDependencyProvider;
import com.android.systemui.plugins.PluginManager;
import com.android.systemui.plugins.VolumeDialog;
import com.android.systemui.plugins.VolumeDialogController;
import com.android.systemui.qs.tiles.DndTile;
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 java.io.FileDescriptor;
@@ -60,6 +59,9 @@ public class VolumeDialogComponent implements VolumeComponent, TunerService.Tuna
private final SystemUI mSysui;
private final Context mContext;
private final VolumeDialogControllerImpl mController;
private final InterestingConfigChanges mConfigChanges = new InterestingConfigChanges(
ActivityInfo.CONFIG_FONT_SCALE);
private final Extension mExtension;
private VolumeDialog mDialog;
private VolumePolicy mVolumePolicy = new VolumePolicy(
DEFAULT_VOLUME_DOWN_TO_ENTER_SILENT, // volumeDownToEnterSilent
@@ -76,7 +78,7 @@ public class VolumeDialogComponent implements VolumeComponent, TunerService.Tuna
// Allow plugins to reference the VolumeDialogController.
Dependency.get(PluginDependencyProvider.class)
.allowPluginDependency(VolumeDialogController.class);
Dependency.get(ExtensionController.class).newExtension(VolumeDialog.class)
mExtension = Dependency.get(ExtensionController.class).newExtension(VolumeDialog.class)
.withPlugin(VolumeDialog.class)
.withDefault(this::createDefault)
.withCallback(dialog -> {
@@ -148,7 +150,9 @@ public class VolumeDialogComponent implements VolumeComponent, TunerService.Tuna
@Override
public void onConfigurationChanged(Configuration newConfig) {
// noop
if (mConfigChanges.applyNewConfig(mContext.getResources())) {
mExtension.reload();
}
}
@Override

View File

@@ -97,5 +97,10 @@ public class FakeExtensionController implements ExtensionController {
public void destroy() {
mTracker.getLeakInfo(mAllocation).clearAllocations();
}
@Override
public T reload() {
return null;
}
}
}