summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--api/current.txt11
-rw-r--r--media/java/android/media/audiofx/Visualizer.java33
2 files changed, 23 insertions, 21 deletions
diff --git a/api/current.txt b/api/current.txt
index f4b95d2..e6fb767 100644
--- a/api/current.txt
+++ b/api/current.txt
@@ -13872,6 +13872,8 @@ package android.media.audiofx {
method public boolean getEnabled();
method public int getFft(byte[]) throws java.lang.IllegalStateException;
method public static int getMaxCaptureRate();
+ method public int getMeasurementMode() throws java.lang.IllegalStateException;
+ method public int getMeasurementPeakRms(android.media.audiofx.Visualizer.MeasurementPeakRms);
method public int getSamplingRate() throws java.lang.IllegalStateException;
method public int getScalingMode() throws java.lang.IllegalStateException;
method public int getWaveForm(byte[]) throws java.lang.IllegalStateException;
@@ -13879,6 +13881,7 @@ package android.media.audiofx {
method public int setCaptureSize(int) throws java.lang.IllegalStateException;
method public int setDataCaptureListener(android.media.audiofx.Visualizer.OnDataCaptureListener, int, boolean, boolean);
method public int setEnabled(boolean) throws java.lang.IllegalStateException;
+ method public int setMeasurementMode(int) throws java.lang.IllegalStateException;
method public int setScalingMode(int) throws java.lang.IllegalStateException;
field public static final int ALREADY_EXISTS = -2; // 0xfffffffe
field public static final int ERROR = -1; // 0xffffffff
@@ -13887,6 +13890,8 @@ package android.media.audiofx {
field public static final int ERROR_INVALID_OPERATION = -5; // 0xfffffffb
field public static final int ERROR_NO_INIT = -3; // 0xfffffffd
field public static final int ERROR_NO_MEMORY = -6; // 0xfffffffa
+ field public static final int MEASUREMENT_MODE_NONE = 0; // 0x0
+ field public static final int MEASUREMENT_MODE_PEAK_RMS = 1; // 0x1
field public static final int SCALING_MODE_AS_PLAYED = 1; // 0x1
field public static final int SCALING_MODE_NORMALIZED = 0; // 0x0
field public static final int STATE_ENABLED = 2; // 0x2
@@ -13895,6 +13900,12 @@ package android.media.audiofx {
field public static final int SUCCESS = 0; // 0x0
}
+ public static final class Visualizer.MeasurementPeakRms {
+ ctor public Visualizer.MeasurementPeakRms();
+ field public int mPeak;
+ field public int mRms;
+ }
+
public static abstract interface Visualizer.OnDataCaptureListener {
method public abstract void onFftDataCapture(android.media.audiofx.Visualizer, byte[], int);
method public abstract void onWaveFormDataCapture(android.media.audiofx.Visualizer, byte[], int);
diff --git a/media/java/android/media/audiofx/Visualizer.java b/media/java/android/media/audiofx/Visualizer.java
index 580a4f9..fb7f718 100644
--- a/media/java/android/media/audiofx/Visualizer.java
+++ b/media/java/android/media/audiofx/Visualizer.java
@@ -57,6 +57,11 @@ import android.os.Message;
* anymore to free up native resources associated to the Visualizer instance.
* <p>Creating a Visualizer on the output mix (audio session 0) requires permission
* {@link android.Manifest.permission#MODIFY_AUDIO_SETTINGS}
+ * <p>The Visualizer class can also be used to perform measurements on the audio being played back.
+ * The measurements to perform are defined by setting a mask of the requested measurement modes with
+ * {@link #setMeasurementMode(int)}. Supported values are {@link #MEASUREMENT_MODE_NONE} to cancel
+ * any measurement, and {@link #MEASUREMENT_MODE_PEAK_RMS} for peak and RMS monitoring.
+ * Measurements can be retrieved through {@link #getMeasurementPeakRms(MeasurementPeakRms)}.
*/
public class Visualizer {
@@ -94,20 +99,15 @@ public class Visualizer {
public static final int SCALING_MODE_AS_PLAYED = 1;
/**
- * @hide
- * CANDIDATE FOR PUBLIC API
- * Defines a measurement mode with no requested measurement.
+ * Defines a measurement mode in which no measurements are performed.
*/
public static final int MEASUREMENT_MODE_NONE = 0;
/**
- * @hide
- * CANDIDATE FOR PUBLIC API
* Defines a measurement mode which computes the peak and RMS value in mB, where 0mB is the
* maximum sample value, and -9600mB is the minimum value.
- * Values for peak and RMS can be retrieved with {@link #getIntMeasurements(int, int[])}, where
- * the array holds the peak value at index {@link #MEASUREMENT_INDEX_PEAK} in the measurement
- * array, and the RMS value at index {@link #MEASUREMENT_INDEX_RMS}.
+ * Values for peak and RMS can be retrieved with
+ * {@link #getMeasurementPeakRms(MeasurementPeakRms)}.
*/
public static final int MEASUREMENT_MODE_PEAK_RMS = 1 << 0;
@@ -368,8 +368,6 @@ public class Visualizer {
}
/**
- * @hide
- * CANDIDATE FOR PUBLIC API
* Sets the combination of measurement modes to be performed by this audio effect.
* @param mode a mask of the measurements to perform. The valid values are
* {@link #MEASUREMENT_MODE_NONE} (to cancel any measurement)
@@ -389,8 +387,6 @@ public class Visualizer {
}
/**
- * @hide
- * CANDIDATE FOR PUBLIC API
* Returns the current measurement modes performed by this audio effect
* @return the mask of the measurements,
* {@link #MEASUREMENT_MODE_NONE} (when no measurements are performed)
@@ -497,30 +493,25 @@ public class Visualizer {
}
/**
- * @hide
- * CANDIDATE FOR PUBLIC API
* A class to store peak and RMS values.
* Peak and RMS are expressed in mB, as described in the
* {@link Visualizer#MEASUREMENT_MODE_PEAK_RMS} measurement mode.
*/
public static final class MeasurementPeakRms {
/**
- * @hide
- * CANDIDATE FOR PUBLIC API
+ * The peak value in mB.
*/
public int mPeak;
/**
- * @hide
- * CANDIDATE FOR PUBLIC API
+ * The RMS value in mB.
*/
public int mRms;
}
/**
- * @hide
* Retrieves the latest peak and RMS measurement.
- * Sets the peak and RMS fields of the {@link Visualizer.MeasurementPeakRms} to the latest
- * measured values.
+ * Sets the peak and RMS fields of the supplied {@link Visualizer.MeasurementPeakRms} to the
+ * latest measured values.
* @param measurement a non-null {@link Visualizer.MeasurementPeakRms} instance to store
* the measurement values.
* @return {@link #SUCCESS} in case of success, {@link #ERROR_BAD_VALUE},