2013-09-24 04:17:12 +00:00
|
|
|
// Copyright (c) 2013 Google Inc. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
|
|
// found in the LICENSE file.
|
|
|
|
|
|
|
|
#ifndef MEDIA_BASE_STREAM_INFO_H_
|
|
|
|
#define MEDIA_BASE_STREAM_INFO_H_
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "base/memory/ref_counted.h"
|
|
|
|
|
|
|
|
namespace media {
|
|
|
|
|
|
|
|
enum StreamType {
|
|
|
|
kStreamAudio,
|
|
|
|
kStreamVideo,
|
|
|
|
};
|
|
|
|
|
2013-11-12 20:32:44 +00:00
|
|
|
class StreamInfo : public base::RefCountedThreadSafe<StreamInfo> {
|
2013-09-24 04:17:12 +00:00
|
|
|
public:
|
|
|
|
StreamInfo(StreamType stream_type,
|
|
|
|
int track_id,
|
2013-10-14 20:55:48 +00:00
|
|
|
uint32 time_scale,
|
|
|
|
uint64 duration,
|
|
|
|
const std::string& codec_string,
|
|
|
|
const std::string& language,
|
2013-09-24 04:17:12 +00:00
|
|
|
const uint8* extra_data,
|
|
|
|
size_t extra_data_size,
|
|
|
|
bool is_encrypted);
|
|
|
|
|
|
|
|
// Returns true if this object has appropriate configuration values, false
|
|
|
|
// otherwise.
|
|
|
|
virtual bool IsValidConfig() const = 0;
|
|
|
|
|
|
|
|
// Returns a human-readable string describing |*this|.
|
2013-10-14 20:55:48 +00:00
|
|
|
virtual std::string ToString() const;
|
2013-09-24 04:17:12 +00:00
|
|
|
|
|
|
|
StreamType stream_type() const { return stream_type_; }
|
|
|
|
int track_id() const { return track_id_; }
|
2013-10-14 20:55:48 +00:00
|
|
|
uint32 time_scale() const { return time_scale_; }
|
|
|
|
uint64 duration() const { return duration_; }
|
|
|
|
const std::string& codec_string() const { return codec_string_; }
|
|
|
|
const std::string& language() const { return language_; }
|
2013-09-24 04:17:12 +00:00
|
|
|
|
|
|
|
bool is_encrypted() const { return is_encrypted_; }
|
|
|
|
|
2013-11-12 20:32:44 +00:00
|
|
|
const std::vector<uint8>& extra_data() const { return extra_data_; }
|
2013-09-24 04:17:12 +00:00
|
|
|
|
2013-10-14 20:55:48 +00:00
|
|
|
void set_duration(int duration) { duration_ = duration; }
|
|
|
|
|
2014-01-16 00:52:07 +00:00
|
|
|
protected:
|
|
|
|
friend class base::RefCountedThreadSafe<StreamInfo>;
|
|
|
|
virtual ~StreamInfo();
|
|
|
|
|
2013-09-24 04:17:12 +00:00
|
|
|
private:
|
|
|
|
// Whether the stream is Audio or Video.
|
|
|
|
StreamType stream_type_;
|
|
|
|
int track_id_;
|
2013-10-14 20:55:48 +00:00
|
|
|
// The actual time is calculated as time / time_scale_ in seconds.
|
|
|
|
uint32 time_scale_;
|
|
|
|
// Duration base on time_scale.
|
|
|
|
uint64 duration_;
|
|
|
|
std::string codec_string_;
|
|
|
|
std::string language_;
|
2013-09-24 04:17:12 +00:00
|
|
|
// Whether the stream is potentially encrypted.
|
|
|
|
// Note that in a potentially encrypted stream, individual buffers
|
|
|
|
// can be encrypted or not encrypted.
|
|
|
|
bool is_encrypted_;
|
|
|
|
// Optional byte data required for some audio/video decoders such as Vorbis
|
|
|
|
// codebooks.
|
|
|
|
std::vector<uint8> extra_data_;
|
|
|
|
|
|
|
|
// Not using DISALLOW_COPY_AND_ASSIGN here intentionally to allow the compiler
|
|
|
|
// generated copy constructor and assignment operator. Since the extra data is
|
|
|
|
// typically small, the performance impact is minimal.
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace media
|
|
|
|
|
|
|
|
#endif // MEDIA_BASE_STREAM_INFO_H_
|