📄 categorylabelposition.java
字号:
/* =========================================================== * JFreeChart : a free chart library for the Java(tm) platform * =========================================================== * * (C) Copyright 2000-2004, by Object Refinery Limited and Contributors. * * Project Info: http://www.jfree.org/jfreechart/index.html * * This library is free software; you can redistribute it and/or modify it under the terms * of the GNU Lesser General Public License as published by the Free Software Foundation; * either version 2.1 of the License, or (at your option) any later version. * * This library 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License along with this * library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, * Boston, MA 02111-1307, USA. * * [Java is a trademark or registered trademark of Sun Microsystems, Inc. * in the United States and other countries.] * * -------------------------- * CategoryLabelPosition.java * -------------------------- * (C) Copyright 2003, 2004, by Object Refinery Limited and Contributors. * * Original Author: David Gilbert (for Object Refinery Limited); * Contributor(s): -; * * $Id: CategoryLabelPosition.java,v 1.6 2004/03/23 15:53:27 mungady Exp $ * * Changes * ------- * 31-Oct-2003 : Version 1 (DG); * 17-Feb-2004 : Added new constructor (DG); * 23-Mar-2004 : Added width calculation parameters (DG); * */package org.jfree.chart.axis;import java.io.Serializable;import org.jfree.text.TextBlockAnchor;import org.jfree.ui.RectangleAnchor;import org.jfree.ui.TextAnchor;/** * The attributes that control the position of the labels for the categories on a * {@link CategoryAxis}. Instances of this class are immutable and other JFreeChart classes * rely upon this. */public class CategoryLabelPosition implements Serializable { /** The category anchor point. */ private RectangleAnchor categoryAnchor; /** The text block anchor. */ private TextBlockAnchor labelAnchor; /** The rotation anchor. */ private TextAnchor rotationAnchor; /** The rotation angle (in radians). */ private double angle; /** The width calculation type. */ private CategoryLabelWidthType widthType; /** The maximum label width as a percentage of the category space or the range space. */ private float widthRatio; /** * Creates a new position record with default settings. */ public CategoryLabelPosition() { this( RectangleAnchor.CENTER, TextBlockAnchor.BOTTOM_CENTER, TextAnchor.CENTER, 0.0, CategoryLabelWidthType.CATEGORY, 0.90f ); } /** * Creates a new category label position record. * * @param categoryAnchor the category anchor (<code>null</code> not permitted). * @param labelAnchor the label anchor (<code>null</code> not permitted). */ public CategoryLabelPosition(RectangleAnchor categoryAnchor, TextBlockAnchor labelAnchor) { // argument checking delegated... this( categoryAnchor, labelAnchor, TextAnchor.CENTER, 0.0, CategoryLabelWidthType.CATEGORY, 0.90f ); } /** * Creates a new category label position record. * * @param categoryAnchor the category anchor (<code>null</code> not permitted). * @param labelAnchor the label anchor (<code>null</code> not permitted). * @param widthType the width type (<code>null</code> not permitted). * @param widthRatio the maximum label width as a percentage (of the category space or the * range space). */ public CategoryLabelPosition(RectangleAnchor categoryAnchor, TextBlockAnchor labelAnchor, CategoryLabelWidthType widthType, float widthRatio) { // argument checking delegated... this(categoryAnchor, labelAnchor, TextAnchor.CENTER, 0.0, widthType, widthRatio); } /** * Creates a new position record. The item label anchor is a point relative to the * data item (dot, bar or other visual item) on a chart. The item label is aligned * by aligning the text anchor with the item label anchor. * * @param categoryAnchor the category anchor (<code>null</code> not permitted). * @param labelAnchor the label anchor (<code>null</code> not permitted). * @param rotationAnchor the rotation anchor (<code>null</code> not permitted). * @param angle the rotation angle (<code>null</code> not permitted). * * @deprecated Use alternative constructor. */ public CategoryLabelPosition(RectangleAnchor categoryAnchor, TextBlockAnchor labelAnchor, TextAnchor rotationAnchor, double angle) { if (categoryAnchor == null) { throw new IllegalArgumentException("Null 'categoryAnchor' argument."); } if (labelAnchor == null) { throw new IllegalArgumentException("Null 'labelAnchor' argument."); } if (rotationAnchor == null) { throw new IllegalArgumentException("Null 'rotationAnchor' argument."); } this.categoryAnchor = categoryAnchor; this.labelAnchor = labelAnchor; this.rotationAnchor = rotationAnchor; this.angle = angle; this.widthType = CategoryLabelWidthType.CATEGORY; this.widthRatio = 0.90f; } /** * Creates a new position record. The item label anchor is a point relative to the * data item (dot, bar or other visual item) on a chart. The item label is aligned * by aligning the text anchor with the item label anchor. * * @param categoryAnchor the category anchor (<code>null</code> not permitted). * @param labelAnchor the label anchor (<code>null</code> not permitted). * @param rotationAnchor the rotation anchor (<code>null</code> not permitted). * @param angle the rotation angle (<code>null</code> not permitted). * @param widthType the width type (<code>null</code> not permitted). * @param widthRatio the maximum label width as a percentage (of the category space or the * range space). */ public CategoryLabelPosition(RectangleAnchor categoryAnchor, TextBlockAnchor labelAnchor, TextAnchor rotationAnchor, double angle, CategoryLabelWidthType widthType, float widthRatio) { if (categoryAnchor == null) { throw new IllegalArgumentException("Null 'categoryAnchor' argument."); } if (labelAnchor == null) { throw new IllegalArgumentException("Null 'labelAnchor' argument."); } if (rotationAnchor == null) { throw new IllegalArgumentException("Null 'rotationAnchor' argument."); } if (widthType == null) { throw new IllegalArgumentException("Null 'widthType' argument."); } this.categoryAnchor = categoryAnchor; this.labelAnchor = labelAnchor; this.rotationAnchor = rotationAnchor; this.angle = angle; this.widthType = widthType; this.widthRatio = widthRatio; } /** * Returns the item label anchor. * * @return the item label anchor (never <code>null</code>). */ public RectangleAnchor getCategoryAnchor() { return this.categoryAnchor; } /** * Returns the text block anchor. * * @return the text block anchor (never <code>null</code>). */ public TextBlockAnchor getLabelAnchor() { return this.labelAnchor; } /** * Returns the rotation anchor point. * * @return the rotation anchor point (never <code>null</code>). */ public TextAnchor getRotationAnchor() { return this.rotationAnchor; } /** * Returns the angle of rotation for the label. * * @return the angle (in radians). */ public double getAngle() { return this.angle; } /** * Returns the width calculation type. * * @return The width calculation type. */ public CategoryLabelWidthType getWidthType() { return this.widthType; } /** * Returns the ratio used to calculate the maximum category label width. * * @return The ratio. */ public float getWidthRatio() { return this.widthRatio; } /** * Tests an object for equality with this instance. * * @param object the object. * * @return a boolean. */ public boolean equals(Object object) { if (object == null) { return false; } if (object == this) { return true; } if (object instanceof CategoryLabelPosition) { CategoryLabelPosition p = (CategoryLabelPosition) object; boolean b0 = (this.categoryAnchor.equals(p.categoryAnchor)); boolean b1 = (this.labelAnchor.equals(p.labelAnchor)); boolean b2 = (this.rotationAnchor.equals(p.rotationAnchor)); boolean b3 = (this.angle == p.angle); return b0 && b1 && b2 && b3; } return false; }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -