import java.awt.* import java.awt.image.* import javax.imageio.* import org.geotools.data.shapefile.* import org.geotools.factory.* import org.geotools.filter.* import org.geotools.map.* import org.geotools.renderer.lite.* import org.geotools.styling.* url = new URL("file://C:/share/geotools/world.shp") shapefile = new ShapefileDataStore(url) fs = shapefile.getFeatureSource() schema = fs.getSchema() crs = schema.getGeometryDescriptor().getCoordinateReferenceSystem() map = new DefaultMapContext([] as MapLayer[], crs) // スタイルを作成 ff = FilterFactoryFinder.createFilterFactory() sf = CommonFactoryFinder.getStyleFactory() // ポリゴンの線の色 stroke = sf.createStroke( ff.literal(new Color(47, 184, 27)), ff.literal(1) ) // ポリゴンの塗りつぶし色 fill = sf.createFill( ff.literal(new Color(133, 255, 7)) ) sym = sf.createPolygonSymbolizer(stroke, fill, null) rule = sf.createRule() rule.symbolizers().add(sym) fts = sf.createFeatureTypeStyle([rule] as Rule[]) style = sf.createStyle() style.featureTypeStyles().add(fts) map.addLayer(new FeatureLayer(fs, style)) // レンダリング renderer = new StreamingRenderer() renderer.setContext(map) width = 400 bounds = map.getMaxBounds() rect = new Rectangle(0, 0, width, (int)(width * bounds.getHeight() / bounds.getWidth())) image = new BufferedImage((int)rect.width, (int)rect.height, BufferedImage.TYPE_INT_RGB) gr = image.createGraphics() gr.setPaint(Color.WHITE) gr.fill(rect) renderer.paint(gr, rect, bounds) ImageIO.write(image, "jpeg", new File("polygon.jpg"))出力画像
※世界地図のシェイプファイルは以下からダウンロード
World map for APRS
http://aprsworld.net/gisdata/world/
※.groovy/libからGROOVY_HOME/libにgeotools-2.7.3-bin.zipに
含まれるjarをコピーする
動作環境
groovy 1.8.2, JDK6 Update27, GeoTools 2.7.3
関連情報
・GeoToolsのウェブサイト
http://geotools.org/