/*******************************************************************************
* Breakout Cave Survey Visualizer
*
* Copyright (C) 2014 James Edwards
*
* jedwards8 at fastmail dot fm
*
* 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, write to the Free Software Foundation, Inc., 51
* Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*******************************************************************************/
package com.andork.plot;
import java.awt.Color;
import java.awt.Graphics2D;
import java.awt.Paint;
import java.awt.Rectangle;
import java.awt.RenderingHints;
import com.andork.plot.PlotAxis.Orientation;
public class HorizontalGridLineLayer implements IPlotLayer {
private LinearAxisConversion axisConversion = new LinearAxisConversion();
private int minMinorGridLineSpacing = 30;
public HorizontalGridLineLayer() {
}
public HorizontalGridLineLayer(PlotAxis axis) {
if (axis.getOrientation() != Orientation.VERTICAL) {
throw new IllegalArgumentException("axis must be VERTICAL");
}
axisConversion = axis.getAxisConversion();
}
public LinearAxisConversion getAxisConversion() {
return axisConversion;
}
public int getMinMinorGridLineSpacing() {
return minMinorGridLineSpacing;
}
@Override
public void render(Graphics2D g2, Rectangle bounds) {
Object prevAntialiasing = g2.getRenderingHint(RenderingHints.KEY_ANTIALIASING);
Paint prevPaint = g2.getPaint();
g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
double axisStart = axisConversion.invert(0);
double axisEnd = axisConversion.invert(bounds.height);
double minorHorizontalGridLineSpacing = GridMath
.niceCeiling(Math.abs(axisConversion.invert(minMinorGridLineSpacing) - axisStart));
double majorHorizontalGridLineSpacing = minorHorizontalGridLineSpacing * 2;
g2.setColor(Color.LIGHT_GRAY);
PlotUtils.drawHorizontalGridLines(g2, bounds, axisStart, axisEnd, minorHorizontalGridLineSpacing);
g2.setColor(Color.GRAY);
PlotUtils.drawHorizontalGridLines(g2, bounds, axisStart, axisEnd, majorHorizontalGridLineSpacing);
g2.setPaint(prevPaint);
g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING, prevAntialiasing);
}
public void setAxisConversion(LinearAxisConversion axisConversion) {
if (axisConversion == null) {
throw new IllegalArgumentException("axisConversion must be non-null");
}
this.axisConversion = axisConversion;
}
public void setMinMinorGridLineSpacing(int minMinorGridLineSpacing) {
this.minMinorGridLineSpacing = minMinorGridLineSpacing;
}
}