Added in API level 26

Builder


class Builder
kotlin.Any
   ↳ android.media.VolumeShaper.Configuration.Builder

Builder class for a VolumeShaper.Configuration object.

Here is an example where Builder is used to define the VolumeShaper.Configuration.

VolumeShaper.Configuration LINEAR_RAMP =
          new VolumeShaper.Configuration.Builder()
              .setInterpolatorType(VolumeShaper.Configuration.INTERPOLATOR_TYPE_LINEAR)
              .setCurve(new float[] { 0.f, 1.f }, // times
                        new float[] { 0.f, 1.f }) // volumes
              .setDuration(1000)
              .build();
  

Summary

Public constructors

Constructs a new Builder with the defaults.

Constructs a new Builder with settings copied from a given VolumeShaper.Configuration.

Public methods
VolumeShaper.Configuration

Builds a new VolumeShaper object.

VolumeShaper.Configuration.Builder

Inverts the volume curve so that the max volume becomes the min volume and vice versa.

VolumeShaper.Configuration.Builder

Reflects the volume curve so that the shaper changes volume from the end to the start.

VolumeShaper.Configuration.Builder

Scale the curve end volume to a target value.

VolumeShaper.Configuration.Builder

Scale the curve start volume to a target value.

VolumeShaper.Configuration.Builder
setCurve(times: FloatArray, volumes: FloatArray)

Sets the volume curve.

VolumeShaper.Configuration.Builder
setDuration(durationMillis: Long)

Sets the VolumeShaper duration in milliseconds.

VolumeShaper.Configuration.Builder
setInterpolatorType(interpolatorType: Int)

Sets the interpolator type.

Public constructors

Builder

Added in API level 26
Builder()

Constructs a new Builder with the defaults.

Builder

Added in API level 26
Builder(configuration: VolumeShaper.Configuration)

Constructs a new Builder with settings copied from a given VolumeShaper.Configuration.

Parameters
configuration VolumeShaper.Configuration: prototypical configuration which will be reused in the new Builder. This value cannot be null.

Public methods

build

Added in API level 26
fun build(): VolumeShaper.Configuration

Builds a new VolumeShaper object.

Return
VolumeShaper.Configuration a new VolumeShaper object. This value cannot be null.
Exceptions
java.lang.IllegalStateException if curve is not properly set.

invertVolumes

Added in API level 26
fun invertVolumes(): VolumeShaper.Configuration.Builder

Inverts the volume curve so that the max volume becomes the min volume and vice versa.

Return
VolumeShaper.Configuration.Builder the same Builder instance. This value cannot be null.
Exceptions
java.lang.IllegalStateException if curve has not been set.

reflectTimes

Added in API level 26
fun reflectTimes(): VolumeShaper.Configuration.Builder

Reflects the volume curve so that the shaper changes volume from the end to the start.

Return
VolumeShaper.Configuration.Builder the same Builder instance. This value cannot be null.
Exceptions
java.lang.IllegalStateException if curve has not been set.

scaleToEndVolume

Added in API level 26
fun scaleToEndVolume(volume: Float): VolumeShaper.Configuration.Builder

Scale the curve end volume to a target value. Keeps the start volume the same. This works best if the volume curve is monotonic.

Parameters
volume Float: the target end volume to use.
Return
VolumeShaper.Configuration.Builder the same Builder instance. This value cannot be null.
Exceptions
java.lang.IllegalArgumentException if volume is not valid.
java.lang.IllegalStateException if curve has not been set.

scaleToStartVolume

Added in API level 26
fun scaleToStartVolume(volume: Float): VolumeShaper.Configuration.Builder

Scale the curve start volume to a target value. Keeps the end volume the same. This works best if the volume curve is monotonic.

Parameters
volume Float: the target start volume to use.
Return
VolumeShaper.Configuration.Builder the same Builder instance. This value cannot be null.
Exceptions
java.lang.IllegalArgumentException if volume is not valid.
java.lang.IllegalStateException if curve has not been set.

setCurve

Added in API level 26
fun setCurve(
    times: FloatArray,
    volumes: FloatArray
): VolumeShaper.Configuration.Builder

Sets the volume curve. The volume curve is represented by a set of control points given by two float arrays of equal length, one representing the time (x) coordinates and one corresponding to the volume (y) coordinates. The length must be at least 2 and no greater than VolumeShaper.Configuration.getMaximumCurvePoints().

The volume curve is normalized as follows: time (x) coordinates should be monotonically increasing, from 0.f to 1.f; volume (y) coordinates must be within 0.f to 1.f.

The time scale is set by setDuration.

Parameters
times FloatArray: an array of float values representing the time line of the volume curve. This value cannot be null.
volumes FloatArray: an array of float values representing the amplitude of the volume curve. This value cannot be null.
Return
VolumeShaper.Configuration.Builder the same Builder instance. This value cannot be null.
Exceptions
java.lang.IllegalArgumentException if times or volumes is invalid.

setDuration

Added in API level 26
fun setDuration(durationMillis: Long): VolumeShaper.Configuration.Builder

Sets the VolumeShaper duration in milliseconds. If omitted, the default duration is 1 second.

Parameters
durationMillis Long:
Return
VolumeShaper.Configuration.Builder the same Builder instance. This value cannot be null.
Exceptions
java.lang.IllegalArgumentException if durationMillis is not strictly positive.

setInterpolatorType

Added in API level 26
fun setInterpolatorType(interpolatorType: Int): VolumeShaper.Configuration.Builder

Sets the interpolator type. If omitted the default interpolator type is INTERPOLATOR_TYPE_CUBIC.

Parameters
interpolatorType Int: method of interpolation used for the volume curve. One of INTERPOLATOR_TYPE_STEP, INTERPOLATOR_TYPE_LINEAR, INTERPOLATOR_TYPE_CUBIC, INTERPOLATOR_TYPE_CUBIC_MONOTONIC. Value is android.media.VolumeShaper.Configuration#INTERPOLATOR_TYPE_STEP, android.media.VolumeShaper.Configuration#INTERPOLATOR_TYPE_LINEAR, android.media.VolumeShaper.Configuration#INTERPOLATOR_TYPE_CUBIC, or android.media.VolumeShaper.Configuration#INTERPOLATOR_TYPE_CUBIC_MONOTONIC
Return
VolumeShaper.Configuration.Builder the same Builder instance. This value cannot be null.
Exceptions
java.lang.IllegalArgumentException if interpolatorType is not valid.