summaryrefslogtreecommitdiffstats
path: root/media/java
diff options
context:
space:
mode:
authorJae Seo <jaeseo@google.com>2015-05-18 18:05:33 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2015-05-18 18:05:34 +0000
commit194118f913cc6b018291cff4b1779a3bb24af5c0 (patch)
treee9bb627ec885e0b81c9a10aafbf0bb07068920f8 /media/java
parentbeda8613ad7bc01affa17857faed04d9589db34c (diff)
parent76c4fc297723aceea9d4021b26b39c26768b54c3 (diff)
downloadframeworks_base-194118f913cc6b018291cff4b1779a3bb24af5c0.zip
frameworks_base-194118f913cc6b018291cff4b1779a3bb24af5c0.tar.gz
frameworks_base-194118f913cc6b018291cff4b1779a3bb24af5c0.tar.bz2
Merge "Make PlaybackParams parcelable" into mnc-dev
Diffstat (limited to 'media/java')
-rw-r--r--media/java/android/media/PlaybackParams.aidl19
-rw-r--r--media/java/android/media/PlaybackParams.java50
2 files changed, 66 insertions, 3 deletions
diff --git a/media/java/android/media/PlaybackParams.aidl b/media/java/android/media/PlaybackParams.aidl
new file mode 100644
index 0000000..0356117
--- /dev/null
+++ b/media/java/android/media/PlaybackParams.aidl
@@ -0,0 +1,19 @@
+/*
+ * Copyright 2015 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package android.media;
+
+parcelable PlaybackParams;
diff --git a/media/java/android/media/PlaybackParams.java b/media/java/android/media/PlaybackParams.java
index 7212904..021dbf2 100644
--- a/media/java/android/media/PlaybackParams.java
+++ b/media/java/android/media/PlaybackParams.java
@@ -16,11 +16,13 @@
package android.media;
+import android.annotation.IntDef;
+import android.os.Parcel;
+import android.os.Parcelable;
+
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
-import android.annotation.IntDef;
-
/**
* Structure for common playback params.
*
@@ -52,7 +54,7 @@ import android.annotation.IntDef;
* similar to {@link AudioTrack#setPlaybackRate(int)}.</li>
* </ul>
*/
-public final class PlaybackParams {
+public final class PlaybackParams implements Parcelable {
/** @hide */
@IntDef(
value = {
@@ -94,6 +96,20 @@ public final class PlaybackParams {
private float mPitch = 1.0f;
private float mSpeed = 1.0f;
+ public PlaybackParams() {
+ }
+
+ private PlaybackParams(Parcel in) {
+ mSet = in.readInt();
+ mAudioFallbackMode = in.readInt();
+ mAudioStretchMode = in.readInt();
+ mPitch = in.readFloat();
+ if (mPitch < 0.f) {
+ mPitch = 0.f;
+ }
+ mSpeed = in.readFloat();
+ }
+
/**
* Allows defaults to be returned for properties not set.
* Otherwise a {@link java.lang.IllegalArgumentException} exception
@@ -203,4 +219,32 @@ public final class PlaybackParams {
}
return mSpeed;
}
+
+ public static final Parcelable.Creator<PlaybackParams> CREATOR =
+ new Parcelable.Creator<PlaybackParams>() {
+ @Override
+ public PlaybackParams createFromParcel(Parcel in) {
+ return new PlaybackParams(in);
+ }
+
+ @Override
+ public PlaybackParams[] newArray(int size) {
+ return new PlaybackParams[size];
+ }
+ };
+
+
+ @Override
+ public int describeContents() {
+ return 0;
+ }
+
+ @Override
+ public void writeToParcel(Parcel dest, int flags) {
+ dest.writeInt(mSet);
+ dest.writeInt(mAudioFallbackMode);
+ dest.writeInt(mAudioStretchMode);
+ dest.writeFloat(mPitch);
+ dest.writeFloat(mSpeed);
+ }
}