1 /*
2 * Licensed to The Apereo Foundation under one or more contributor license
3 * agreements. See the NOTICE file distributed with this work for additional
4 * information regarding copyright ownership.
5 *
6 *
7 * The Apereo Foundation licenses this file to you under the Educational
8 * Community License, Version 2.0 (the "License"); you may not use this file
9 * except in compliance with the License. You may obtain a copy of the License
10 * at:
11 *
12 * http://opensource.org/licenses/ecl2.txt
13 *
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
16 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
17 * License for the specific language governing permissions and limitations under
18 * the License.
19 *
20 */
21
22
23 package org.opencastproject.metadata.mpeg7;
24
25 /**
26 * A video segment represents a temporal decomposition of the video stream that may have properties like text
27 * annotations attached to it.
28 *
29 * <pre>
30 * <complexType name="VideoSegmentType">
31 * <complexContent>
32 * <extension base="mpeg7:SegmentType">
33 * <sequence>
34 * <choice minOccurs="0">
35 * <element name="MediaTime" type="mpeg7:MediaTimeType"/>
36 * <element name="TemporalMask" type="mpeg7:TemporalMaskType"/>
37 * </choice>
38 * <choice minOccurs="0" maxOccurs="unbounded">
39 * <element name="VisualDescriptor" type="mpeg7:VisualDType"/>
40 * <element name="VisualDescriptionScheme" type="mpeg7:VisualDSType"/>
41 * <element name="VisualTimeSeriesDescriptor"
42 * type="mpeg7:VisualTimeSeriesType"/>
43 * </choice>
44 * <element name="MultipleView" type="mpeg7:MultipleViewType"
45 * minOccurs="0"/>
46 * <element name="Mosaic" type="mpeg7:MosaicType" minOccurs="0"
47 * maxOccurs="unbounded"/>
48 * <choice minOccurs="0" maxOccurs="unbounded">
49 * <element name="SpatialDecomposition"
50 * type="mpeg7:VideoSegmentSpatialDecompositionType"/>
51 * <element name="TemporalDecomposition"
52 * type="mpeg7:VideoSegmentTemporalDecompositionType"/>
53 * <element name="SpatioTemporalDecomposition"
54 * type="mpeg7:VideoSegmentSpatioTemporalDecompositionType"/>
55 * <element name="MediaSourceDecomposition"
56 * type="mpeg7:VideoSegmentMediaSourceDecompositionType"/>
57 * </choice>
58 * </sequence>
59 * </extension>
60 * </complexContent>
61 * </complexType>
62 * </pre>
63 */
64 public interface VideoSegment extends Segment {
65
66 /**
67 * Returns <code>true</code> if there is a spatio temporal decomposition as part of this segment.
68 *
69 * @return <code>true</code> if there is a spatio temporal decomposition
70 */
71 boolean hasSpatioTemporalDecomposition();
72
73 /**
74 * Creates a spatio temporal decomposition in this video segment.
75 *
76 * @param gap
77 * <code>true</code> if there may be gap between the elements
78 * @param overlap
79 * <code>true</code> if elements may overlap
80 * @return the new decomposition
81 * @throws IllegalStateException
82 * if there is already such a decomposition
83 */
84 SpatioTemporalDecomposition createSpatioTemporalDecomposition(boolean gap, boolean overlap)
85 throws IllegalStateException;
86
87 /**
88 * Returns the spatio temporal decomposition that contains information about elements on the segment such as text
89 * elements.
90 *
91 * @return the spatio temporal decomposition
92 */
93 SpatioTemporalDecomposition getSpatioTemporalDecomposition();
94
95 }