| /* |
| * Copyright (C) 2011 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; |
| |
| import android.annotation.NonNull; |
| import android.os.Parcel; |
| |
| /** |
| * Class encapsulating subtitle data, as received through the |
| * {@link MediaPlayer.OnSubtitleDataListener} interface. |
| * The subtitle data includes: |
| * <ul> |
| * <li> the track index</li> |
| * <li> the start time (in microseconds) of the data</li> |
| * <li> the duration (in microseconds) of the data</li> |
| * <li> the actual data.</li> |
| * </ul> |
| * The data is stored in a byte-array, and is encoded in one of the supported in-band |
| * subtitle formats. The subtitle encoding is determined by the MIME type of the |
| * {@link MediaPlayer.TrackInfo} of the subtitle track, one of |
| * {@link MediaFormat#MIMETYPE_TEXT_CEA_608}, {@link MediaFormat#MIMETYPE_TEXT_CEA_708}, |
| * {@link MediaFormat#MIMETYPE_TEXT_VTT}. |
| * <p> |
| * Here is an example of iterating over the tracks of a {@link MediaPlayer}, and checking which |
| * encoding is used for the subtitle tracks: |
| * <p> |
| * <pre class="prettyprint"> |
| * MediaPlayer mp = new MediaPlayer(); |
| * mp.setDataSource(myContentLocation); |
| * mp.prepare(); // synchronous prepare, ready to use when method returns |
| * final TrackInfo[] trackInfos = mp.getTrackInfo(); |
| * for (TrackInfo info : trackInfo) { |
| * if (info.getTrackType() == TrackInfo.MEDIA_TRACK_TYPE_SUBTITLE) { |
| * final String mime = info.getFormat().getString(MediaFormat.KEY_MIME); |
| * if (MediaFormat.MIMETYPE_TEXT_CEA_608.equals(mime) { |
| * // subtitle encoding is CEA 608 |
| * } else if (MediaFormat.MIMETYPE_TEXT_CEA_708.equals(mime) { |
| * // subtitle encoding is CEA 708 |
| * } else if (MediaFormat.MIMETYPE_TEXT_VTT.equals(mime) { |
| * // subtitle encoding is WebVTT |
| * } |
| * } |
| * } |
| * </pre> |
| * <p> |
| * See |
| * {@link MediaPlayer#setOnSubtitleDataListener(android.media.MediaPlayer.OnSubtitleDataListener, android.os.Handler)} |
| * to receive subtitle data from a MediaPlayer object. |
| * |
| * @see android.media.MediaPlayer |
| */ |
| public final class SubtitleData |
| { |
| private static final String TAG = "SubtitleData"; |
| |
| private int mTrackIndex; |
| private long mStartTimeUs; |
| private long mDurationUs; |
| private byte[] mData; |
| |
| /** @hide */ |
| public SubtitleData(Parcel parcel) { |
| if (!parseParcel(parcel)) { |
| throw new IllegalArgumentException("parseParcel() fails"); |
| } |
| } |
| |
| /** |
| * Constructor. |
| * |
| * @param trackIndex the index of the media player track which contains this subtitle data. |
| * @param startTimeUs the start time in microsecond for the subtitle data |
| * @param durationUs the duration in microsecond for the subtitle data |
| * @param data the data array for the subtitle data. It should not be null. |
| * No data copying is made. |
| */ |
| public SubtitleData(int trackIndex, long startTimeUs, long durationUs, @NonNull byte[] data) { |
| if (data == null) { |
| throw new IllegalArgumentException("null data is not allowed"); |
| } |
| mTrackIndex = trackIndex; |
| mStartTimeUs = startTimeUs; |
| mDurationUs = durationUs; |
| mData = data; |
| } |
| |
| /** |
| * Returns the index of the media player track which contains this subtitle data. |
| * @return an index in the array returned by {@link MediaPlayer#getTrackInfo()}. |
| */ |
| public int getTrackIndex() { |
| return mTrackIndex; |
| } |
| |
| /** |
| * Returns the media time at which the subtitle should be displayed, expressed in microseconds. |
| * @return the display start time for the subtitle |
| */ |
| public long getStartTimeUs() { |
| return mStartTimeUs; |
| } |
| |
| /** |
| * Returns the duration in microsecond during which the subtitle should be displayed. |
| * @return the display duration for the subtitle |
| */ |
| public long getDurationUs() { |
| return mDurationUs; |
| } |
| |
| /** |
| * Returns the encoded data for the subtitle content. |
| * Encoding format depends on the subtitle type, refer to |
| * <a href="https://en.wikipedia.org/wiki/CEA-708">CEA 708</a>, |
| * <a href="https://en.wikipedia.org/wiki/EIA-608">CEA/EIA 608</a> and |
| * <a href="https://www.w3.org/TR/webvtt1/">WebVTT</a>, defined by the MIME type |
| * of the subtitle track. |
| * @return the encoded subtitle data |
| */ |
| public @NonNull byte[] getData() { |
| return mData; |
| } |
| |
| private boolean parseParcel(Parcel parcel) { |
| parcel.setDataPosition(0); |
| if (parcel.dataAvail() == 0) { |
| return false; |
| } |
| |
| mTrackIndex = parcel.readInt(); |
| mStartTimeUs = parcel.readLong(); |
| mDurationUs = parcel.readLong(); |
| mData = new byte[parcel.readInt()]; |
| parcel.readByteArray(mData); |
| |
| return true; |
| } |
| } |