ImageVerifierCode 换一换
格式:DOC , 页数:11 ,大小:142.50KB ,
资源ID:7277317      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-7277317.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(利用JFreeChart生成折线图.doc)为本站会员(hskm5268)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

利用JFreeChart生成折线图.doc

1、利用 JFreeChart 生成折线图通过 JFreeChart 插件,既可以生成普通效果的折线图,也可以生成 3D 效果的折线图。如果想生成普通效果的折线图,需要通过工厂类 ChartFactory 的 createLineChart()方法获得JFreeChart 类的实例;如果想生成 3D 效果的折线图,需要通过工厂类 ChartFactory 的createLineChart3D()方法获得 JFreeChart 类的实例。这两个方法的入口参数是完全相同的,各个入口参数的类型及功能请参见 14.2.1 节的表 14.2。可以分别通过绘图区对象 CategoryPlot 的 getDom

2、ainAxis()方法和 getRangeAxis()方法,获得横轴对象和纵轴对象,通过得到的轴对象可以设置绘制坐标轴的相关属性,常用方法及实现功能如表 14.4 所示。表 14.4 设置坐标轴绘制属性的部分通用方法通 用 方 法实 现 功 能setAxisLineStroke(Stroke stroke)通过该方法可以设置轴线的粗细setAxisLinePaint(Paint paint)通过该方法可以设置轴线的颜色setLabelFont(Font font)通过该方法可以设置坐标轴标题的字体setLabelPaint(Paint paint)通过该方法可以设置坐标轴标题的颜色纵轴对象还提

3、供了设置坐标最大值的方法 setUpperBound(double max),在默认情况下将最大值控制在能够正常绘制统计图的范围内。通过 java.awt.BasicStroke 类可以绘制出各种各样的线段,大体分为实线段和虚线段,可控的绘制条件包括线条的宽度、线段端点的风格、折线段的折点风格、虚线段的绘制风格和虚线段的绘制偏移量,BasicStroke 类提供的所有构造方法如表 14.5 所示。表 14.5 BasicStroke 类提供的所有构造方法构 造 方 法使 用 说 明BasicStroke()创建一个实线对象,各控制条件均采用默认值,宽度为 1.0,端点风格为 CAP_SQUAR

4、E,折点风格为JOIN_MITER,折点控制值为 10.0BasicStroke(float width)创建一个指定宽度的实线对象,其他参数仍采用默认值BasicStroke(float width, int cap, int join)创建一个指定宽度、指定端点风格和指定折点风格的实线对象,折点控制值仍采用默认值 10.0BasicStroke(float width, int cap, int 创建一个指定宽度、指定端点风格、指定折点风格和join, float miterlimit) 指定折点控制值的实线对象BasicStroke(float width, int cap, int j

5、oin, float miterlimit, float dash, float dash_phase)通过该构造方法,既可以创建实线对象,又可以创建虚线对象,当将参数 dash 设为 null 时,创建的即为实线对象,如果将其设为 float 型数组,创建的则为虚线对象,最后一个参数用来设置开始绘制虚线的偏移量线段端点的修饰风格有 3 种,分别由 3 个常量表示,具体信息如表 14.6 所示。表 14.6 线段端点修饰风格简介常 量 名 称常 量 值修 饰 办 法BasicStroke.CAP_BUTT0对线段端点不加任何修饰BasicStroke.CAP_ROUND1在线段端点加半圆进行修

6、饰,半圆的直径为线段的宽度BasicStroke.CAP_SQUARE2在线段端点加矩形进行修饰,矩形的宽度为线段宽度的一半,矩形的高度为线段的宽度线段折点的修饰风格同样有 3 种,也由 3 个常量表示,具体信息如表 14.7 所示。表 14.7 线段折点修饰风格简介常 量 名 称常 量 值修 饰 办 法BasicStroke.JOIN_MITER0对线段折点不加任何修饰BasicStroke.JOIN_ROUND1在折线段的两端加半圆进行修饰,半圆的直径为线段的宽度BasicStroke.JOIN_BEVEL2将组成折点的两条线段的外侧延长至相交,然后填充被包的区域入口参数 dash 用来定

7、义虚线,为 float 型数组,当 dash 数组由偶数个元素组成时,索引值为偶数的元素值代表虚线段的长度,索引值为奇数的元素值代表两个虚线段之间的空白部分的长度,需要注意的是,数组的索引值是从 0 开始的;当数组中只有一个元素时,例如dash=6,等同于 dash=6,6。注意:建议不要为 dash 数组设定奇数个元素,那样将无法把握虚线的绘制规律,为一个元素的情况除外。入口参数 dash_phase 用来定义虚线开始绘制位置的偏移量。以 dash=6为例,如果dash_phase=0,则虚线正常绘制;如果 dash_phase=3,则第一段短化线的长度为 6-3,后面则正常绘制。示例 14

8、-04 编程类图书年销量折线图分析下面来看一个绘制折线图的例子,该例绘制的折线图效果如图 14.6 和图 14.7 所示。图 14.6 普通效果的折线图 图 14.7 3D 效果的折线图代码 14-04 光盘位置:光盘 mingrisoft14sl04下面的代码负责定义折线的绘制风格,并将指定的图例用实线绘制,代码如下:BasicStroke realLine = new BasicStroke(1.6f);float dashes = 8.0f ; / 定义虚线数组BasicStroke brokenLine = new BasicStroke(1.6f, / 线条粗细BasicStroke

9、.CAP_ROUND, / 端点风格BasicStroke.JOIN_ROUND, / 折点风格8.f, / 折点处理办法dashes, / 虚线数组0.0f); / 虚线偏移量int special = 1; / 定义利用需线绘制的图例for (int i = 0; i cutline.length; i+) if (i = special) renderer.setSeriesStroke(i, realLine); / 利用实线绘制 else renderer.setSeriesStroke(i, brokenLine); / 利用虚线绘制下面的代码负责获得横轴对象,并设置相关的绘图属性

10、,代码如下:CategoryAxis domainAxis = plot.getDomainAxis();domainAxis.setAxisLineStroke(new BasicStroke(1.6f); / 设置轴线粗细domainAxis.setAxisLinePaint(Color.BLACK); / 设置轴线颜色domainAxis.setCategoryLabelPositionOffset(5); / 设置统计种类与轴线的颜色domainAxis.setLabelFont(new Font(“黑体“, Font.BOLD, 16); / 设置坐标轴标题字体domainAxis.

11、setLabelPaint(Color.BLACK); / 设置坐标轴标题颜色/ 设置坐标轴标题旋转角度,这里并未旋转,目的是告诉读者这个方法domainAxis.setCategoryLabelPositions(CategoryLabelPositions.STANDARD);下面的代码负责获得纵轴对象,并设置相关的绘图属性,代码如下:ValueAxis rangeAxis = plot.getRangeAxis();rangeAxis.setAxisLineStroke(new BasicStroke(1.6f); / 设置轴线粗细rangeAxis.setAxisLinePaint(C

12、olor.BLACK); / 设置轴线颜色rangeAxis.setUpperBound(100.0f); / 设置坐标最大值rangeAxis.setTickMarkStroke(new BasicStroke(1.6f); / 设置坐标标记大小rangeAxis.setTickMarkPaint(Color.BLACK); / 设置坐标标记颜色rangeAxis.setLabelFont(new Font(“黑体“, Font.BOLD, 16); / 设置坐标轴标题字体rangeAxis.setLabelPaint(Color.BLACK); / 设置坐标轴标题颜色rangeAxis.s

13、etLabelAngle(Math.PI / 2); / 设置坐标轴标题旋转角度横坐标只能事 Comparable 型的 晕 你看我构造函数里是这样写的, public void addValue(double value, Comparable rowKey, Comparable columnKey) addValue(new Double(value), rowKey, columnKey); public void setValue(Number value, Comparable rowKey, Comparable columnKey) this.data.setValue(val

14、ue, rowKey, columnKey); fireDatasetChanged(); JFreeChart 类: void setAntiAlias(boolean flag) 字体模糊边界 void setBackgroundImage(Image image) 背景图片 void setBackgroundImageAlignment(int alignment) 背景图片对齐方式(参数常量在 org.jfree.ui.Align 类中定义) void setBackgroundImageAlpha(float alpha) 背景图片透明度( 0.01.0) void setBack

15、groundPaint(Paint paint) 背景色 void setBorderPaint(Paint paint) 边界线条颜色 void setBorderStroke(Stroke stroke) 边界线条笔触 void setBorderVisible(boolean visible) 边界线条是否可见 - TextTitle 类: void setFont(Font font) 标题字体 void setPaint(Paint paint) 标题字体颜色 void setText(String text) 标题内容 - StandardLegend(Legend)类: void

16、 setBackgroundPaint(Paint paint) 图示背景色 void setTitle(String title) 图示标题内容 void setTitleFont(Font font) 图示标题字体 void setBoundingBoxArcWidth(int arcWidth) 图示边界圆角宽 void setBoundingBoxArcHeight(int arcHeight) 图示边界圆角高 void setOutlinePaint(Paint paint) 图示边界线条颜色 void setOutlineStroke(Stroke stroke) 图示边界线条笔触

17、 void setDisplaySeriesLines(boolean flag) 图示项是否显示横线(折线图有效) void setDisplaySeriesShapes(boolean flag) 图示项是否显示形状(折线图有效) void setItemFont(Font font) 图示项字体 void setItemPaint(Paint paint) 图示项字体颜色 void setAnchor(int anchor) 图示在图表中的显示位置(参数常量在 Legend类中定义) - Axis 类: void setVisible(boolean flag) 坐标轴是否可见 void

18、 setAxisLinePaint(Paint paint) 坐标轴线条颜色(3D 轴无效) void setAxisLineStroke(Stroke stroke) 坐标轴线条笔触(3D 轴无效) void setAxisLineVisible(boolean visible) 坐标轴线条是否可见(3D 轴无效) void setFixedDimension(double dimension) (用于复合表中对多坐标轴的设置)void setLabel(String label) 坐标轴标题 void setLabelFont(Font font) 坐标轴标题字体 void setLabe

19、lPaint(Paint paint) 坐标轴标题颜色 void setLabelAngle(double angle) 坐标轴标题旋转角度(纵坐标可以旋转) void setTickLabelFont(Font font) 坐标轴标尺值字体 void setTickLabelPaint(Paint paint) 坐标轴标尺值颜色 void setTickLabelsVisible(boolean flag) 坐标轴标尺值是否显示 void setTickMarkPaint(Paint paint) 坐标轴标尺颜色 void setTickMarkStroke(Stroke stroke) 坐

20、标轴标尺笔触 void setTickMarksVisible(boolean flag) 坐标轴标尺是否显示 ValueAxis(Axis)类: void setAutoRange(boolean auto) 自动设置数据轴数据范围 void setAutoRangeMinimumSize(double size) 自动设置数据轴数据范围时数据范围的最小跨度 void setAutoTickUnitSelection(boolean flag) 数据轴的数据标签是否自动确定(默认为 true) void setFixedAutoRange(double length) 数据轴固定数据范围(设

21、置 100 的话就是显示 MAXVALUE 到 MAXVALUE-100 那段数据范围) void setInverted(boolean flag) 数据轴是否反向(默认为 false) void setLowerMargin(double margin) 数据轴下(左)边距 void setUpperMargin(double margin) 数据轴上(右)边距 void setLowerBound(double min) 数据轴上的显示最小值 void setUpperBound(double max) 数据轴上的显示最大值 void setPositiveArrowVisible(bo

22、olean visible) 是否显示正向箭头(3D 轴无效) void setNegativeArrowVisible(boolean visible) 是否显示反向箭头(3D 轴无效) void setVerticalTickLabels(boolean flag) 数据轴数据标签是否旋转到垂直 void setStandardTickUnits(TickUnitSource source) 数据轴的数据标签(可以只显示整数标签,需要将 AutoTickUnitSelection 设 false) NumberAxis(ValueAxis)类: void setAutoRangeInclu

23、desZero(boolean flag) 是否强制在自动选择的数据范围中包含 0 void setAutoRangeStickyZero(boolean flag) 是否强制在整个数据轴中包含 0,即使 0 不在数据范围中 void setNumberFormatOverride(NumberFormat formatter) 数据轴数据标签的显示格式 void setTickUnit(NumberTickUnit unit) 数据轴的数据标签(需要将AutoTickUnitSelection 设 false) DateAxis(ValueAxis)类: void setMaximumDat

24、e(Date maximumDate) 日期轴上的最小日期 void setMinimumDate(Date minimumDate) 日期轴上的最大日期 void setRange(Date lower,Date upper) 日期轴范围 void setDateFormatOverride(DateFormat formatter) 日期轴日期标签的显示格式 void setTickUnit(DateTickUnit unit) 日期轴的日期标签(需要将AutoTickUnitSelection 设 false) void setTickMarkPosition(DateTickMarkP

25、osition position) 日期标签位置(参数常量在 org.jfree.chart.axis.DateTickMarkPosition 类中定义) CategoryAxis(Axis)类: void setCategoryMargin(double margin) 分类轴边距 void setLowerMargin(double margin) 分类轴下(左)边距 void setUpperMargin(double margin) 分类轴上(右)边距 void setVerticalCategoryLabels(boolean flag) 分类轴标题是否旋转到垂直 void set

26、MaxCategoryLabelWidthRatio(float ratio) 分类轴分类标签的最大宽度 Plot 类: void setBackgroundImage(Image image) 数据区的背景图片 void setBackgroundImageAlignment(int alignment) 数据区的背景图片对齐方式(参数常量在 org.jfree.ui.Align 类中定义) void setBackgroundPaint(Paint paint) 数据区的背景图片背景色 void setBackgroundAlpha(float alpha) 数据区的背景透明度(0.01.

27、0) void setForegroundAlpha(float alpha) 数据区的前景透明度(0.01.0) void setDataAreaRatio(double ratio) 数据区占整个图表区的百分比 void setOutLinePaint(Paint paint) 数据区的边界线条颜色 void setOutLineStroke(Stroke stroke) 数据区的边界线条笔触 void setNoDataMessage(String message) 没有数据时显示的消息 void setNoDataMessageFont(Font font) 没有数据时显示的消息字体

28、void setNoDataMessagePaint(Paint paint) 没有数据时显示的消息颜色 CategoryPlot(Plot)类: void setDataset(CategoryDataset dataset) 数据区的 2 维数据表 void setColumnRenderingOrder(SortOrder order) 数据分类的排序方式 void setAxisOffset(Spacer offset) 坐标轴到数据区的间距 void setOrientation(PlotOrientation orientation) 数据区的方向(PlotOrientation.

29、HORIZONTAL 或 PlotOrientation.VERTICAL) void setDomainAxis(CategoryAxis axis) 数据区的分类轴 void setDomainAxisLocation(AxisLocation location) 分类轴的位置(参数常量在org.jfree.chart.axis.AxisLocation 类中定义) void setDomainGridlinesVisible(boolean visible) 分类轴网格是否可见 void setDomainGridlinePaint(Paint paint) 分类轴网格线条颜色 void

30、 setDomainGridlineStroke(Stroke stroke) 分类轴网格线条笔触 void setRangeAxis(ValueAxis axis) 数据区的数据轴 void setRangeAxisLocation(AxisLocation location) 数据轴的位置(参数常量在org.jfree.chart.axis.AxisLocation 类中定义) void setRangeGridlinesVisible(boolean visible) 数据轴网格是否可见 void setRangeGridlinePaint(Paint paint) 数据轴网格线条颜色

31、void setRangeGridlineStroke(Stroke stroke) 数据轴网格线条笔触 void setRenderer(CategoryItemRenderer renderer) 数据区的表示者(详见Renderer 组) void addAnnotation(CategoryAnnotation annotation) 给数据区加一个注释 void addRangeMarker(Marker marker,Layer layer) 给数据区加一个数值范围区域 PiePlot(Plot)类: void setDataset(PieDataset dataset) 数据区的

32、 1 维数据表 void setIgnoreNullValues(boolean flag) 忽略无值的分类 void setCircular(boolean flag) 饼图是否一定是正圆 void setStartAngle(double angle) 饼图的初始角度 void setDirection(Rotation direction) 饼图的旋转方向 void setExplodePercent(int section,double percent) 抽取的那块(1 维数据表的分类下标)以及抽取出来的距离(0.01.0) ,3D 饼图无效 void setLabelBackgrou

33、ndPaint(Paint paint) 分类标签的底色 void setLabelFont(Font font) 分类标签的字体 void setLabelPaint(Paint paint) 分类标签的字体颜色 void setLabelLinkMargin(double margin) 分类标签与图的连接线边距 void setLabelLinkPaint(Paint paint) 分类标签与图的连接线颜色 void setLabelLinkStroke(Stroke stroke) 分类标签与图的连接线笔触 void setLabelOutlinePaint(Paint paint)

34、分类标签边框颜色 void setLabelOutlineStroke(Paint paint) 分类标签边框笔触 void setLabelShadowPaint(Paint paint) 分类标签阴影颜色 void setMaximumLabelWidth(double width) 分类标签的最大长度(0.01.0) void setPieIndex(int index) 饼图的索引(复合饼图中用到) void setSectionOutlinePaint(int section,Paint paint) 指定分类饼的边框颜色 void setSectionOutlineStroke(i

35、nt section,Stroke stroke) 指定分类饼的边框笔触 void setSectionPaint(int section,Paint paint) 指定分类饼的颜色 void setShadowPaint(Paint paint) 饼图的阴影颜色 void setShadowXOffset(double offset) 饼图的阴影相对图的水平偏移 void setShadowYOffset(double offset) 饼图的阴影相对图的垂直偏移 void setLabelGenerator(PieSectionLabelGenerator generator) 分类标签的格

36、式,设置成 null 则整个标签包括连接线都不显示 void setToolTipGenerator(PieToolTipGenerator generator) MAP 中鼠标移上的显示格式 void setURLGenerator(PieURLGenerator generator) MAP 中钻取链接格式 PiePlot3D(PiePlot)类: void setDepthFactor(double factor) 3D 饼图的 Z 轴高度(0.01.0) MultiplePiePlot(Plot)类: void setLimit(double limit) 每个饼图之间的数据关联(详细

37、比较复杂) void setPieChart(JFreeChart pieChart) 每个饼图的显示方式(见 JFreeChart 类个 PiePlot 类)AbstractRenderer 类: void setItemLabelAnchorOffset(double offset) 数据标签的与数据点的偏移 void setItemLabelsVisible(boolean visible) 数据标签是否可见 void setItemLabelFont(Font font) 数据标签的字体 void setItemLabelPaint(Paint paint) 数据标签的字体颜色 voi

38、d setItemLabelPosition(ItemLabelPosition position) 数据标签位置 void setPositiveItemLabelPosition(ItemLabelPosition position) 正数标签位置 void setNegativeItemLabelPosition(ItemLabelPosition position) 负数标签位置 void setOutLinePaint(Paint paint) 图形边框的线条颜色 void setOutLineStroke(Stroke stroke) 图形边框的线条笔触 void setPaint

39、(Paint paint) 所有分类图形的颜色 void setShape(Shape shape) 所有分类图形的形状(如折线图的点) void setStroke(Stroke stroke) 所有分类图形的笔触(如折线图的线)void setSeriesItemLabelsVisible(int series,boolean visible) 指定分类的数据标签是否可见 void setSeriesItemLabelFont(int series,Font font) 指定分类的数据标签的字体 void setSeriesItemLabelPaint(int series,Paint p

40、aint) 指定分类的数据标签的字体颜色 void setSeriesItemLabelPosition(int series,ItemLabelPosition position) 数据标签位置 void setSeriesPositiveItemLabelPosition(int series,ItemLabelPosition position) 正数标签位置 void setSeriesNegativeItemLabelPosition(int series,ItemLabelPosition position) 负数标签位置 void setSeriesOutLinePaint(in

41、t series,Paint paint) 指定分类的图形边框的线条颜色 void setSeriesOutLineStroke(int series,Stroke stroke) 指定分类的图形边框的线条笔触 void setSeriesPaint(int series,Paint paint) 指定分类图形的颜色 void setSeriesShape(int series,Shape shape) 指定分类图形的形状(如折线图的点) void setSeriesStroke(int series,Stroke stroke) 指定分类图形的笔触(如折线图的线) AbstractCateg

42、oryItemRenderer(AbstractRenderer)类: void setLabelGenerator(CategoryLabelGenerator generator) 数据标签的格式 void setToolTipGenerator(CategoryToolTipGenerator generator) MAP 中鼠标移上的显示格式 void setItemURLGenerator(CategoryURLGenerator generator) MAP 中钻取链接格式 void setSeriesLabelGenerator(int series,CategoryLabelG

43、enerator generator) 指定分类的数据标签的格式 void setSeriesToolTipGenerator(int series,CategoryToolTipGenerator generator) 指定分类的 MAP 中鼠标移上的显示格式 void setSeriesItemURLGenerator(int series,CategoryURLGenerator generator) 指定分类的 MAP 中钻取链接格式 BarRenderer(AbstractCategoryItemRenderer)类: void setDrawBarOutline(boolean d

44、raw) 是否画图形边框 void setItemMargin(double percent) 每个 BAR 之间的间隔 void setMaxBarWidth(double percent) 每个 BAR 的最大宽度 void setMinimumBarLength(double min) 最短的 BAR 长度,避免数值太小而显示不出 void setPositiveItemLabelPositionFallback(ItemLabelPosition position) 无法在BAR 中显示的正数标签位置 void setNegativeItemLabelPositionFallback(ItemLabelPosition position) 无法在BAR 中显示的负数标签位置 BarRenderer3D(BarRenderer)类: void setWallPaint(Paint paint) 3D 坐标轴的墙体颜色 GroupedStackedBarRenderer(StackedBarRenderer)类: void setSeriesToGroupMap(KeyToGroupMap map)

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报