salesforce 零基础学习(二十六)自定义图表chart简单介绍(使用apex和VF实现)

chart在报表中经常使用到,他可以使报表结果更加直观的展现给用户。salesforce支持VF和apex代码来更好的展示chart。

chart分类:常用的图表样式有饼状图,柱状图,折线图,条形图,表盘图,雷达图,及线性系列图表等。

图表根据样式不同显示的内容不同,大概包含以下部分:

1. X,Y坐标;

2. 标题;

3. 内容及所含数量(data);

4.移入上面显示的相关提示信息(tip);

5.说明(legend)。

注:这里只是总结大概的部分,显示的部分因图表样式而有相应的差距,chart是可以高度自定义的,可以通过vf标签的属性对内容进行显示或者隐藏。

这里主要对饼状图进行描述,其他图形可以参看Page Developer的描述以及相关标签的属性介绍来自行练习。我们要实现的大概效果如下图所示。

还是以Goods__c表为例,其中一个字段为GoodsBrand__c,类型为PickList,主要有四种可选择产品类型,华为,小米,魅族以及联想。我们要做的chart为展示数据表中各个品牌所占的比例。

对此饼状图大概分析:制作此饼状图需要有数据,说明(legend),提示信息(tip)。

其中,我们使用<apex:chart>标签来封装数据,使用<apex:pieSeries>来显示数据。<apex:pieSeries>有这样两个属性,labelField展示图表上面显示的内容信息,此信息与legend的标题信息相同且legend不可以自己定义,dataField用来展示比例,即这个值占据总量的多少。默认情况下tip信息由key,value队组成,显示的key为labelField值,显示的value为dataField的值。

制作步骤:

1.Apex用于制作数据

 1 public class PieChartController {
 2     public Map<String,Integer> goodsBrandNumberMap = new Map<String,Integer>();
 3     public Set<String> goodsBrand{get;set;}
 4     public PieChartController() {
 5         Map<String, object> goodsBrandValuesMap = PickListValuesUtil.getPicklistValues('Goods__c','GoodsBrand__c');
 6         goodsBrand = goodsBrandValuesMap.keySet();
 7         List<Goods__c> goodsList = [select Id,GoodsBrand__c from Goods__c where GoodsBrand__c <> null];
 8         for(Goods__c currentGoods : goodsList) {
 9             if(goodsBrand.contains(currentGoods.GoodsBrand__c)) {
10                 if(goodsBrandNumberMap.keySet().contains(currentGoods.GoodsBrand__c)) {
11                     goodsBrandNumberMap.put(currentGoods.GoodsBrand__c,goodsBrandNumberMap.get(currentGoods.GoodsBrand__c) + 1);
12                 } else {
13                     goodsBrandNumberMap.put(currentGoods.GoodsBrand__c,1);
14                 }
15             }
16         }
17     }
18     
19     public List<Data> getGoodsBrandPieData() {
20         List<Data> pieWdegeData = new List<Data>(); 
21         for(String goodsBrandName : goodsBrandNumberMap.keySet()) {
22             Data data = new Data(goodsBrandName + '\n' + goodsBrandNumberMap.get(goodsBrandName),goodsBrandNumberMap.get(goodsBrandName),goodsBrandName);
23             pieWdegeData.add(data);
24         }
25         
26         return pieWdegeData;
27     }
28     
29     // Wrapper class
30     public class Data {
31         //label 
32         public String chartLabel { get; set; }
33         //the value of chart label
34         public Decimal valueOfChartLabel { get; set; } 
35         //tip customize
36         public String tipOfChartLabel {get;set;}
37         //tip customize
38         public Decimal tipOfLabelValue{get;set;}
39         
40         public Data(String chartLabel,Decimal valueOfChartLabel) {
41             this.chartLabel = chartLabel;
42             this.valueOfChartLabel = valueOfChartLabel;
43         }
44         
45         //if the label of tip need to customize,choose this
46         public Data(String chartLabel,Decimal valueOfChartLabel,String tipOfChartLabel) {
47             this(chartLabel,valueOfChartLabel);
48             this.tipOfChartLabel = tipOfChartLabel;
49         }
50         
51         //if both the label of tip and the value of tip need to customize ,choose this
52         public Data(String chartLabel,Decimal valueOfChartLabel,String tipOfChartLabel,Decimal tipOfLabelValue) {
53             this(chartLabel,valueOfChartLabel,tipOfChartLabel);
54             this.tipOfLabelValue = tipOfLabelValue;
55         }
56     }
57 }

由于展现的legend需要自己定义,所以我们在构造Data时要考虑图表的label以及对应的value和label提示信息以及相对应的value。Data相当于一个Property,前台通过数据绑定后在使用<apex:pieSeries>便相当于迭代器,将列表中每个Data元素取出。

2.Page页面显示数据

 1 <apex:page controller="PieChartController" title="Pie Chart"> 
 2     
 3     <apex:chart data="{!goodsBrandPieData}" height="400" width="500" colorSet="#0A224E,#BF381A,#A0D8F1,#E9AF32,#E07628"> 
 4         <apex:legend position="bottom"/> 
 5         <apex:pieSeries labelField="chartLabel" dataField="valueOfChartLabel" donut="50"> 
 6             <apex:chartLabel display="none" orientation="vertical" font="bold 18px Helvetica"/>
 7             <apex:chartTips labelField="tipOfChartLabel"/>
 8                 
 9         </apex:pieSeries> 
10     </apex:chart>
11     
12 </apex:page>

通过上述代码便可以实现上图所示的chart。

我们把Page页面做些调整,页面代码如下所示:

1 <apex:page controller="PieChartController" title="Pie Chart"> 
2     
3     <apex:chart data="{!goodsBrandPieData}" height="400" width="500"> 
4         <apex:legend position="bottom"/> 
5         <apex:pieSeries labelField="tipOfChartLabel" dataField="valueOfChartLabel" donut="50"> 
6         </apex:pieSeries> 
7     </apex:chart>
8     
9 </apex:page>

显示效果如下图所示

可以看出legend和label显示样式相同,如果需要进行相关的定制化,详见PDF中所使用标签的属性。

总结:自定义图表简单的说便是先提供数据进行绑定,然后通过需要的图表样式进行解析即可,如果需要定制一些特殊需要,详见使用的标签属性,legend标签无value等自定义的值,其值与label绑定,所以如果需要legend显示特殊的值,需要在设置Data时考虑相关的信息,在label绑定时,绑定legend需要显示的值,在对label进行自定义操作。如果篇中有错误地方欢迎指出,如果有问题欢迎留言。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏用户2442861的专栏

javascript dom学习笔记

http://blog.csdn.net/zhoulenihao/article/details/11099455

671
来自专栏Android机动车

Flutter 实战:撸半个知乎日报~HomePage

https://github.com/zhujian1989/ZhihuDailyPurifyByFlutter

812
来自专栏编程

类选择符和ID选择符

类选择符 ? HTML代码: CSS代码: div { width: 200px; height: 200px; border: 1px solid #000;...

1887
来自专栏Android开发实战

Android自定义View系列 (从小白做起) 一: 初识

很多的Android入门程序猿来说对于自定义View,可能都是比较恐惧的,其实没那么难,写的多了也就熟练了。 高手之路也是从小白做起的。

532
来自专栏小狼的世界

不同浏览器对于换行的处理

在一个容器中,如果设定了宽度,一般来说自动换行都是比较正常的,但是如果遇到了连续的英文字符,这个问题就会让人头疼。这不,我们部门的用户在测试的时候输入连续的字符...

612
来自专栏数据小魔方

数据地图系列10|excel(VBA)数据地图透明度填充法

今天要跟大家分享数据地图系列的第10篇——excel(VBA)数据地图透明度填充法。 这种方法的制作步骤难度与前一篇相比都较低,但是涉及到的VBA代码却要比前一...

4705
来自专栏文渊之博

sql 日期格式汇总

SQLserver中用convert函数转换日期格式2008-01-15 15:51SQLserver中用convert函数转换日期格式 SQL Server中...

1755
来自专栏听雨堂

异步方式访问网页

采用BackgroundWorker,在后台执行程序,往往比开新线程更简单和更加安全。 简单的使用方法 System.ComponentModel.Backgr...

1809
来自专栏柠檬先生

css3响应式布局设计——回顾

响应式设计是在不同设备下分辨率不同显示的样式就不同。 media 属性用于为不同的媒体类型规定不同的样式。根绝浏览器的宽度和高度重新渲染页面。     语法:...

1717
来自专栏Android机动车

自定义View之客服好评View

这个版本主要的任务就是完成环信客服系统的集成,上一篇文章 仿IOS下载View 也是这个版本开发需求中的一小部分,那今天介绍一下另一个小需求 客服好评。 客服好...

985

扫码关注云+社区