001    //$HeadURL: svn+ssh://jwilden@svn.wald.intevation.org/deegree/base/branches/2.5_testing/src/org/deegree/ogcwebservices/wms/capabilities/Attribution.java $
002    /*----------------------------------------------------------------------------
003     This file is part of deegree, http://deegree.org/
004     Copyright (C) 2001-2009 by:
005       Department of Geography, University of Bonn
006     and
007       lat/lon GmbH
008    
009     This library is free software; you can redistribute it and/or modify it under
010     the terms of the GNU Lesser General Public License as published by the Free
011     Software Foundation; either version 2.1 of the License, or (at your option)
012     any later version.
013     This library is distributed in the hope that it will be useful, but WITHOUT
014     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
015     FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
016     details.
017     You should have received a copy of the GNU Lesser General Public License
018     along with this library; if not, write to the Free Software Foundation, Inc.,
019     59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
020    
021     Contact information:
022    
023     lat/lon GmbH
024     Aennchenstr. 19, 53177 Bonn
025     Germany
026     http://lat-lon.de/
027    
028     Department of Geography, University of Bonn
029     Prof. Dr. Klaus Greve
030     Postfach 1147, 53001 Bonn
031     Germany
032     http://www.geographie.uni-bonn.de/deegree/
033    
034     e-mail: info@deegree.org
035    ----------------------------------------------------------------------------*/
036    package org.deegree.ogcwebservices.wms.capabilities;
037    
038    import java.net.URL;
039    
040    /**
041     * The optional Attribution element provides a way to identify the source of the map data used in a
042     * Layer or collection of Layers. Attribution encloses several optional elements: <OnlineResource>
043     * states the data provider's URL; <Title> is a human-readable string naming the data provider;
044     * <LogoURL> is the URL of a logo image. Client applications may choose to display one or more of
045     * these items. A <Format> element in LogoURL indicates the MIME type of the logo image, and the
046     * attributes width and height state the size of the image in pixels.
047     *
048     * <p>
049     * ----------------------------------------------------------------------
050     * </p>
051     *
052     * @author <a href="mailto:k.lupp@web.de">Katharina Lupp</a>
053     * @author <a href="mailto:mschneider@lat-lon.de">Markus Schneider</a>
054     * @version $Revision: 18195 $
055     */
056    public class Attribution {
057        private LogoURL logoURL = null;
058    
059        private String title = null;
060    
061        private URL onlineResource = null;
062    
063        /**
064         * constructor initializing the class with the attributes
065         *
066         * @param title
067         * @param onlineResource
068         * @param logoURL
069         */
070        public Attribution( String title, URL onlineResource, LogoURL logoURL ) {
071            setTitle( title );
072            setOnlineResource( onlineResource );
073            setLogoURL( logoURL );
074        }
075    
076        /**
077         * @return a human-readable string naming the data providerreturns the title of the attribution.
078         */
079        public String getTitle() {
080            return title;
081        }
082    
083        /**
084         * sets the title
085         *
086         * @param title
087         */
088        public void setTitle( String title ) {
089            this.title = title;
090        }
091    
092        /**
093         * @return the data provider's URL
094         */
095        public URL getOnlineResource() {
096            return onlineResource;
097        }
098    
099        /**
100         * sets the data provider's URL
101         *
102         * @param onlineResource
103         */
104        public void setOnlineResource( URL onlineResource ) {
105            this.onlineResource = onlineResource;
106        }
107    
108        /**
109         * @return the URL of a logo image
110         */
111        public LogoURL getLogoURL() {
112            return logoURL;
113        }
114    
115        /**
116         * sets the URL of a logo image
117         *
118         * @param logoURL
119         */
120        public void setLogoURL( LogoURL logoURL ) {
121            this.logoURL = logoURL;
122        }
123    
124        @Override
125        public String toString() {
126            String ret = null;
127            ret = "title = " + title + "\n";
128            ret += ( "onlineResource = " + onlineResource + "\n" );
129            ret += ( "logoURL = " + logoURL + "\n" );
130            return ret;
131        }
132    
133    }