flex 自定义tooltip
//flex用例网址
http://thanksmister.com/2012/01/18/flex-chart-datatip-renderer/
main.mxml
<?xml version="1.0" encoding="utf-8"?>
<mx:Application
xmlns:mx="http://www.adobe.com/2006/mxml"
xmlns:slc="com.scottlogic.charts.*"
layout="horizontal"
width="400"
height="300"
viewSourceURL="srcview/index.html"
>
<mx:Script>
<![CDATA[
import mx.charts.series.items.ColumnSeriesItem;
import mx.charts.series.ColumnSeries;
import mx.charts.HitData;
import mx.collections.ArrayCollection;
[Bindable]
public var sales:ArrayCollection = new ArrayCollection([
{period: "Q1", toys: 900, electronics: 300, clothes: 400},
{period: "Q2", toys: 200, electronics: 600, clothes: 450},
{period: "Q3", toys: 500, electronics: 300, clothes: 200},
{period: "Q4", toys: 800, electronics: 100, clothes: 300}
]);
/**
*
*/
private function myDataTipFunction(hitData:HitData):String
{
var series:ColumnSeries = ColumnSeries(hitData.element);
var item:ColumnSeriesItem = ColumnSeriesItem(hitData.chartItem);
var quarter:Object = xAxis.formatForScreen(item.xValue);
var total:Number = columnSet.positiveTotalsByAxis[item.xValue];
var value:Number = Number(item.yValue) - Number(item.minValue);
var percent:Number = Math.round(value / total * 1000) / 10; // want 2 decimal place precision
return "In <b>" + quarter + "</b> there were <b>" + value + " "
+ series.displayName + "</b> units sold.<br/>This is <b>"
+ percent + "%</b> of the <b>" + total + " total</b> units sold in "
+ quarter + ".";
}
]]>
</mx:Script>
<mx:ColumnChart
dataProvider="{sales}"
width="100%"
height="100%"
showDataTips="true"
dataTipFunction="myDataTipFunction"
>
<mx:horizontalAxis>
<mx:CategoryAxis id="xAxis" categoryField="period" />
</mx:horizontalAxis>
<mx:verticalAxis>
<mx:LinearAxis id="yAxis" />
</mx:verticalAxis>
<mx:series>
<slc:ColumnSet id="columnSet" type="stacked">
<mx:ColumnSeries yField="toys" displayName="Toys" />
<mx:ColumnSeries yField="electronics" displayName="Electronics" />
<mx:ColumnSeries yField="clothes" displayName="Clothes" />
</slc:ColumnSet>
</mx:series>
</mx:ColumnChart>
</mx:Application>
ColumnSet.as
package com.scottlogic.charts
{
import flash.utils.Dictionary;
import mx.charts.series.ColumnSet;
/**
* Extension to mx.charts.series.ColumnSet to expose the
* stack totals for public use, e.g. in a data tip
* function.
*/
public class ColumnSet extends mx.charts.series.ColumnSet
implements IStackedSeries
{
/**
* Constructor
*/
public function ColumnSet()
{
super();
}
/**
* @see IStackedSeries.positiveTotalsByAxis
*/
public function get positiveTotalsByAxis():Dictionary
{
return posTotalsByPrimaryAxis;
}
/**
* @see IStackedSeries.negativeTotalsByAxis
*/
public function get negativeTotalsByAxis():Dictionary
{
return negTotalsByPrimaryAxis;
}
/**
* @see IStackedSeries.stackMaximum
*/
public function get stackMaximum():Number
{
return stackedMaximum;
}
/**
* @see IStackedSeries.stackMinimum
*/
public function get stackMinimum():Number
{
return stackedMinimum;
}
}
}
flex 自定义tooltip的更多相关文章
- Flex自定义组件开发之日周月日期选择日历控件
原文:Flex自定义组件开发之日周月日期选择日历控件 使用过DateField的我们都知道,DateField 控件是用于显示日期的文本字段,字段右侧带有日历图标.当用户在控件边框内的 ...
- Flex自定义组件、皮肤,并调用
标签:Flex 自定义组件 自定义皮肤 主应用调用模块 本程序样例学习自flex 实战教程.但因原教程代码不全,且根据个人需求有更改. 1文件列表 自定义as类Reveal.as,该类实现组件的 ...
- flex 自定义组件的编写
使用flex也很久了,也改过别人写的flex自定义组件,但是就是没有系统的研究下flex组件的编写步骤,和要注意的东西,在这里我参照一本书中的例子,好好的理解下,也为了巩固下自己对flex的理解! 1 ...
- echarts自定义tooltip提示框内容
1.echarts自定义tooltip提示框内容 https://blog.csdn.net/dreamsup/article/details/56667330 2.关于Echarts的formatt ...
- DevExpress.XtraGrid.GridControl 实现自定义tooltip
DevExpress.XtraGrid.GridControl 控件默认的tooltip显示的每一个单元格的文本值,但是实际工作中会出现各种需求.我这里就有一个列是折扣率显示的值是0-1之间的两位小数 ...
- Flex 自定义事件
一.分派自定义事件类型 任何实现flash.event.IEventDispatcher接口的对象都可以分派事件,这包括所有显示对象和一些非显示对象类.通常,对于 自定义的非显示类,可以通过扩展fla ...
- flex自定义preloader预加载进度条
flex默认的preloader已经很不错了,可是有时候还是需要自定义的. 需要在要出现自定义预加载的程序的<mx:Application>标签里加入preloader="& ...
- Flex 自定义 Zlert 组件!
说明: 原生的 Alert.show 参数,要显示的按钮你只能 Alert.OK | Alert.Cancel 这样; 自定义 Zlert 参数跟原生的 差不多,按钮写法是这样写的: {"b ...
- Flex 自定义打印控件编写
打印历来是web应用一个比较棘手的问题,幸好flex web应用是运行在flash player上的,flash player可以访问打印机,所以flex 应用可以实现比较强大的打印功能.Flex 自 ...
随机推荐
- August 02nd 2017 Week 31st Wednesday
Love means never having to say you are sorry. 爱就是永远不必说对不起. If there is ture love, you will never do ...
- [COGS 2065]学数数
2065. 学数数 ★★★☆ 输入文件:jxthree.in 输出文件:jxthree.out 简单对比时间限制:1 s 内存限制:256 MB [题目描述] 从前有一只咩,还有一只叽 ...
- Java 集合框架(常用数据结构)
早在Java 2中之前,Java就提供了特设类.比如:向量(Vector).栈(Stack).字典(Dictionary).哈希表(Hashtable)这些类(数据结构)用来存储和操作对象组.虽然这些 ...
- Java中的Scanner类
java.util.Scanner是Java5的新特征,我们可以通过Scanner类来获取用户的输入.创建Scanner对象的基本语法: Scanner s = new Scanner(System. ...
- java @XmlTransient与@Transient区别
1.@XmlTransient a.@XmlTransient 注解解决 JavaBean 属性名称与字段名称之间的名称冲突,或者用于防止字段/属性的映射 b.阻止将 JavaBean 属性映射到 X ...
- jQuery中异步请求
1.load方法 使用load()方法通过Ajax请求加载服务器中的数据,并把返回的数据放置到指定的元素中,它的调用格式为: $(selector).load(URL,data,callback); ...
- unittest 测试
unittest 测试 单元测试是用来对一个模块.一个函数或者一个类来进行正确性检验的测试工作. 比如对函数abs(),我们可以编写出以下几个测试用例: 输入正数,比如1.1.2.0.99,期待返回值 ...
- 小米root
ROOT之前,需要做几个准备工作: 首先,你需要去MIUI官网解锁,解锁教程见MIUI官网(百度搜索 MIUI解锁,第一个就是),然后根据官方指导进行解锁: 然后,因为MAX2的ROOT是卡刷,所以解 ...
- 【luogu P3258 [JLOI2014]松鼠的新家】 题解
题目链接:https://www.luogu.org/problemnew/show/P3258 谁说树剖过不去会RE呢? 我今天就是要强行树剖了 树剖强艹 #include <cstdio&g ...
- Jmeter测试实例
说明:测试某系统登陆功能,登陆中的验证码已被屏蔽,辅助工具Firebug. 1.打开被测系统准备好firebug,准备抓包登陆操作: