All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.wicketstuff.html5.media.webvtt.VttCue Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.
 */
package org.wicketstuff.html5.media.webvtt;

/**
 * A cue block containing the translations
*
* Base on the browser cues can be styled with CSS. So you only have to include a CSS file into the * HTML page the video is embedded.
*
* Further information:
* http://tiffanybbrown.com/2013/12/14/subtitles-and-captions-with-webvtt/ * * * @author Tobias Soloschenko * */ public class VttCue { public enum Vertical { lr("lr"), rl("rl"); private String verticalName; Vertical(String verticalName) { this.verticalName = verticalName; } public String getVerticalName() { return verticalName; } public void setVerticalName(String verticalName) { this.verticalName = verticalName; } } public enum Alignment { start, middle, end } private String cueId; private String line; private String position; private String size; private Alignment alignment; private Vertical vertical; private VttTime startTime; private VttTime stopTime; private String text; private String voiceSpan; private VttRegion vttRegion; private String note; /** * Creates a cue with the required arguments * * @param cueId * the id of the cue * @param startTime * the start time of the cue * @param stopTime * the end time of the cue * @param text * the text of the cue */ public VttCue(String cueId, VttTime startTime, VttTime stopTime, String text) { this.cueId = cueId; this.startTime = startTime; this.stopTime = stopTime; this.text = text; } /** * Gets the position the text will appear vertically * * @return the position the text will appear vertically */ public String getLine() { return line; } /** * Sets the position the text will appear vertically (number, percentage e.g. 20% or 10) * * @param line * the position the text will appear vertically * @return the cue to perform further operations */ public VttCue setLine(String line) { this.line = line; return this; } /** * Gets the position of the text * * @return the position of the text */ public String getPosition() { return position; } /** * Sets the position the text will appear horizontally (percentage e.g. 20%) * * @param position * the position of the text * @return the cue to perform further operations */ public VttCue setPosition(String position) { this.position = position; return this; } /** * Gets the size (width of the text area) * * @return the size (width of the text area) */ public String getSize() { return size; } /** * Sets the size (width of the text area) * * @param size * the size of the text area (percentage e.g. 40%) * @return the cue to perform further operations */ public VttCue setSize(String size) { this.size = size; return this; } /** * Gets the alignment of the text * * @return the alignment of the text */ public Alignment getAlignment() { return alignment; } /** * Sets the alignment of the text * * @param alignment * the alignment of the text * @return the cue to perform further operations */ public VttCue setAlignment(Alignment alignment) { this.alignment = alignment; return this; } /** * Gets the vertical behavior * * @return the vertical behavior */ public Vertical getVertical() { return vertical; } /** * Sets the text to be displayed vertically rather than horizontally, such as in some Asian * languages * * @param vertical * the vertical behavior * @return the cue to perform further operations */ public VttCue setVertical(Vertical vertical) { this.vertical = vertical; return this; } /** * Gets the voice span applied to the cue * * @return the voice span applied to the cue */ public String getVoiceSpan() { return voiceSpan; } /** * Sets a voice span applied to the cue * * @param voiceSpan * the voice span applied to the cue * @return the cue to perform further operations */ public VttCue setVoiceSpan(String voiceSpan) { this.voiceSpan = voiceSpan; return this; } /** * Gets the region applied to the cue * * @return the region applied to the cue */ public VttRegion getRegion() { return vttRegion; } /** * Sets the region applied to the cue * * @param vttRegion * the region applied to the cue * @return the cue to perform further operations */ public VttCue setRegion(VttRegion vttRegion) { this.vttRegion = vttRegion; return this; } /** * Gets the note of the cue * * @return the note of the cue */ public String getNote() { return note; } /** * Sets the note of the cue * * @param note * the note to be set to the cue * @return the cue to perform further operations */ public VttCue setNote(String note) { this.note = note; return this; } /** * Gets the cue id * * @return the cue id */ public String getCueId() { return cueId; } /** * Gets the start time * * @return the start time */ public VttTime getStartTime() { return startTime; } /** * Gets the stop time * * @return the stop time */ public VttTime getStopTime() { return stopTime; } /** * Gets the text content * * @return the content as String */ public String getText() { return text; } /** * Gets the representation as builder * * @return thre representation as builder */ public StringBuilder getRepresentation() { StringBuilder builder = new StringBuilder(1000); builder.append(getCueId().replaceAll("\n", " ")); builder.append("\n"); builder.append(getStartTime().getRepresentation()); builder.append(" --> "); builder.append(getStopTime().getRepresentation()); if (getRegion() != null) { builder.append(" region:"); builder.append(getRegion().getId()); } if (getAlignment() != null) { builder.append(" align:"); builder.append(getAlignment().name()); } if (getVertical() != null) { builder.append(" vertical:"); builder.append(getVertical().getVerticalName()); } if (getSize() != null) { builder.append(" size:"); builder.append(getSize()); } if (getLine() != null) { builder.append(" line:"); builder.append(getLine()); } if (getPosition() != null) { builder.append(" position:"); builder.append(getPosition()); } builder.append("\n"); if (getVoiceSpan() != null || getRegion() != null) { builder.append(""); } builder.append(getText()); return builder; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy