Loading src/com/android/settings/media/MediaDeviceUpdateWorker.java +13 −0 Original line number Diff line number Diff line Loading @@ -146,6 +146,19 @@ public class MediaDeviceUpdateWorker extends SliceBackgroundWorker return mTopDevice; } /** * Request to set volume. * * @param device for the targeted device. * @param volume for the new value. * */ public void adjustVolume(MediaDevice device, int volume) { ThreadUtils.postOnBackgroundThread(() -> { device.requestSetVolume(volume); }); } private class DevicesChangedBroadcastReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { Loading src/com/android/settings/media/MediaOutputSlice.java +33 −10 Original line number Diff line number Diff line Loading @@ -16,6 +16,8 @@ package com.android.settings.media; import static android.app.slice.Slice.EXTRA_RANGE_VALUE; import static com.android.settings.slices.CustomSliceRegistry.MEDIA_OUTPUT_SLICE_URI; import android.app.PendingIntent; Loading Loading @@ -49,6 +51,7 @@ public class MediaOutputSlice implements CustomSliceable { private static final String TAG = "MediaOutputSlice"; private static final String MEDIA_DEVICE_ID = "media_device_id"; private static final int NON_SLIDER_VALUE = -1; public static final String MEDIA_PACKAGE_NAME = "media_package_name"; Loading Loading @@ -86,7 +89,7 @@ public class MediaOutputSlice implements CustomSliceable { final MediaDevice topDevice = isTouched ? worker.getTopDevice() : connectedDevice; if (topDevice != null) { listBuilder.addRow(getActiveDeviceHeaderRow(topDevice)); listBuilder.addInputRange(getActiveDeviceHeaderRow(topDevice)); worker.setTopDevice(topDevice); } Loading @@ -100,7 +103,7 @@ public class MediaOutputSlice implements CustomSliceable { return listBuilder.build(); } private ListBuilder.RowBuilder getActiveDeviceHeaderRow(MediaDevice device) { private ListBuilder.InputRangeBuilder getActiveDeviceHeaderRow(MediaDevice device) { final String title = device.getName(); final IconCompat icon = getDeviceIconCompat(device); Loading @@ -108,14 +111,23 @@ public class MediaOutputSlice implements CustomSliceable { getBroadcastIntent(mContext, device.getId(), device.hashCode()); final SliceAction primarySliceAction = SliceAction.createDeeplink(broadcastAction, icon, ListBuilder.ICON_IMAGE, title); final ListBuilder.RowBuilder rowBuilder = new ListBuilder.RowBuilder() final ListBuilder.InputRangeBuilder builder = new ListBuilder.InputRangeBuilder() .setTitleItem(icon, ListBuilder.ICON_IMAGE) .setTitle(title) .setSubtitle(device.getSummary()) .setPrimaryAction(primarySliceAction); .setPrimaryAction(primarySliceAction) .setInputAction(getSliderInputAction(device.hashCode(), device.getId())) .setMax(device.getMaxVolume()) .setValue(device.getCurrentVolume()); return builder; } return rowBuilder; private PendingIntent getSliderInputAction(int requestCode, String id) { final Intent intent = new Intent(getUri().toString()) .setData(getUri()) .putExtra(MEDIA_DEVICE_ID, id) .setClass(mContext, SliceBroadcastReceiver.class); return PendingIntent.getBroadcast(mContext, requestCode, intent, 0); } private IconCompat getDeviceIconCompat(MediaDevice device) { Loading Loading @@ -152,7 +164,7 @@ public class MediaOutputSlice implements CustomSliceable { .setPrimaryAction(SliceAction.create(broadcastAction, deviceIcon, ListBuilder.ICON_IMAGE, title)) .setTitle(title) .setSubtitle(device.getSummary()); .setSubtitle(device.isConnected() ? null : device.getSummary()); return rowBuilder; } Loading @@ -162,7 +174,7 @@ public class MediaOutputSlice implements CustomSliceable { intent.setClass(context, SliceBroadcastReceiver.class); intent.putExtra(MEDIA_DEVICE_ID, id); intent.addFlags(Intent.FLAG_RECEIVER_FOREGROUND); return PendingIntent.getBroadcast(context, requestCode /* requestCode */, intent, return PendingIntent.getBroadcast(context, requestCode, intent, PendingIntent.FLAG_UPDATE_CURRENT); } Loading @@ -175,11 +187,22 @@ public class MediaOutputSlice implements CustomSliceable { public void onNotifyChange(Intent intent) { final MediaDeviceUpdateWorker worker = getWorker(); final String id = intent != null ? intent.getStringExtra(MEDIA_DEVICE_ID) : ""; if (TextUtils.isEmpty(id)) { return; } final MediaDevice device = worker.getMediaDeviceById(id); if (device != null) { if (device == null) { return; } final int newPosition = intent.getIntExtra(EXTRA_RANGE_VALUE, NON_SLIDER_VALUE); if (newPosition == NON_SLIDER_VALUE) { // Intent for device connection Log.d(TAG, "onNotifyChange() device name : " + device.getName()); worker.setIsTouched(true); worker.connectDevice(device); } else { // Intent for volume adjustment worker.adjustVolume(device, newPosition); } } Loading tests/robotests/src/com/android/settings/media/MediaOutputSliceTest.java +21 −0 Original line number Diff line number Diff line Loading @@ -17,6 +17,7 @@ package com.android.settings.media; import static android.app.slice.Slice.EXTRA_RANGE_VALUE; import static android.app.slice.Slice.HINT_LIST_ITEM; import static android.app.slice.SliceItem.FORMAT_SLICE; Loading Loading @@ -144,6 +145,7 @@ public class MediaOutputSliceTest { final MediaDevice device = mock(MediaDevice.class); when(device.getName()).thenReturn(TEST_DEVICE_1_NAME); when(device.getIcon()).thenReturn(mTestDrawable); when(device.getMaxVolume()).thenReturn(100); when(mLocalMediaManager.getCurrentConnectedDevice()).thenReturn(device); final Slice mediaSlice = mMediaOutputSlice.getSlice(); Loading Loading @@ -188,4 +190,23 @@ public class MediaOutputSliceTest { verify(mLocalMediaManager, never()).connectDevice(device); } @Test public void onNotifyChange_adjustVolume() { mDevices.clear(); final MediaDevice device = mock(MediaDevice.class); when(device.getId()).thenReturn(TEST_DEVICE_1_ID); when(mLocalMediaManager.getMediaDeviceById(mDevices, TEST_DEVICE_1_ID)).thenReturn(device); mDevices.add(device); mMediaDeviceUpdateWorker.onDeviceListUpdate(mDevices); final Intent intent = new Intent(); intent.putExtra("media_device_id", TEST_DEVICE_1_ID); intent.putExtra(EXTRA_RANGE_VALUE, 30); mMediaOutputSlice.onNotifyChange(intent); verify(device).requestSetVolume(30); } } Loading
src/com/android/settings/media/MediaDeviceUpdateWorker.java +13 −0 Original line number Diff line number Diff line Loading @@ -146,6 +146,19 @@ public class MediaDeviceUpdateWorker extends SliceBackgroundWorker return mTopDevice; } /** * Request to set volume. * * @param device for the targeted device. * @param volume for the new value. * */ public void adjustVolume(MediaDevice device, int volume) { ThreadUtils.postOnBackgroundThread(() -> { device.requestSetVolume(volume); }); } private class DevicesChangedBroadcastReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { Loading
src/com/android/settings/media/MediaOutputSlice.java +33 −10 Original line number Diff line number Diff line Loading @@ -16,6 +16,8 @@ package com.android.settings.media; import static android.app.slice.Slice.EXTRA_RANGE_VALUE; import static com.android.settings.slices.CustomSliceRegistry.MEDIA_OUTPUT_SLICE_URI; import android.app.PendingIntent; Loading Loading @@ -49,6 +51,7 @@ public class MediaOutputSlice implements CustomSliceable { private static final String TAG = "MediaOutputSlice"; private static final String MEDIA_DEVICE_ID = "media_device_id"; private static final int NON_SLIDER_VALUE = -1; public static final String MEDIA_PACKAGE_NAME = "media_package_name"; Loading Loading @@ -86,7 +89,7 @@ public class MediaOutputSlice implements CustomSliceable { final MediaDevice topDevice = isTouched ? worker.getTopDevice() : connectedDevice; if (topDevice != null) { listBuilder.addRow(getActiveDeviceHeaderRow(topDevice)); listBuilder.addInputRange(getActiveDeviceHeaderRow(topDevice)); worker.setTopDevice(topDevice); } Loading @@ -100,7 +103,7 @@ public class MediaOutputSlice implements CustomSliceable { return listBuilder.build(); } private ListBuilder.RowBuilder getActiveDeviceHeaderRow(MediaDevice device) { private ListBuilder.InputRangeBuilder getActiveDeviceHeaderRow(MediaDevice device) { final String title = device.getName(); final IconCompat icon = getDeviceIconCompat(device); Loading @@ -108,14 +111,23 @@ public class MediaOutputSlice implements CustomSliceable { getBroadcastIntent(mContext, device.getId(), device.hashCode()); final SliceAction primarySliceAction = SliceAction.createDeeplink(broadcastAction, icon, ListBuilder.ICON_IMAGE, title); final ListBuilder.RowBuilder rowBuilder = new ListBuilder.RowBuilder() final ListBuilder.InputRangeBuilder builder = new ListBuilder.InputRangeBuilder() .setTitleItem(icon, ListBuilder.ICON_IMAGE) .setTitle(title) .setSubtitle(device.getSummary()) .setPrimaryAction(primarySliceAction); .setPrimaryAction(primarySliceAction) .setInputAction(getSliderInputAction(device.hashCode(), device.getId())) .setMax(device.getMaxVolume()) .setValue(device.getCurrentVolume()); return builder; } return rowBuilder; private PendingIntent getSliderInputAction(int requestCode, String id) { final Intent intent = new Intent(getUri().toString()) .setData(getUri()) .putExtra(MEDIA_DEVICE_ID, id) .setClass(mContext, SliceBroadcastReceiver.class); return PendingIntent.getBroadcast(mContext, requestCode, intent, 0); } private IconCompat getDeviceIconCompat(MediaDevice device) { Loading Loading @@ -152,7 +164,7 @@ public class MediaOutputSlice implements CustomSliceable { .setPrimaryAction(SliceAction.create(broadcastAction, deviceIcon, ListBuilder.ICON_IMAGE, title)) .setTitle(title) .setSubtitle(device.getSummary()); .setSubtitle(device.isConnected() ? null : device.getSummary()); return rowBuilder; } Loading @@ -162,7 +174,7 @@ public class MediaOutputSlice implements CustomSliceable { intent.setClass(context, SliceBroadcastReceiver.class); intent.putExtra(MEDIA_DEVICE_ID, id); intent.addFlags(Intent.FLAG_RECEIVER_FOREGROUND); return PendingIntent.getBroadcast(context, requestCode /* requestCode */, intent, return PendingIntent.getBroadcast(context, requestCode, intent, PendingIntent.FLAG_UPDATE_CURRENT); } Loading @@ -175,11 +187,22 @@ public class MediaOutputSlice implements CustomSliceable { public void onNotifyChange(Intent intent) { final MediaDeviceUpdateWorker worker = getWorker(); final String id = intent != null ? intent.getStringExtra(MEDIA_DEVICE_ID) : ""; if (TextUtils.isEmpty(id)) { return; } final MediaDevice device = worker.getMediaDeviceById(id); if (device != null) { if (device == null) { return; } final int newPosition = intent.getIntExtra(EXTRA_RANGE_VALUE, NON_SLIDER_VALUE); if (newPosition == NON_SLIDER_VALUE) { // Intent for device connection Log.d(TAG, "onNotifyChange() device name : " + device.getName()); worker.setIsTouched(true); worker.connectDevice(device); } else { // Intent for volume adjustment worker.adjustVolume(device, newPosition); } } Loading
tests/robotests/src/com/android/settings/media/MediaOutputSliceTest.java +21 −0 Original line number Diff line number Diff line Loading @@ -17,6 +17,7 @@ package com.android.settings.media; import static android.app.slice.Slice.EXTRA_RANGE_VALUE; import static android.app.slice.Slice.HINT_LIST_ITEM; import static android.app.slice.SliceItem.FORMAT_SLICE; Loading Loading @@ -144,6 +145,7 @@ public class MediaOutputSliceTest { final MediaDevice device = mock(MediaDevice.class); when(device.getName()).thenReturn(TEST_DEVICE_1_NAME); when(device.getIcon()).thenReturn(mTestDrawable); when(device.getMaxVolume()).thenReturn(100); when(mLocalMediaManager.getCurrentConnectedDevice()).thenReturn(device); final Slice mediaSlice = mMediaOutputSlice.getSlice(); Loading Loading @@ -188,4 +190,23 @@ public class MediaOutputSliceTest { verify(mLocalMediaManager, never()).connectDevice(device); } @Test public void onNotifyChange_adjustVolume() { mDevices.clear(); final MediaDevice device = mock(MediaDevice.class); when(device.getId()).thenReturn(TEST_DEVICE_1_ID); when(mLocalMediaManager.getMediaDeviceById(mDevices, TEST_DEVICE_1_ID)).thenReturn(device); mDevices.add(device); mMediaDeviceUpdateWorker.onDeviceListUpdate(mDevices); final Intent intent = new Intent(); intent.putExtra("media_device_id", TEST_DEVICE_1_ID); intent.putExtra(EXTRA_RANGE_VALUE, 30); mMediaOutputSlice.onNotifyChange(intent); verify(device).requestSetVolume(30); } }