/*******************************************************************************
* Copyright (c) MOBAC developers
*
* This program 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 2 of the License, or
* (at your option) any later version.
*
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
******************************************************************************/
package mobac.gui.mapview.layer;
import java.awt.Color;
import java.awt.Graphics2D;
import java.awt.Point;
import java.awt.geom.AffineTransform;
import mobac.gui.mapview.JMapViewer;
import mobac.gui.mapview.PreviewMap;
import mobac.gui.mapview.controller.RectangleSelectionMapController;
import mobac.gui.mapview.interfaces.MapLayer;
import mobac.program.interfaces.MapSpace;
/**
* Displays a polygon on the map - only for testing purposes
*/
public class RectangleSelectionLayer implements MapLayer {
private final RectangleSelectionMapController mapController;
public RectangleSelectionLayer(RectangleSelectionMapController rectangleSelectionMapController) {
this.mapController = rectangleSelectionMapController;
}
public void paint(JMapViewer map, Graphics2D g, int zoom, int minX, int minY, int maxX, int maxY) {
MapSpace mapSpace = map.getMapSource().getMapSpace();
g.setColor(Color.BLUE);
Point p1 = mapController.getiStartSelectionPoint();
Point p2 = mapController.getiEndSelectionPoint();
if (p1 == null || p2 == null)
return;
p1 = mapSpace.changeZoom(p1, PreviewMap.MAX_ZOOM, zoom);
p2 = mapSpace.changeZoom(p2, PreviewMap.MAX_ZOOM, zoom);
int x = Math.min(p1.x, p2.x);
int y = Math.min(p1.y, p2.y);
int w = Math.abs(p1.x - p2.x);
int h = Math.abs(p1.y - p2.y);
AffineTransform at = g.getTransform();
try {
g.translate(-minX, -minY);
g.drawRect(x, y, w, h);
} finally {
g.setTransform(at);
}
}
}