001    //$HeadURL: $
002    /*----------------    FILE HEADER  ------------------------------------------
003     This file is part of deegree.
004     Copyright (C) 2001-2008 by:
005     Department of Geography, University of Bonn
006     http://www.giub.uni-bonn.de/deegree/
007     lat/lon GmbH
008     http://www.lat-lon.de
009    
010     This library is free software; you can redistribute it and/or
011     modify it under the terms of the GNU Lesser General Public
012     License as published by the Free Software Foundation; either
013     version 2.1 of the License, or (at your option) any later version.
014     This library is distributed in the hope that it will be useful,
015     but WITHOUT ANY WARRANTY; without even the implied warranty of
016     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
017     Lesser General Public License for more details.
018     You should have received a copy of the GNU Lesser General Public
019     License along with this library; if not, write to the Free Software
020     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
021     Contact:
022    
023     Andreas Poth
024     lat/lon GmbH
025     Aennchenstr. 19
026     53177 Bonn
027     Germany
028     E-Mail: poth@lat-lon.de
029    
030     Prof. Dr. Klaus Greve
031     Department of Geography
032     University of Bonn
033     Meckenheimer Allee 166
034     53115 Bonn
035     Germany
036     E-Mail: greve@giub.uni-bonn.de
037     ---------------------------------------------------------------------------*/
038    
039    
040    package org.deegree.tools.app3d;
041    
042    import javax.media.j3d.Group;
043    
044    /**
045     * The <code>J3DExporter</code> Inteface allows for easy access to some common the export methods.
046     *
047     * @author <a href="mailto:bezema@lat-lon.de">Rutger Bezema</a>
048     *
049     * @author last edited by: $Author:$
050     *
051     * @version $Revision:$, $Date:$
052     *
053     */
054    
055    public interface J3DExporter {
056        
057        
058        /**
059         * A method which can be called to export to the given format.
060         * @param result a reference to which the implementing class should write.
061         * @param j3dScene the scene to be exported.
062         */
063        public void export( StringBuilder result, Group j3dScene );
064        
065        /**
066         * @return A Name which can be presented to a calling client;
067         */
068        public String getName( );
069        
070        
071        /**
072         * @return a simple description which can describes the function of the implementing class.
073         */
074        public String getShortDescription();
075        
076    
077    }
078