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 自 ...
随机推荐
- FOR YOU
给你 作者:余秀华 一家朴素的茶馆, 面前目光朴素的你皆为我喜欢 你的胡子,昨夜辗转的面色让我忧伤 我想带给你的,一路已经丢失得差不多 除了窗外凋谢的春色 遇见你以后,你不停地爱别人,一个接一个 我没 ...
- Linux常用软件安装
1. 修改Linux的基本配置 1.修改主机名 vi /etc/sysconfig/network NETWORKING=yes HOSTNAME=server1.itcast.cn 2.修改ip地址 ...
- HTML 教程
HTML5 标准 超文本标记语言(英语:HyperText Markup Language,简称:HTML) 是一种用于创建网页的标准标记语言. 您可以使用 HTML 来建立自己的 WEB 站点,HT ...
- facebook页面种简单测试js调用flash开放的js接口的方法
无意间折腾出来的,此方法很triky,但是很简单有效. 背景说明: facebook种内嵌的iframe无法直接访问. 解决方法: chrome浏览器为例 1.右键查看iframe源代码,此时进入if ...
- redis缓存机制【转载】
转载自:http://blog.csdn.net/acmman/article/details/53434134 redis的主从模式(1)介绍redis存储数据是在内存中运行的,运行速度比关系型数据 ...
- sed.md
SED sed是一种流编辑器,它是文本处理中非常中的工具,能够完美的配合正则表达式使用,功能不同凡响.处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用s ...
- CentOS 安装jira 6.3.6
java 目录: /usr/java/jdk1.6.0_45 tomcat 目录:/usr/tomcat-7.0.29 jira 目录: /usr/local/jira jira 访问地址: cent ...
- 百度Apollo安装说明
前言:最近在和百度Apollo合作,Apollo的人很nice,大家都在全力帮助我们解决问题.但Apollo系统有点难搞,安装起来很费劲,为了避免再次踩坑,留下笔记,流传后人,O(∩_∩)O. 1. ...
- Redis(三)内存模型
本文转载自编程迷思,原文链接 深入学习Redis(1):Redis内存模型 前言 Redis是目前最火爆的内存数据库之一,通过在内存中读写数据,大大提高了读写速度,可以说Redis是实现网站高并发不可 ...
- JDK(一)JDK集合框架
JDK中的集合框架分为两大类:Collection和Map.Collection以一组Object的形式保存元素,Map以Key-Value对的形式保存元素. 上图列出的类并不完整,只列举了平时比较常 ...