Files
shaka-player/lib/media/segment_reference.js
T
Timothy Drews 36fec68e75 Create 'media' namespace for stream generic code.
* Move internal non-DASH specific code into the 'media' namespace.
* Remove DASH references from generic stream code.

The documentation is not changed as a follow-up patch will factor out
DASH functionality from StreamVideoSource back into a new
DashVideoSource class.

b/18903621

Change-Id: I78d6e4f2824d4983619f17872828d95655fcfe50
2015-01-26 15:08:48 -08:00

83 lines
2.5 KiB
JavaScript

/**
* Copyright 2014 Google Inc.
*
* 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.
*
* @fileoverview Implements a segment reference structure.
*/
goog.provide('shaka.media.SegmentReference');
goog.require('goog.Uri');
/**
* Creates a SegmentReference, which is a reference to some media segment.
*
* @param {number} index The segment's number, starting at 0, within the stream.
* @param {number} startTime The time, in seconds, that the segment begins.
* @param {?number} endTime The time, in seconds, that the segment ends. The
* segment ends immediately before this time. A null value indicates that
* the segment continues to the end of the stream.
* @param {number} startByte The position of the segment's first byte.
* @param {?number} endByte The position of the segment's last byte, inclusive.
* A null value indicates that the segment continues to the end of the
* file located at |url|.
* @param {!goog.Uri} url The segment's location.
* @constructor
* @struct
*/
shaka.media.SegmentReference = function(
index, startTime, endTime, startByte, endByte, url) {
/**
* The segment's number, starting at 0, within the stream.
* @const {number}
*/
this.index = index;
/**
* The time, in seconds, that the segment begins.
* @const {number}
*/
this.startTime = startTime;
/**
* The time, in seconds, that the segment ends. The segment ends immediately
* before this time. A null value indicates that the segment continues to the
* end of the stream.
* @const {?number}
*/
this.endTime = endTime;
/**
* The position of the segment's first byte.
* @const {number}
*/
this.startByte = startByte;
/**
* The position of the segment's last byte, inclusive. A null value indicates
* that the segment continues to the end of the file located at |url|.
* @const {?number}
*/
this.endByte = endByte;
/**
* The segment's location.
* @const {!goog.Uri}
*/
this.url = url;
};