⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 eaf20.java

📁 编辑视频文件
💻 JAVA
字号:
/* * File:     EAF20.java * Project:  MPI Linguistic Application * Date:     02 May 2007 * * Copyright (C) 2001-2007  Max Planck Institute for Psycholinguistics * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */package mpi.eudico.server.corpora.clomimpl.dobes;import org.w3c.dom.Document;import org.w3c.dom.Element;import org.w3c.dom.Node;/**   <p>   You can call this class a factory: it instantiates a DOM object.   You can also call it an API for a specific DOM object.   <p>   You explicitely have to add the ANNOTATION_DOCUMENT to the EAF DOM:   <code>   Element e = newAnnotationDocument(new Date()+"", "gregor", "version 1.0");   daf.appendChild(e);   </code>   <p>   To write the DOM to file, use   getDocumentElement(), which returns all including Elements.   <code>   System.out.println("<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?>");   System.out.println("<!DOCTYPE Trans SYSTEM \"EAFv2.0.dtd\">");   System.out.println(""+daf.getDocumentElement());   </code>   The arguments of the newELEMENT() methods must not be null, if not otheriwse   stated. A RuntimeException will be thrown if an argument is null.   This is much better than to silently write incomplete data.*/import java.util.Date;import java.util.Locale;import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory;/** * DOCUMENT ME! * $Id: jalopy_gnu_src_dist.xml,v 1.3 2007/02/06 13:30:33 hasloe Exp $ * @author $Author: hasloe $ * @version $Revision: 1.3 $ */public class EAF20 {    /**        Three Time Units     */    public final static String TIME_UNIT_MILLISEC = "milliseconds";    /** Holds value of property DOCUMENT ME! */    public final static String TIME_UNIT_NTSC = "NTSC-frames";    /** Holds value of property DOCUMENT ME! */    public final static String TIME_UNIT_PAL = "PAL-frames";    /**       The DOM document variable doc is a private,       all newELEMENT method calls will modify it.     */    private Document doc;    /**       Remember to append a ANNOTATION_DOCUMENT Element to the doc variable using       appendChild();    */    public EAF20() throws Exception {        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();        DocumentBuilder db = dbf.newDocumentBuilder();        this.doc = db.newDocument();    }    /**       Testing the class.     */    public EAF20(boolean test) throws Exception {        this();        //test...        Element e = newAnnotationDocument(new Date() + "", "gregor",                "version 2.0");        appendChild(e);        System.out.println("" + getDocumentElement());    }    /**       EAF is per se a subtype of org.w3c.dom.Document.       It is not inheriting from Document, because only two methods have to be       supported.     */    /** see org.w3c.dom.Element.getDocumentElement() */    public final Element getDocumentElement() {        return this.doc.getDocumentElement();    }    /** see org.w3c.dom.Element.appendChild() */    public final Node appendChild(Node e) {        return this.doc.appendChild(e);    }    /**       All methods "newELEMENT()" are returning an obkect of type org.w3c.dom.Element       with name ELEMENT.       Technically speaking, they encapsulate       the two methods Element.setAttribute() and Element.createTextNode() and do some       housekeeping.    */    /**       Use result in <your daf variable>.appendChild();       @return a new Element ANNOTATION_DOCUMENT.       @param creationDate Creation date of this annotation       @param author Author of this annotation.       @param version --->documentation missing<---     */    public final Element newAnnotationDocument(String creationDate,        String author, String version) {        if (creationDate == null) {            throw new RuntimeException("EAF");        }        if (author == null) {            throw new RuntimeException("EAF");        }        if (version == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("ANNOTATION_DOCUMENT");        result.setAttribute("xsi:noNamespaceSchemaLocation",            "http://www.mpi.nl/tools/elan/EAFv2.0.xsd");        result.setAttribute("DATE", creationDate);        result.setAttribute("AUTHOR", author);        result.setAttribute("VERSION", version);        result.setAttribute("FORMAT", "2.0");        return result;    }    /**       Use result in annotationDocument.appendChild();       @return a new Element HEADER.       @param mediaFile --->documentation missing<---       @param timeUnits --->documentation missing<---     */    public final Element newHeader(String mediaFile, String timeUnits) {        if (mediaFile == null) {            throw new RuntimeException("EAF");        }        if (timeUnits == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("HEADER");        result.setAttribute("MEDIA_FILE", mediaFile);        result.setAttribute("TIME_UNITS", timeUnits);        return result;    }    /**       @return a new Element HEADER with a default time unit of milliseconds.       @param mediaFile same meaning as above     */    public final Element newHeader(String mediaFile) {        if (mediaFile == null) {            throw new RuntimeException("EAF");        }        return newHeader(mediaFile, EAF20.TIME_UNIT_MILLISEC);    }    /**       Use result in annotationDocument.appendChild();       @return a new Element TIME_ORDER.     */    public final Element newTimeOrder() {        Element result = this.doc.createElement("TIME_ORDER");        return result;    }    /**       Use result in time_order.appendChild();       @return a new Element TIME_SLOT with a time       @param id   --->documentation missing<---       @param time a time slot has a precise time. NULLABLE     */    public final Element newTimeSlot(String id, long time) {        if (id == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("TIME_SLOT");        result.setAttribute("TIME_SLOT_ID", id);        result.setAttribute("TIME_VALUE", time + "");        return result;    }    /**       Use result in time_order.appendChild();       @return a new Element TIME_SLOT without time.       @param id   --->documentation missing<---       (Java remark: long is not an object and therfore cannot be null.)     */    public final Element newTimeSlot(String id) {        if (id == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("TIME_SLOT");        result.setAttribute("TIME_SLOT_ID", id);        return result;    }    /**       Use result in annotationDocument.appendChild();       @return a new Element TIER.       @param id   --->documentation missing<---       @param time --->documentation missing<---       @param participant --->documentation missing<--- NULLABLE       @param typeRef --->documentation missing<---       @param language --->documentation missing<---       @param parent --->documentation missing<--- NULLABLE     */    public final Element newTier(String id, String participant, String typeRef,        Locale language, String parent) {        if (id == null) {            throw new RuntimeException("EAF");        }        if (typeRef == null) {            throw new RuntimeException("EAF");        }        if (language == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("TIER");        result.setAttribute("TIER_ID", id);        if (participant != null) {            result.setAttribute("PARTICIPANT", participant);        }        result.setAttribute("LINGUISTIC_TYPE_REF", typeRef);        result.setAttribute("DEFAULT_LOCALE", language.getLanguage());        if (parent != null) {            result.setAttribute("PARENT_REF", parent);        }        return result;    }    /**       Use result in tier.appendChild();       @return a new Element ANNOTATION.     */    public final Element newAnnotation() {        Element result = this.doc.createElement("ANNOTATION");        return result;    }    /**       Use result in annotation.appendChild();       @return a new Element ALIGNABLE_ANNOTATION.       @param id   --->documentation missing<---       @param beginTimeSlot --->documentation missing<---       @param endTimeSlot --->documentation missing<---     */    public final Element newAlignableAnnotation(String id,        String beginTimeSlot, String endTimeSlot) {        if (id == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("ALIGNABLE_ANNOTATION");        result.setAttribute("ANNOTATION_ID", id);        result.setAttribute("TIME_SLOT_REF1", beginTimeSlot);        result.setAttribute("TIME_SLOT_REF2", endTimeSlot);        return result;    }    /**       Use result in annotation.appendChild();       @return a new Element REF_ANNOTATION.       @param id   --->documentation missing<---       @param annotationRef --->documentation missing<---     */    public final Element newRefAnnotation(String id, String annotationRef,        String previousAnnotation) {        if (id == null) {            throw new RuntimeException("EAF");        }        if (annotationRef == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("REF_ANNOTATION");        result.setAttribute("ANNOTATION_ID", id);        result.setAttribute("ANNOTATION_REF", annotationRef);        if (previousAnnotation != null) {            result.setAttribute("PREVIOUS_ANNOTATION", previousAnnotation);        }        return result;    }    /**       Use result in refAnnotation.appendChild();       @return a new Element ANNOTATION_VALUE.       @param value   --->documentation missing<---     */    public final Element newAnnotationValue(String value) {        if (value == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("ANNOTATION_VALUE");        result.appendChild(doc.createTextNode(value));        return result;    }    /**       Use result in annotationDocument.appendChild();       @return a new Element LINGUISTIC_TYPE.       @param id   --->documentation missing<---     */    public final Element newLinguisticType(String id, boolean timeAlignable,        boolean graphicReferences, String constraint) {        if (id == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("LINGUISTIC_TYPE");        result.setAttribute("LINGUISTIC_TYPE_ID", id);        result.setAttribute("TIME_ALIGNABLE", timeAlignable ? "true" : "false");        result.setAttribute("GRAPHIC_REFERENCES",            graphicReferences ? "true" : "false");        if (constraint != null) {            result.setAttribute("CONSTRAINTS", constraint);        }        return result;    }    /**     * Use result in annotationDocument.appendChild();     * @return a new Element CONSTRAINT     */    public final Element newConstraint(String stereotype, String description) {        if (stereotype == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("CONSTRAINT");        result.setAttribute("STEREOTYPE", stereotype);        if (description != null) {            result.setAttribute("DESCRIPTION", description);        }        return result;    }    /**       Use result in annotationDocument.appendChild();       @return a new Element LOCALE.       @param locale   --->documentation missing<---     */    public final Element newLocale(Locale l) {        if (l == null) {            throw new RuntimeException("EAF");        }        Element result = this.doc.createElement("LOCALE");        result.setAttribute("LANGUAGE_CODE", l.getLanguage());        if (!l.getCountry().equals("")) {            result.setAttribute("COUNTRY_CODE", l.getCountry());        }        if (!l.getVariant().equals("")) {            result.setAttribute("VARIANT", l.getVariant());        }        return result;    }    /**       For Testing.    */    public static void main(String[] a) throws Exception {        new EAF20(true);    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -