2014-02-14 23:21:05 +00:00
|
|
|
// Copyright 2014 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 or at
|
|
|
|
// https://developers.google.com/open-source/licenses/bsd
|
2013-11-12 20:37:58 +00:00
|
|
|
|
|
|
|
#ifndef MEDIA_MP4_MP4_GENERAL_SEGMENTER_H_
|
|
|
|
#define MEDIA_MP4_MP4_GENERAL_SEGMENTER_H_
|
|
|
|
|
|
|
|
#include "media/mp4/mp4_segmenter.h"
|
|
|
|
|
|
|
|
namespace media {
|
|
|
|
namespace mp4 {
|
|
|
|
|
|
|
|
struct SegmentType;
|
|
|
|
|
2014-01-23 22:34:39 +00:00
|
|
|
/// Segmenter for MP4 live, main and simple profiles. The generated media file
|
|
|
|
/// can contain one or many segments with segment duration defined by @b
|
|
|
|
/// MuxerOptions.segment_duration. A segment can contain one or many
|
|
|
|
/// subsegments defined by @b num_subsegments_per_sidx. A subsegment can
|
|
|
|
/// contain one or many fragments with fragment duration defined by @b
|
|
|
|
/// MuxerOptions.fragment_duration. The actual segment or fragment duration
|
|
|
|
/// may not match the requested duration exactly, but will be approximated.
|
|
|
|
/// That is, the segmenter tries to end segment/fragment at the first sample
|
|
|
|
/// with overall segment/fragment duration not smaller than defined duration
|
|
|
|
/// and yet meet SAP requirements. The generated segments are written to files
|
|
|
|
/// defined by @b MuxerOptions.segment_template if specified; otherwise,
|
|
|
|
/// the segments are appended to the main output file specified by @b
|
|
|
|
/// MuxerOptions.output_file_name.
|
2013-11-12 20:37:58 +00:00
|
|
|
class MP4GeneralSegmenter : public MP4Segmenter {
|
|
|
|
public:
|
2014-01-08 19:56:59 +00:00
|
|
|
MP4GeneralSegmenter(const MuxerOptions& options,
|
|
|
|
scoped_ptr<FileType> ftyp,
|
|
|
|
scoped_ptr<Movie> moov);
|
2014-01-16 00:52:07 +00:00
|
|
|
virtual ~MP4GeneralSegmenter();
|
2013-11-12 20:37:58 +00:00
|
|
|
|
2014-01-23 22:34:39 +00:00
|
|
|
/// @name MP4Segmenter implementation overrides.
|
|
|
|
/// @{
|
2013-11-12 20:37:58 +00:00
|
|
|
virtual Status Initialize(EncryptorSource* encryptor_source,
|
2014-01-14 01:38:34 +00:00
|
|
|
double clear_lead_in_seconds,
|
2013-11-12 20:37:58 +00:00
|
|
|
const std::vector<MediaStream*>& streams) OVERRIDE;
|
|
|
|
|
2013-12-12 23:49:31 +00:00
|
|
|
virtual bool GetInitRange(size_t* offset, size_t* size) OVERRIDE;
|
|
|
|
virtual bool GetIndexRange(size_t* offset, size_t* size) OVERRIDE;
|
2014-01-23 22:34:39 +00:00
|
|
|
/// @}
|
2013-12-12 23:49:31 +00:00
|
|
|
|
2013-11-12 20:37:58 +00:00
|
|
|
protected:
|
|
|
|
virtual Status FinalizeSegment() OVERRIDE;
|
|
|
|
|
|
|
|
private:
|
|
|
|
// Write segment to file.
|
|
|
|
Status WriteSegment();
|
|
|
|
|
|
|
|
scoped_ptr<SegmentType> styp_;
|
|
|
|
uint32 num_segments_;
|
|
|
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(MP4GeneralSegmenter);
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace mp4
|
|
|
|
} // namespace media
|
|
|
|
|
|
|
|
#endif // MEDIA_MP4_MP4_GENERAL_SEGMENTER_H_
|