用Tableau画环形图系列(五)画圆弧图(2)

本系列导航

用Tableau画环形图系列(一)画个简单的圆

用Tableau画环形图系列(二)画同心圆

用Tableau画环形图系列(三)画环状条形图

用Tableau画环形图系列(四)画圆弧图(1)

用Tableau画环形图系列(五)画圆弧图(2)

用Tableau画环形图系列(六)画柱状环形图

用Tableau画环形图系列(七)用Tableau画尖状环形图[翻译]


关于圆弧图(Arc Chart)有多种形式,上一讲讲的是一种常见形式,前段时间看到Andy Kriebel大神的一个作品,觉得特别漂亮,就下载下来研究了一下。


用Tableau画环形图系列(五)画圆弧图(2)_第1张图片
https://public.tableau.com/profile/andy.kriebel#!/vizhome/EuropeanIrishWhiskeySalesCurves/JumpyCurvy

如果你理解了前面的文章,就会觉得特别简单,下面我们来自己做一个。

老办法,构造一张point表(两个字段link和point),值是0-180,这个不多说了

再构造一张circle表,也很简单,R随便填(可以有负数)

用Tableau画环形图系列(五)画圆弧图(2)_第2张图片

引入Tableau,用内连接连接两张表,构造出新表

构建[sin]:SIN([point] * PI() / 180) * [R]

关键就在怎么构建cos这个值,因为要使所有圆的起始点(或者结束点)都是一个点,怎么做?

构建[cos]=((COS([point] * PI() / 180))+1) * [R],关键就在这里cos先加了一个1,又要复习前面的知识了,cos(x) 返回的是 -1.0 到 1.0 之间的数,0度的时候,cos(0*pi/180)=1,那么180度的时候,cos(180*PI()/180)=-1,如果加上1,cos(180*PI()/180)+1=0,本身sin(180*PI()/180)=0,那么所有圆在180度时的值都是0,也就是结束点都是(0,0)


用Tableau画环形图系列(五)画圆弧图(2)_第3张图片

所以就结果就很明显了


用Tableau画环形图系列(五)画圆弧图(2)_第4张图片

是不是很简单。

下面有两个思考题

1.如果cos减去1是什么结果?

2,如果想做成下面的效果,该改哪里?


用Tableau画环形图系列(五)画圆弧图(2)_第5张图片

好了,环形图系列就到这里了,其实环形图有很多种形式,我也只是研究了这么几个简单的,大家有兴趣还是去多拆解Tableau Public上的作品,多多研究,会有很大收获。

此篇文章已发布到我的公众号:saodisir,有兴趣也可关注一下

你可能感兴趣的:(用Tableau画环形图系列(五)画圆弧图(2))