Merge "Add SystemApi
tag on getLastAudibleStreamVolume"
This commit is contained in:
commit
f3a2e55ff7
@ -5252,6 +5252,7 @@ package android.media {
|
||||
method @NonNull @RequiresPermission(android.Manifest.permission.MODIFY_AUDIO_ROUTING) public static java.util.List<android.media.audiopolicy.AudioVolumeGroup> getAudioVolumeGroups();
|
||||
method @RequiresPermission(anyOf={android.Manifest.permission.MODIFY_AUDIO_ROUTING, "android.permission.QUERY_AUDIO_STATE"}) public int getDeviceVolumeBehavior(@NonNull android.media.AudioDeviceAttributes);
|
||||
method @NonNull @RequiresPermission(anyOf={android.Manifest.permission.MODIFY_AUDIO_ROUTING, "android.permission.QUERY_AUDIO_STATE"}) public java.util.List<android.media.AudioDeviceAttributes> getDevicesForAttributes(@NonNull android.media.AudioAttributes);
|
||||
method @RequiresPermission("android.permission.QUERY_AUDIO_STATE") public int getLastAudibleStreamVolume(int);
|
||||
method @IntRange(from=0) public long getMaxAdditionalOutputDeviceDelay(@NonNull android.media.AudioDeviceInfo);
|
||||
method @IntRange(from=0) @RequiresPermission(android.Manifest.permission.MODIFY_AUDIO_ROUTING) public int getMaxVolumeIndexForAttributes(@NonNull android.media.AudioAttributes);
|
||||
method @IntRange(from=0) @RequiresPermission(android.Manifest.permission.MODIFY_AUDIO_ROUTING) public int getMinVolumeIndexForAttributes(@NonNull android.media.AudioAttributes);
|
||||
|
@ -1172,7 +1172,8 @@ public class AudioManager {
|
||||
*
|
||||
* @hide
|
||||
*/
|
||||
@UnsupportedAppUsage
|
||||
@SystemApi
|
||||
@RequiresPermission("android.permission.QUERY_AUDIO_STATE")
|
||||
public int getLastAudibleStreamVolume(int streamType) {
|
||||
final IAudioService service = getService();
|
||||
try {
|
||||
|
@ -3193,6 +3193,13 @@ public class AudioService extends IAudioService.Stub
|
||||
}
|
||||
}
|
||||
|
||||
private void enforceQueryStatePermission() {
|
||||
if (mContext.checkCallingOrSelfPermission(Manifest.permission.QUERY_AUDIO_STATE)
|
||||
!= PackageManager.PERMISSION_GRANTED) {
|
||||
throw new SecurityException("Missing QUERY_AUDIO_STATE permissions");
|
||||
}
|
||||
}
|
||||
|
||||
private void enforceQueryStateOrModifyRoutingPermission() {
|
||||
if (mContext.checkCallingOrSelfPermission(android.Manifest.permission.MODIFY_AUDIO_ROUTING)
|
||||
!= PackageManager.PERMISSION_GRANTED
|
||||
@ -4094,6 +4101,7 @@ public class AudioService extends IAudioService.Stub
|
||||
|
||||
/** Get last audible volume before stream was muted. */
|
||||
public int getLastAudibleStreamVolume(int streamType) {
|
||||
enforceQueryStatePermission();
|
||||
ensureValidStreamType(streamType);
|
||||
int device = getDeviceForStream(streamType);
|
||||
return (mStreamStates[streamType].getIndex(device) + 5) / 10;
|
||||
|
Loading…
x
Reference in New Issue
Block a user