summaryrefslogtreecommitdiffstats
path: root/media/libstagefright/timedtext/TimedTextSRTSource.h
blob: 598c20063d0ed43f411c7fedfaca18e6e8ba49d1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/*
 * Copyright (C) 2012 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.
 */

#ifndef TIMED_TEXT_SRT_SOURCE_H_
#define TIMED_TEXT_SRT_SOURCE_H_

#include <media/stagefright/MediaErrors.h>
#include <media/stagefright/MediaSource.h>
#include <utils/Compat.h>  // off64_t

#include "TimedTextSource.h"

namespace android {

class AString;
class DataSource;
class MediaBuffer;
class Parcel;

class TimedTextSRTSource : public TimedTextSource {
public:
    TimedTextSRTSource(const sp<DataSource>& dataSource);
    virtual status_t start();
    virtual status_t stop();
    virtual status_t read(
            int64_t *startTimeUs,
            int64_t *endTimeUs,
            Parcel *parcel,
            const MediaSource::ReadOptions *options = NULL);
    virtual sp<MetaData> getFormat();

protected:
    virtual ~TimedTextSRTSource();

private:
    sp<DataSource> mSource;
    sp<MetaData> mMetaData;

    struct TextInfo {
        int64_t endTimeUs;
        // The offset of the text in the original file.
        off64_t offset;
        int textLen;
    };

    size_t mIndex;
    KeyedVector<int64_t, TextInfo> mTextVector;

    void reset();
    status_t scanFile();
    status_t getNextSubtitleInfo(
            off64_t *offset, int64_t *startTimeUs, TextInfo *info);
    status_t readNextLine(off64_t *offset, AString *data);
    status_t getText(
            const MediaSource::ReadOptions *options,
            AString *text, int64_t *startTimeUs, int64_t *endTimeUs);
    status_t extractAndAppendLocalDescriptions(
            int64_t timeUs, const AString &text, Parcel *parcel);

    // Compares the time range of the subtitle at index to the given timeUs.
    // The time range of the subtitle to match with given timeUs is extended to
    // [endTimeUs of the previous subtitle, endTimeUs of current subtitle).
    //
    // This compare function is used to find a next subtitle when read() is
    // called with seek options. Note that timeUs within gap ranges, such as
    // [200, 300) in the below example, will be matched to the closest future
    // subtitle, [300, 400).
    //
    // For instance, assuming there are 3 subtitles in mTextVector,
    // 0: [100, 200)      ----> [0, 200)
    // 1: [300, 400)      ----> [200, 400)
    // 2: [500, 600)      ----> [400, 600)
    // If the 'index' parameter contains 1, this function
    // returns 0, if timeUs is in [200, 400)
    // returns -1, if timeUs >= 400,
    // returns 1, if timeUs < 200.
    int compareExtendedRangeAndTime(size_t index, int64_t timeUs);

    DISALLOW_EVIL_CONSTRUCTORS(TimedTextSRTSource);
};

}  // namespace android

#endif  // TIMED_TEXT_SRT_SOURCE_H_