All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.codename1.charts.renderers.XYMultipleSeriesRenderer Maven / Gradle / Ivy

/**
 * Copyright (C) 2009 - 2013 SC 4ViewSoft SRL
 *  
 * 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 com.codename1.charts.renderers;

import com.codename1.ui.Component;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import com.codename1.charts.util.NumberFormat;
import com.codename1.charts.util.ColorUtil;
import com.codename1.charts.util.MathHelper;
import com.codename1.ui.Font;


/**
 * Multiple XY series renderer.
 */
public class XYMultipleSeriesRenderer extends DefaultRenderer {
  /** The X axis title. */
  private String mXTitle = "";
  /** The Y axis title. */
  private String[] mYTitle;
  /** The axis title text size. */
  private float mAxisTitleTextSize = 12;
  /** The start value in the X axis range. */
  private double[] mMinX;
  /** The end value in the X axis range. */
  private double[] mMaxX;
  /** The start value in the Y axis range. */
  private double[] mMinY;
  /** The end value in the Y axis range. */
  private double[] mMaxY;
  /** The approximative number of labels on the x axis. */
  private int mXLabels = 5;
  /** The approximative number of labels on the y axis. */
  private int mYLabels = 5;
  /** The current orientation of the chart. */
  private Orientation mOrientation = Orientation.HORIZONTAL;
  /** The X axis text labels. */
  private Map mXTextLabels = new HashMap();
  /** The Y axis text labels. */
  private Map> mYTextLabels = new LinkedHashMap>();
  /** A flag for enabling or not the pan on the X axis. */
  private boolean mPanXEnabled = true;
  /** A flag for enabling or not the pan on the Y axis. */
  private boolean mPanYEnabled = true;
  /** A flag for enabling or not the zoom on the X axis. */
  private boolean mZoomXEnabled = true;
  /** A flag for enabling or not the zoom on the Y axis . */
  private boolean mZoomYEnabled = true;
  /** The spacing between bars, in bar charts. */
  private double mBarSpacing = 0;
  /** The margins colors. */
  private int mMarginsColor = NO_COLOR;
  /** The pan limits. */
  private double[] mPanLimits;
  /** The zoom limits. */
  private double[] mZoomLimits;
  /** The X axis labels rotation angle. */
  private float mXLabelsAngle;
  /** The Y axis labels rotation angle. */
  private float mYLabelsAngle;
  /** The initial axis range. */
  private Map initialRange = new LinkedHashMap();
  /** The point size for charts displaying points. */
  private float mPointSize = 3;
  /** The grid color. */
  private int[] mGridColors;
  /** The number of scales. */
  private int scalesCount;
  /** The X axis labels alignment. */
  private int xLabelsAlign = Component.CENTER;
  /** The Y axis labels alignment. */
  private int[] yLabelsAlign;
  /** The X text label padding. */
  private float mXLabelsPadding = 0;
  /** The Y text label padding. */
  private float mYLabelsPadding = 0;
  /** The Y axis labels vertical padding. */
  private float mYLabelsVerticalPadding = 2;
  /** The Y axis alignment. */
  private int[] yAxisAlign;
  /** The X axis labels color. */
  private int mXLabelsColor = TEXT_COLOR;
  /** The Y axis labels color. */
  private int[] mYLabelsColor = new int[] { TEXT_COLOR };
  /**
   * If X axis value selection algorithm to be used. Only used by the time
   * charts.
   */
  private boolean mXRoundedLabels = true;
  /** The X label format. */
  private NumberFormat mXLabelFormat;
  /** The Y label format. */
  private NumberFormat[] mYLabelFormat;
  /** A constant value for the bar chart items width. */
  private float mBarWidth = -1;
  /** The zoom in limit permitted in the axis X */
  private double mZoomInLimitX = 0;
  /** The zoom in limit permitted in the axis Y */
  private double mZoomInLimitY = 0;

  /**
   * An enum for the XY chart orientation of the X axis.
   */
  public enum Orientation {
    HORIZONTAL(0), VERTICAL(90);
    /** The rotate angle. */
    private int mAngle = 0;

    private Orientation(int angle) {
      mAngle = angle;
    }

    /**
     * Return the orientation rotate angle.
     * 
     * @return the orientaion rotate angle
     */
    public int getAngle() {
      return mAngle;
    }
  }

  public XYMultipleSeriesRenderer() {
    this(1);
  }

  public XYMultipleSeriesRenderer(int scaleNumber) {
    scalesCount = scaleNumber;
    initAxesRange(scaleNumber);
  }

  public void initAxesRange(int scales) {
    mYTitle = new String[scales];
    yLabelsAlign = new int[scales];
    yAxisAlign = new int[scales];
    mYLabelsColor = new int[scales];
    mYLabelFormat = new NumberFormat[scales];
    mMinX = new double[scales];
    mMaxX = new double[scales];
    mMinY = new double[scales];
    mMaxY = new double[scales];
    mGridColors = new int[scales];
    for (int i = 0; i < scales; i++) {
      mYLabelsColor[i] = TEXT_COLOR;
      mYLabelFormat[i] = NumberFormat.getNumberInstance();
      mGridColors[i] = ColorUtil.argb(75, 200, 200, 200);
      initAxesRangeForScale(i);
    }
  }

  public void initAxesRangeForScale(int i) {
    mMinX[i] = MathHelper.NULL_VALUE;
    mMaxX[i] = MathHelper.NULL_VALUE;
    mMinY[i] = MathHelper.NULL_VALUE;
    mMaxY[i] = MathHelper.NULL_VALUE;
    double[] range = new double[] { mMinX[i], mMaxX[i], mMinY[i], mMaxY[i] };
    initialRange.put(i, range);
    mYTitle[i] = "";
    mYTextLabels.put(i, new HashMap());
    yLabelsAlign[i] = Component.CENTER;
    yAxisAlign[i] = Component.LEFT;
  }

  /**
   * Returns the current orientation of the chart X axis.
   * 
   * @return the chart orientation
   */
  public Orientation getOrientation() {
    return mOrientation;
  }

  /**
   * Sets the current orientation of the chart X axis.
   * 
   * @param orientation the chart orientation
   */
  public void setOrientation(Orientation orientation) {
    mOrientation = orientation;
  }

  /**
   * Returns the title for the X axis.
   * 
   * @return the X axis title
   */
  public String getXTitle() {
    return mXTitle;
  }

  /**
   * Sets the title for the X axis.
   * 
   * @param title the X axis title
   */
  public void setXTitle(String title) {
    mXTitle = title;
  }

  /**
   * Returns the title for the Y axis.
   * 
   * @return the Y axis title
   */
  public String getYTitle() {
    return getYTitle(0);
  }

  /**
   * Returns the title for the Y axis.
   * 
   * @param scale the renderer scale
   * @return the Y axis title
   */
  public String getYTitle(int scale) {
    return mYTitle[scale];
  }

  /**
   * Sets the title for the Y axis.
   * 
   * @param title the Y axis title
   */
  public void setYTitle(String title) {
    setYTitle(title, 0);
  }

  /**
   * Sets the title for the Y axis.
   * 
   * @param title the Y axis title
   * @param scale the renderer scale
   */
  public void setYTitle(String title, int scale) {
    mYTitle[scale] = title;
  }

  /**
   * Returns the axis title text size.
   * 
   * @return the axis title text size
   */
  public float getAxisTitleTextSize() {
    return mAxisTitleTextSize;
  }

  /**
   * Sets the axis title text size. Consider using  {@link #setAxisTitleTextFont(com.codename1.ui.Font) }
   * instead to allow the font size to to be adjusted appropriately for the display
   * resolution.
   * 
   * @param textSize the chart axis text size
   */
  public void setAxisTitleTextSize(float textSize) {
    mAxisTitleTextSize = textSize;
  }
  
  
  /**
   * Sets the Axis title text font size using a Font object instead of a point size.
   * This method is the preferred way to set font size because it allows you to 
   * more easily have fonts appear in an appropriate size for the target device.
   * 
   * Alternatively check out {@link #setAxisTitleTextSize(float) } to set the text
   * size in pixels.
   * @param font 
   */
  public void setAxisTitleTextFont(Font font){
      setAxisTitleTextSize(font.getHeight());
  }

  /**
   * Returns the start value of the X axis range.
   * 
   * @return the X axis range start value
   */
  public double getXAxisMin() {
    return getXAxisMin(0);
  }

  /**
   * Sets the start value of the X axis range.
   * 
   * @param min the X axis range start value
   */
  public void setXAxisMin(double min) {
    setXAxisMin(min, 0);
  }

  /**
   * Returns if the minimum X value was set.
   * 
   * @return the minX was set or not
   */
  public boolean isMinXSet() {
    return isMinXSet(0);
  }

  /**
   * Returns the end value of the X axis range.
   * 
   * @return the X axis range end value
   */
  public double getXAxisMax() {
    return getXAxisMax(0);
  }

  /**
   * Sets the end value of the X axis range.
   * 
   * @param max the X axis range end value
   */
  public void setXAxisMax(double max) {
    setXAxisMax(max, 0);
  }

  /**
   * Returns if the maximum X value was set.
   * 
   * @return the maxX was set or not
   */
  public boolean isMaxXSet() {
    return isMaxXSet(0);
  }

  /**
   * Returns the start value of the Y axis range.
   * 
   * @return the Y axis range end value
   */
  public double getYAxisMin() {
    return getYAxisMin(0);
  }

  /**
   * Sets the start value of the Y axis range.
   * 
   * @param min the Y axis range start value
   */
  public void setYAxisMin(double min) {
    setYAxisMin(min, 0);
  }

  /**
   * Returns if the minimum Y value was set.
   * 
   * @return the minY was set or not
   */
  public boolean isMinYSet() {
    return isMinYSet(0);
  }

  /**
   * Returns the end value of the Y axis range.
   * 
   * @return the Y axis range end value
   */
  public double getYAxisMax() {
    return getYAxisMax(0);
  }

  /**
   * Sets the end value of the Y axis range.
   * 
   * @param max the Y axis range end value
   */
  public void setYAxisMax(double max) {
    setYAxisMax(max, 0);
  }

  /**
   * Returns if the maximum Y value was set.
   * 
   * @return the maxY was set or not
   */
  public boolean isMaxYSet() {
    return isMaxYSet(0);
  }

  /**
   * Returns the start value of the X axis range.
   * 
   * @param scale the renderer scale
   * @return the X axis range start value
   */
  public double getXAxisMin(int scale) {
    return mMinX[scale];
  }

  /**
   * Sets the start value of the X axis range.
   * 
   * @param min the X axis range start value
   * @param scale the renderer scale
   */
  public void setXAxisMin(double min, int scale) {
    if (!isMinXSet(scale)) {
      initialRange.get(scale)[0] = min;
    }
    mMinX[scale] = min;
  }

  /**
   * Returns if the minimum X value was set.
   * 
   * @param scale the renderer scale
   * @return the minX was set or not
   */
  public boolean isMinXSet(int scale) {
    return mMinX[scale] != MathHelper.NULL_VALUE;
  }

  /**
   * Returns the end value of the X axis range.
   * 
   * @param scale the renderer scale
   * @return the X axis range end value
   */
  public double getXAxisMax(int scale) {
    return mMaxX[scale];
  }

  /**
   * Sets the end value of the X axis range.
   * 
   * @param max the X axis range end value
   * @param scale the renderer scale
   */
  public void setXAxisMax(double max, int scale) {
    if (!isMaxXSet(scale)) {
      initialRange.get(scale)[1] = max;
    }
    mMaxX[scale] = max;
  }

  /**
   * Returns if the maximum X value was set.
   * 
   * @param scale the renderer scale
   * @return the maxX was set or not
   */
  public boolean isMaxXSet(int scale) {
    return mMaxX[scale] != MathHelper.NULL_VALUE;
  }

  /**
   * Returns the start value of the Y axis range.
   * 
   * @param scale the renderer scale
   * @return the Y axis range end value
   */
  public double getYAxisMin(int scale) {
    return mMinY[scale];
  }

  /**
   * Sets the start value of the Y axis range.
   * 
   * @param min the Y axis range start value
   * @param scale the renderer scale
   */
  public void setYAxisMin(double min, int scale) {
    if (!isMinYSet(scale)) {
      initialRange.get(scale)[2] = min;
    }
    mMinY[scale] = min;
  }

  /**
   * Returns if the minimum Y value was set.
   * 
   * @param scale the renderer scale
   * @return the minY was set or not
   */
  public boolean isMinYSet(int scale) {
    return mMinY[scale] != MathHelper.NULL_VALUE;
  }

  /**
   * Returns the end value of the Y axis range.
   * 
   * @param scale the renderer scale
   * @return the Y axis range end value
   */
  public double getYAxisMax(int scale) {
    return mMaxY[scale];
  }

  /**
   * Sets the end value of the Y axis range.
   * 
   * @param max the Y axis range end value
   * @param scale the renderer scale
   */
  public void setYAxisMax(double max, int scale) {
    if (!isMaxYSet(scale)) {
      initialRange.get(scale)[3] = max;
    }
    mMaxY[scale] = max;
  }

  /**
   * Returns if the maximum Y value was set.
   * 
   * @param scale the renderer scale
   * @return the maxY was set or not
   */
  public boolean isMaxYSet(int scale) {
    return mMaxY[scale] != MathHelper.NULL_VALUE;
  }

  /**
   * Returns the approximate number of labels for the X axis.
   * 
   * @return the approximate number of labels for the X axis
   */
  public int getXLabels() {
    return mXLabels;
  }

  /**
   * Sets the approximate number of labels for the X axis.
   * 
   * @param xLabels the approximate number of labels for the X axis
   */
  public void setXLabels(int xLabels) {
    mXLabels = xLabels;
  }

  /**
   * Adds a new text label for the specified X axis value.
   * 
   * @param x the X axis value
   * @param text the text label
   * @deprecated use addXTextLabel instead
   */
  public void addTextLabel(double x, String text) {
    addXTextLabel(x, text);
  }

  /**
   * Adds a new text label for the specified X axis value.
   * 
   * @param x the X axis value
   * @param text the text label
   */
  public synchronized void addXTextLabel(double x, String text) {
    mXTextLabels.put(x, text);
  }

  /**
   * Removes text label for the specified X axis value.
   * 
   * @param x the X axis value
   */
  public synchronized void removeXTextLabel(double x) {
    mXTextLabels.remove(x);
  }

  /**
   * Returns the X axis text label at the specified X axis value.
   * 
   * @param x the X axis value
   * @return the X axis text label
   */
  public synchronized String getXTextLabel(Double x) {
    return mXTextLabels.get(x);
  }

  /**
   * Returns the X text label locations.
   * 
   * @return the X text label locations
   */
  public synchronized Double[] getXTextLabelLocations() {
    Double[] out = new Double[mXTextLabels.keySet().size()];
    return mXTextLabels.keySet().toArray(out);
  }

  /**
   * Clears the existing text labels.
   * 
   * @deprecated use clearXTextLabels instead
   */
  public void clearTextLabels() {
    clearXTextLabels();
  }

  /**
   * Clears the existing text labels on the X axis.
   */
  public synchronized void clearXTextLabels() {
    mXTextLabels.clear();
  }

  /**
   * If X axis labels should be rounded.
   * 
   * @return if rounded time values to be used
   */
  public boolean isXRoundedLabels() {
    return mXRoundedLabels;
  }

  /**
   * Sets if X axis rounded time values to be used.
   * 
   * @param rounded rounded values to be used
   */
  public void setXRoundedLabels(boolean rounded) {
    mXRoundedLabels = rounded;
  }

  /**
   * Adds a new text label for the specified Y axis value.
   * 
   * @param y the Y axis value
   * @param text the text label
   */
  public void addYTextLabel(double y, String text) {
    addYTextLabel(y, text, 0);
  }

  /**
   * Removes text label for the specified Y axis value.
   * 
   * @param y the Y axis value
   */
  public void removeYTextLabel(double y) {
    removeYTextLabel(y, 0);
  }

  /**
   * Adds a new text label for the specified Y axis value.
   * 
   * @param y the Y axis value
   * @param text the text label
   * @param scale the renderer scale
   */
  public synchronized void addYTextLabel(double y, String text, int scale) {
    mYTextLabels.get(scale).put(y, text);
  }

  /**
   * Removes text label for the specified Y axis value.
   * 
   * @param y the Y axis value
   * @param scale the renderer scale
   */
  public synchronized void removeYTextLabel(double y, int scale) {
    mYTextLabels.get(scale).remove(y);
  }

  /**
   * Returns the Y axis text label at the specified Y axis value.
   * 
   * @param y the Y axis value
   * @return the Y axis text label
   */
  public String getYTextLabel(Double y) {
    return getYTextLabel(y, 0);
  }

  /**
   * Returns the Y axis text label at the specified Y axis value.
   * 
   * @param y the Y axis value
   * @param scale the renderer scale
   * @return the Y axis text label
   */
  public synchronized String getYTextLabel(Double y, int scale) {
    return mYTextLabels.get(scale).get(y);
  }

  /**
   * Returns the Y text label locations.
   * 
   * @return the Y text label locations
   */
  public Double[] getYTextLabelLocations() {
    return getYTextLabelLocations(0);
  }

  /**
   * Returns the Y text label locations.
   * 
   * @param scale the renderer scale
   * @return the Y text label locations
   */
  public synchronized Double[] getYTextLabelLocations(int scale) {
    Double[] out = new Double[mYTextLabels.get(scale).keySet().size()];
    return mYTextLabels.get(scale).keySet().toArray(out);
  }

  /**
   * Clears the existing text labels on the Y axis.
   */
  public void clearYTextLabels() {
    clearYTextLabels(0);
  }

  /**
   * Clears the existing text labels on the Y axis.
   * 
   * @param scale the renderer scale
   */
  public synchronized void clearYTextLabels(int scale) {
    mYTextLabels.get(scale).clear();
  }

  /**
   * Returns the approximate number of labels for the Y axis.
   * 
   * @return the approximate number of labels for the Y axis
   */
  public int getYLabels() {
    return mYLabels;
  }

  /**
   * Sets the approximate number of labels for the Y axis.
   * 
   * @param yLabels the approximate number of labels for the Y axis
   */
  public void setYLabels(int yLabels) {
    mYLabels = yLabels;
  }

  /**
   * Returns the constant bar chart item width in pixels.
   * 
   * @return the bar width
   */
  public float getBarWidth() {
    return mBarWidth;
  }

  /**
   * Sets the bar chart item constant width in pixels.
   * 
   * @param width width in pixels
   */
  public void setBarWidth(float width) {
    mBarWidth = width;
  }

  /**
   * Returns the enabled state of the pan on at least one axis.
   * 
   * @return if pan is enabled
   */
  public boolean isPanEnabled() {
    return isPanXEnabled() || isPanYEnabled();
  }

  /**
   * Returns the enabled state of the pan on X axis.
   * 
   * @return if pan is enabled on X axis
   */
  public boolean isPanXEnabled() {
    return mPanXEnabled;
  }

  /**
   * Returns the enabled state of the pan on Y axis.
   * 
   * @return if pan is enabled on Y axis
   */
  public boolean isPanYEnabled() {
    return mPanYEnabled;
  }

  /**
   * Sets the enabled state of the pan.
   * 
   * @param enabledX pan enabled on X axis
   * @param enabledY pan enabled on Y axis
   */
  public void setPanEnabled(boolean enabledX, boolean enabledY) {
    mPanXEnabled = enabledX;
    mPanYEnabled = enabledY;
  }

  /**
   * Override {@link DefaultRenderer#setPanEnabled(boolean)} so it can be
   * delegated to {@link #setPanEnabled(boolean, boolean)}.
   */
  @Override
  public void setPanEnabled(final boolean enabled) {
    setPanEnabled(enabled, enabled);
  }

  /**
   * Returns the enabled state of the zoom on at least one axis.
   * 
   * @return if zoom is enabled
   */
  public boolean isZoomEnabled() {
    return isZoomXEnabled() || isZoomYEnabled();
  }

  /**
   * Returns the enabled state of the zoom on X axis.
   * 
   * @return if zoom is enabled on X axis
   */
  public boolean isZoomXEnabled() {
    return mZoomXEnabled;
  }

  /**
   * Returns the enabled state of the zoom on Y axis.
   * 
   * @return if zoom is enabled on Y axis
   */
  public boolean isZoomYEnabled() {
    return mZoomYEnabled;
  }

  /**
   * Sets the enabled state of the zoom.
   * 
   * @param enabledX zoom enabled on X axis
   * @param enabledY zoom enabled on Y axis
   */
  public void setZoomEnabled(boolean enabledX, boolean enabledY) {
    mZoomXEnabled = enabledX;
    mZoomYEnabled = enabledY;
  }

  /**
   * Returns the spacing between bars, in bar charts.
   * 
   * @return the spacing between bars
   * @deprecated use getBarSpacing instead
   */
  public double getBarsSpacing() {
    return getBarSpacing();
  }

  /**
   * Returns the spacing between bars, in bar charts.
   * 
   * @return the spacing between bars
   */
  public double getBarSpacing() {
    return mBarSpacing;
  }

  /**
   * Sets the spacing between bars, in bar charts. Only available for bar
   * charts. This is a coefficient of the bar width. For instance, if you want
   * the spacing to be a half of the bar width, set this value to 0.5.
   * 
   * @param spacing the spacing between bars coefficient
   */
  public void setBarSpacing(double spacing) {
    mBarSpacing = spacing;
  }

  /**
   * Returns the margins color.
   * 
   * @return the margins color
   */
  public int getMarginsColor() {
    return mMarginsColor;
  }

  /**
   * Sets the color of the margins.
   * 
   * @param color the margins color
   */
  public void setMarginsColor(int color) {
    mMarginsColor = color;
  }

  /**
   * Returns the grid color.
   * @param scale the renderer index
   * 
   * @return the grid color
   */
  public int getGridColor(int scale) {
    return mGridColors[scale];
  }

  /**
   * Sets the color of the grid.
   * 
   * @param color the grid color
   */
  public void setGridColor(int color) {
    setGridColor(color, 0);
  }

  /**
   * Sets the color of the grid.
   * 
   * @param color the grid color
   * @param scale the renderer scale
   */
  public void setGridColor(int color, int scale) {
    mGridColors[scale] = color;
  }

  /**
   * Returns the pan limits.
   * 
   * @return the pan limits
   */
  public double[] getPanLimits() {
    return mPanLimits;
  }

  /**
   * Sets the pan limits as an array of 4 values. Setting it to null or a
   * different size array will disable the panning limitation. Values:
   * [panMinimumX, panMaximumX, panMinimumY, panMaximumY]
   * 
   * @param panLimits the pan limits
   */
  public void setPanLimits(double[] panLimits) {
    mPanLimits = panLimits;
  }

  /**
   * Returns the zoom limits as a 4-element array, or {@literal null} if there
   * are no limits applied.  
   * 
   * 

Array elements are:

*
    *
  • {@literal 0} : Minimum distance between X-Axis min and max values. Same as {@link #getZoomInLimitX() }
  • *
  • {@literal 1} : Maximum distance between X-Axis min and max values.
  • *
  • {@literal 2} : Minimum distance between Y-Axis min and max values. Same as {@link #getZoomInLimitY() }
  • *
  • {@literal 3} : Maximum distance between Y-Axis min and max values.
  • *
* * @return the zoom limits */ public double[] getZoomLimits() { return mZoomLimits; } /** * Sets the zoom limits as an array of 4 values. * *

Array elements are:

*
    *
  • {@literal 0} : Minimum distance between X-Axis min and max values. Same as {@link #getZoomInLimitX() }
  • *
  • {@literal 1} : Maximum distance between X-Axis min and max values.
  • *
  • {@literal 2} : Minimum distance between Y-Axis min and max values. Same as {@link #getZoomInLimitY() }
  • *
  • {@literal 3} : Maximum distance between Y-Axis min and max values.
  • *
* *

Setting this value as {@literal null} will turn off all limits so that, if zoom is enabled, users * can zoom and and out as much as they like.

* * @param zoomLimits the zoom limits */ public void setZoomLimits(double[] zoomLimits) { mZoomLimits = zoomLimits; if (mZoomLimits != null && mZoomLimits.length == 4) { mZoomInLimitX = mZoomLimits[0]; mZoomInLimitY = mZoomLimits[2]; } else { mZoomInLimitX = 0; mZoomInLimitY = 0; } } /** * Returns the rotation angle of labels for the X axis. * * @return the rotation angle of labels for the X axis */ public float getXLabelsAngle() { return mXLabelsAngle; } /** * Sets the rotation angle (in degrees) of labels for the X axis. * * @param angle the rotation angle of labels for the X axis */ public void setXLabelsAngle(float angle) { mXLabelsAngle = angle; } /** * Returns the rotation angle of labels for the Y axis. * * @return the approximate number of labels for the Y axis */ public float getYLabelsAngle() { return mYLabelsAngle; } /** * Sets the rotation angle (in degrees) of labels for the Y axis. * * @param angle the rotation angle of labels for the Y axis */ public void setYLabelsAngle(float angle) { mYLabelsAngle = angle; } /** * Returns the size of the points, for charts displaying points. * * @return the point size */ public float getPointSize() { return mPointSize; } /** * Sets the size of the points, for charts displaying points. * * @param size the point size */ public void setPointSize(float size) { mPointSize = size; } /** * Sets the axes range values. * * @param range an array having the values in this order: minX, maxX, minY, * maxY */ public void setRange(double[] range) { setRange(range, 0); } /** * Sets the axes range values. * * @param range an array having the values in this order: minX, maxX, minY, * maxY * @param scale the renderer scale */ public void setRange(double[] range, int scale) { setXAxisMin(range[0], scale); setXAxisMax(range[1], scale); setYAxisMin(range[2], scale); setYAxisMax(range[3], scale); } public boolean isInitialRangeSet() { return isInitialRangeSet(0); } /** * Returns if the initial range is set. * * @param scale the renderer scale * @return the initial range was set or not */ public boolean isInitialRangeSet(int scale) { return initialRange.get(scale) != null; } /** * Returns the initial range. * * @return the initial range */ public double[] getInitialRange() { return getInitialRange(0); } /** * Returns the initial range. * * @param scale the renderer scale * @return the initial range */ public double[] getInitialRange(int scale) { return initialRange.get(scale); } /** * Sets the axes initial range values. This will be used in the zoom fit tool. * * @param range an array having the values in this order: minX, maxX, minY, * maxY */ public void setInitialRange(double[] range) { setInitialRange(range, 0); } /** * Sets the axes initial range values. This will be used in the zoom fit tool. * * @param range an array having the values in this order: minX, maxX, minY, * maxY * @param scale the renderer scale */ public void setInitialRange(double[] range, int scale) { initialRange.put(scale, range); } /** * Returns the X axis labels color. * * @return the X axis labels color */ public int getXLabelsColor() { return mXLabelsColor; } /** * Returns the Y axis labels color. * * @return the Y axis labels color */ public int getYLabelsColor(int scale) { return mYLabelsColor[scale]; } /** * Sets the X axis labels color. * * @param color the X axis labels color */ public void setXLabelsColor(int color) { mXLabelsColor = color; } /** * Sets the Y axis labels color. * * @param scale the renderer scale * @param color the Y axis labels color */ public void setYLabelsColor(int scale, int color) { mYLabelsColor[scale] = color; } /** * Returns the X axis labels alignment. One of Component.CENTER, Component.LEFT, Component.RIGHT * * @return X labels alignment */ public int getXLabelsAlign() { return xLabelsAlign; } /** * Sets the X axis labels alignment. One of Component.CENTER, Component.LEFT, Component.RIGHT * * @param align the X labels alignment */ public void setXLabelsAlign(int align) { xLabelsAlign = align; } /** * Returns the Y axis labels alignment. * * @param scale the renderer scale * @return Y labels alignment */ public int getYLabelsAlign(int scale) { return yLabelsAlign[scale]; } public void setYLabelsAlign(int align) { setYLabelsAlign(align, 0); } public int getYAxisAlign(int scale) { return yAxisAlign[scale]; } public void setYAxisAlign(int align, int scale) { yAxisAlign[scale] = align; } /** * Sets the Y axis labels alignment. * * @param align the Y labels alignment */ public void setYLabelsAlign(int align, int scale) { yLabelsAlign[scale] = align; } /** * Returns the X labels padding. * * @return X labels padding */ public float getXLabelsPadding() { return mXLabelsPadding; } /** * Sets the X labels padding * * @param padding the amount of padding between the axis and the label */ public void setXLabelsPadding(float padding) { mXLabelsPadding = padding; } /** * Returns the Y labels padding. * * @return Y labels padding */ public float getYLabelsPadding() { return mYLabelsPadding; } /** * Sets the Y labels vertical padding * * @param padding the amount of vertical padding */ public void setYLabelsVerticalPadding(float padding) { mYLabelsVerticalPadding = padding; } /** * Returns the Y labels vertical padding. * * @return Y labels vertical padding */ public float getYLabelsVerticalPadding() { return mYLabelsVerticalPadding; } /** * Sets the Y labels padding * * @param padding the amount of padding between the axis and the label */ public void setYLabelsPadding(float padding) { mYLabelsPadding = padding; } /** * Returns the number format for displaying labels. * * @return the number format for labels * @deprecated use getXLabelFormat and getYLabelFormat instead */ public NumberFormat getLabelFormat() { return getXLabelFormat(); } /** * Sets the number format for displaying labels. * * @param format the number format for labels * @deprecated use setXLabelFormat and setYLabelFormat instead */ void setLabelFormat(NumberFormat format) { setXLabelFormat(format); } /** * Returns the number format for displaying X axis labels. * * @return the number format for X axis labels */ public NumberFormat getXLabelFormat() { return mXLabelFormat; } /** * Sets the number format for X axis displaying labels. * * @param format the number format for X axis labels */ public void setXLabelFormat(NumberFormat format) { mXLabelFormat = format; } /** * Returns the number format for Y axis displaying labels. * * @param scale the renderer scale * @return the number format for Y axis labels */ public NumberFormat getYLabelFormat(int scale) { return mYLabelFormat[scale]; } /** * Sets the number format for Y axis displaying labels. * * @param format the number format for labels * @param scale the renderer scale */ public void setYLabelFormat(NumberFormat format, int scale) { mYLabelFormat[scale] = format; } /** * Returns the zoom in limit permitted in the axis X. This is interpreted as * the maximum distance between {@link #getXAxisMin() } and {@link #getXAxisMax() }. * * @return the maximum zoom in permitted in the axis X * * @see #setZoomInLimitX(double) */ public double getZoomInLimitX() { return mZoomInLimitX; } /** * Sets the zoom in limit permitted in the axis X. * * This function prevent that the distance between {@link #getXAxisMin()} and * {@link #getXAxisMax()} can't be greater or equal than * {@link #getZoomInLimitX()} * * @param zoomInLimitX the maximum distance permitted between * {@link #getXAxisMin()} and {@link #getXAxisMax()}. */ public void setZoomInLimitX(double zoomInLimitX) { this.mZoomInLimitX = zoomInLimitX; if (mZoomLimits == null) { mZoomLimits = new double[]{mZoomInLimitX, 0, 0, 0}; } else { mZoomLimits[0] = mZoomInLimitX; } } /** * Returns the zoom in limit permitted in the axis Y. This is interpreted as * the maximum difference between {@link #getYAxisMin() } and {@link #getYAxisMax() }. * * @return the maximum in zoom permitted in the axis Y * * @see #setZoomInLimitY(double) */ public double getZoomInLimitY() { return mZoomInLimitY; } /** * Sets zoom in limit permitted in the axis Y. * * This function prevent that the distance between {@link #getYAxisMin()} and * {@link #getYAxisMax()} can't be greater or equal than * {@link #getZoomInLimitY()} * * @param zoomInLimitY the maximum distance permitted between * {@link #getYAxisMin()} and {@link #getYAxisMax()} */ public void setZoomInLimitY(double zoomInLimitY) { this.mZoomInLimitY = zoomInLimitY; if (mZoomLimits == null) { mZoomLimits = new double[]{0, 0, mZoomInLimitY, 0}; } else { mZoomLimits[2] = mZoomInLimitY; } } public int getScalesCount() { return scalesCount; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy