首页 > 网站 > WEB开发 > 正文

16.1.创建一个图表

2024-04-27 13:52:21
字体:
来源:转载
供稿:网友
16.1.1. 问题
我想在程序中添加一个图表。
16.1.2. 解决办法
首先要创建目标类型的图表,然后为该类型的图表添加一个合适的CharSeries 对象,最后为该图表绑定数据提供器(dataProvider)。
16.1.3. 讨论
图表有多种类型,在使用之前必须清楚工具箱中有哪些图表可供调用。

每一种图表都有一个ChartSeries 对象与之对应。要将数据显式地表示为某个特定的图表,就要先添加对应的数列类型然后绑定到一个数据提供器上。ChartSeries 对象定义了在图表的x 轴和y 轴上显示何种数据以及数据列的名称。数据列名称可以添加滤镜来显示,包括阴影模糊或者发光的效果。

根据数据的不同格式,你可能需要自定义一个横向或纵向的坐标。如果数据是一个集合,如日期、国家、人,你就需要使用类坐标(CategoryAxis)。如果数据是单纯的数字,就要使用线性坐标(LinearAxis)。

图表的数据提供器可以是一个数组或多个类的集合,也可以是XMLList 对象。如果你要在图表标签上设置一个数据提供器,那么数据列对象就会继承这个数据提供器,或者你可以选择为每个数据列对象单独地指定一个数据提供器。不同的数据列可以使用不同的数据提供器。一个图表不需要使用数据提供器里面的所有数据,可以只使用指定的部分数据。

可以用与以下代码创建条状图和饼状图:
+展开
-XML
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"
layout="horizontalbackgroundColor="0xFFFFFF">

<mx:Script>
<![CDATA[
// a basic data set
[Bindable] public var chartDP:Array = [
{day:'Monday',rainfall:10,elevation:100,temperature:78},
{day:'Tuesday',rainfall:7,elevation:220,temperature:66},
{day:'Wednesday',rainfall:5,elevation:540,temperature:55},
{day:'Thursday',rainfall:8,elevation:60,temperature:84},
{day:'Friday',rainfall:11,elevation:390,temperature:52},
{day:'Saturday',rainfall:12,elevation:790,temperature:45},
{day:'Sunday',rainfall:14,elevation:1220,temperature:24}
];

]]>
</mx:Script>
<mx:ToggleButtonBar dataProvider="{simpleCharts}"
direction="vertical" />

<mx:ViewStack id="simpleCharts" >
<mx:Canvas label="Bar">
<mx:BarChart dataProvider="{chartDP}" >
<mx:verticalAxis>
<mx:CategoryAxis
dataProvider="{chartDP}"
categoryField="day" />

</mx:verticalAxis>
<mx:series>
<!-- bar chart uses a BarSeries -->
<mx:BarSeries
yField="dayxField="rainfall"
displayName="day" />

</mx:series>
</mx:BarChart>
</mx:Canvas>
<mx:Canvas label="Pie">
<mx:PieChart dataProvider="{chartDP}" >
<!-- no axes need to be defined in a pie chart -->
<mx:series>
<!-- pie chart uses a pie series -->
<mx:PieSeries
field="rainfall"
nameField="day"
labelPosition="callout"
displayName="rainfall" />

</mx:series>
</mx:PieChart>
</mx:Canvas>
</mx:ViewStack>
</mx:Application>
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表