org.mapfish.print.map.renderers.BitmapTileRenderer.java Source code

Java tutorial

Introduction

Here is the source code for org.mapfish.print.map.renderers.BitmapTileRenderer.java

Source

/*
 * Copyright (C) 2013  Camptocamp
 *
 * This file is part of MapFish Print
 *
 * MapFish Print 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 3 of the License, or
 * (at your option) any later version.
 *
 * MapFish Print 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 MapFish Print.  If not, see <http://www.gnu.org/licenses/>.
 */

package org.mapfish.print.map.renderers;

import java.awt.geom.AffineTransform;
import java.awt.geom.Point2D;
import java.io.IOException;
import java.net.URI;
import java.util.List;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.mapfish.print.PDFUtils;
import org.mapfish.print.RenderingContext;
import org.mapfish.print.Transformer;
import org.mapfish.print.map.MapTileTask;
import org.mapfish.print.map.ParallelMapTileLoader;

import com.lowagie.text.DocumentException;
import com.lowagie.text.Image;
import com.lowagie.text.pdf.PdfContentByte;
import com.lowagie.text.pdf.PdfGState;
import com.vividsolutions.jts.geom.Coordinate;
import com.vividsolutions.jts.geom.GeometryFactory;
import com.vividsolutions.jts.geom.Polygon;

public class BitmapTileRenderer extends TileRenderer {
    private static final Log LOGGER = LogFactory.getLog(BitmapTileRenderer.class);

    public void render(Transformer transformer, List<URI> uris, ParallelMapTileLoader parallelMapTileLoader,
            final RenderingContext context, final float opacity, int nbTilesHorizontal, double offsetX,
            double offsetY, final long bitmapTileW, final long bitmapTileH) throws IOException {
        final AffineTransform bitmapTransformer = transformer.getBitmapTransform();
        final double rotation = transformer.getRotation();

        for (int i = 0; i < uris.size(); i++) {
            final URI uri = uris.get(i);
            if (uri == null) {
                continue;
            }

            final int line = i / nbTilesHorizontal;
            final int col = i % nbTilesHorizontal;
            final double posX = 0 - offsetX + col * bitmapTileW;
            final double posY = 0 - offsetY + line * bitmapTileH;

            if (rotation != 0.0
                    && !isTileVisible(posX, posY, bitmapTileW, bitmapTileH, bitmapTransformer, transformer)) {
                if (LOGGER.isDebugEnabled()) {
                    LOGGER.debug("Not needed: " + uri);
                }
                continue;
            }

            parallelMapTileLoader.addTileToLoad(new MapTileTask() {
                public Image map;

                protected void readTile() throws IOException, DocumentException {
                    map = PDFUtils.getImage(context, uri, bitmapTileW, bitmapTileH);
                    map.setAbsolutePosition((float) posX, (float) posY);
                }

                protected void renderOnPdf(PdfContentByte dc) throws DocumentException {
                    dc.transform(bitmapTransformer);
                    if (opacity < 1.0) {
                        PdfGState gs = new PdfGState();
                        gs.setFillOpacity(opacity);
                        gs.setStrokeOpacity(opacity);
                        dc.setGState(gs);
                    }
                    dc.addImage(map);
                }
            });
        }
    }

    private boolean isTileVisible(double x, double y, long w, long h, AffineTransform bitmapTransformer,
            Transformer transformer) {
        GeometryFactory gf = new GeometryFactory();
        Polygon page = gf.createPolygon(gf.createLinearRing(new Coordinate[] {
                new Coordinate(transformer.getPaperPosX(), transformer.getPaperPosY()),
                new Coordinate(transformer.getPaperPosX() + transformer.getPaperW(), transformer.getPaperPosY()),
                new Coordinate(transformer.getPaperPosX() + transformer.getPaperW(),
                        transformer.getPaperPosY() + transformer.getPaperH()),
                new Coordinate(transformer.getPaperPosX(), transformer.getPaperPosY() + transformer.getPaperH()),
                new Coordinate(transformer.getPaperPosX(), transformer.getPaperPosY()), }), null);

        Point2D.Float ll = new Point2D.Float();
        Point2D.Float lr = new Point2D.Float();
        Point2D.Float ur = new Point2D.Float();
        Point2D.Float ul = new Point2D.Float();
        bitmapTransformer.transform(new Point2D.Float((float) x, (float) y), ll);
        bitmapTransformer.transform(new Point2D.Float((float) x + w, (float) y), lr);
        bitmapTransformer.transform(new Point2D.Float((float) x + w, (float) y + h), ur);
        bitmapTransformer.transform(new Point2D.Float((float) x, (float) y + h), ul);
        Polygon tile = gf
                .createPolygon(
                        gf.createLinearRing(new Coordinate[] { new Coordinate(ll.getX(), ll.getY()),
                                new Coordinate(lr.getX(), lr.getY()), new Coordinate(ur.getX(), ur.getY()),
                                new Coordinate(ul.getX(), ul.getY()), new Coordinate(ll.getX(), ll.getY()), }),
                        null);

        return page.intersects(tile);
    }
}