Java tutorial
/* * Copyright 2006 Marc Wick, geonames.org * * Licensed 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.rometools.feed.module.georss; import java.util.Collections; import java.util.HashSet; import java.util.Set; import org.jdom2.Element; import com.sun.syndication.feed.module.Module; import com.sun.syndication.io.ModuleGenerator; import org.rometools.feed.module.georss.geometries.*; /** * SimpleGenerator produces georss elements in georss simple format. * * @author Marc Wick * @version $Id: SimpleGenerator.java,v 1.4 2007/04/18 09:59:29 marcwick Exp $ * */ public class SimpleGenerator implements ModuleGenerator { private static final Set NAMESPACES; static { Set nss = new HashSet(); nss.add(GeoRSSModule.SIMPLE_NS); NAMESPACES = Collections.unmodifiableSet(nss); } private String posListToString(PositionList posList) { StringBuffer sb = new StringBuffer(); for (int i = 0; i < posList.size(); ++i) sb.append(posList.getLatitude(i)).append(" ").append(posList.getLongitude(i)).append(" "); return sb.toString(); } /* * (non-Javadoc) * * @see com.sun.syndication.io.ModuleGenerator#getNamespaceUri() */ public String getNamespaceUri() { return GeoRSSModule.GEORSS_GEORSS_URI; } /* * (non-Javadoc) * * @see com.sun.syndication.io.ModuleGenerator#getNamespaces() */ public Set getNamespaces() { return NAMESPACES; } /* * (non-Javadoc) * * @see com.sun.syndication.io.ModuleGenerator#generate(com.sun.syndication.feed.module.Module, * org.jdom2.Element) */ public void generate(Module module, Element element) { // this is not necessary, it is done to avoid the namespace definition // in every item. Element root = element; while (root.getParent() != null && root.getParent() instanceof Element) { root = (Element) element.getParent(); } root.addNamespaceDeclaration(GeoRSSModule.SIMPLE_NS); GeoRSSModule geoRSSModule = (GeoRSSModule) module; AbstractGeometry geometry = geoRSSModule.getGeometry(); if (geometry instanceof Point) { Position pos = ((Point) geometry).getPosition(); Element pointElement = new Element("point", GeoRSSModule.SIMPLE_NS); pointElement.addContent(pos.getLatitude() + " " + pos.getLongitude()); element.addContent(pointElement); } else if (geometry instanceof LineString) { PositionList posList = ((LineString) geometry).getPositionList(); Element lineElement = new Element("line", GeoRSSModule.SIMPLE_NS); lineElement.addContent(posListToString(posList)); element.addContent(lineElement); } else if (geometry instanceof Polygon) { AbstractRing ring = ((Polygon) geometry).getExterior(); if (ring instanceof LinearRing) { PositionList posList = ((LinearRing) ring).getPositionList(); Element polygonElement = new Element("polygon", GeoRSSModule.SIMPLE_NS); polygonElement.addContent(posListToString(posList)); element.addContent(polygonElement); } else { System.err.println("GeoRSS simple format can't handle rings of type: " + ring.getClass().getName()); } if (((Polygon) geometry).getInterior() != null || !((Polygon) geometry).getInterior().isEmpty()) { System.err.println("GeoRSS simple format can't handle interior rings (ignored)"); } } else if (geometry instanceof Envelope) { Envelope envelope = (Envelope) geometry; Element boxElement = new Element("box", GeoRSSModule.SIMPLE_NS); boxElement.addContent(envelope.getMinLatitude() + " " + envelope.getMinLongitude() + " " + envelope.getMaxLatitude() + " " + envelope.getMaxLongitude()); element.addContent(boxElement); } else { System.err.println( "GeoRSS simple format can't handle geometries of type: " + geometry.getClass().getName()); } } }