在刘万祥老师那里看到一种质感华丽的立体滑珠图,Power BI一个度量值也可以实现,效果如下:
本文以一个卡片滑珠图为例,条形图原理类似。
首先,在PPT画一个凹陷的圆角矩形,作为滑珠图的背景。画图过程使用了PPT的阴影效果(教程可网上搜索)。
接着将这个矩形另存为SVG格式。
记事本打开该文件,双引号替换为单引号,复制里面的代码。在Power BI中新建一个度量值,粘贴该代码,无需理解代码含义,只需要知道它是你做好的矩形。
定义一个变量X,参考矩形的宽度,使得业绩达成率按比例进行宽度变化。
在度量值的尾部定义一个圆,圆心的X轴位置引用上面定义的变量,使用
RadialGradient做出渐变效果。
添加一条数据连接细线和数据标签。
完成后放入Html content这个图表即可正常显示。完整度量值在最下方,读者可以直接使用。
完整度量值:
滑珠图带数据标签 =
VAR X=IF([业绩达成率]<0,84.5,IF([业绩达成率]>1,1989.5,84.5+1905*[业绩达成率]))
Return
/*
* 提示:该行代码过长,系统自动注释不进行高亮。一键复制会移除系统注释
* "<svg viewbox='0 0 2074 169' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' overflow='hidden'><defs><clipPath id='clip0'><rect x='959' y='385' width='2074' height='169'/></clipPath><clipPath id='clip1'><path d='M959 413.168C959 397.611 971.611 385 987.168 385L3004.83 385C3020.39 385 3033 397.611 3033 413.168L3033 525.832C3033 541.389 3020.39 554 3004.83 554L987.168 554C971.611 554 959 541.389 959 525.832Z' fill-rule='evenodd' clip-rule='evenodd'/></clipPath><clipPath id='clip2'><rect x='-2.92966e-05' y='0' width='926' height='123.728'/></clipPath><image width='926' height='123' xlink:href='' preserveAspectRatio='none' id='img3'></image><clipPath id='clip4'><path d='M-9.43567e-06 3.99351e-06 926 3.99351e-06 926 123 0 123Z' fill-rule='evenodd' clip-rule='evenodd'/></clipPath><image width='2074' height='169' xlink:href='' preserveAspectRatio='none' id='img5'></image><clipPath id='clip6'><rect x='959' y='385' width='2074' height='169'/></clipPath></defs><g clip-path='url(#clip0)' transform='translate(-959 -385)'><g clip-path='url(#clip1)'><path d='M574.326 647.835C574.326 632.279 586.937 619.667 602.494 619.667L1818.47 619.667C1834.02 619.667 1846.64 632.279 1846.64 647.835L1846.64 760.499C1846.64 776.055 1834.02 788.667 1818.47 788.667L602.494 788.667C586.937 788.667 574.326 776.055 574.326 760.499Z' fill='#D1D9E6' fill-rule='evenodd' transform='matrix(1.63011 0 0 1 22.7885 -234.667)'/><g clip-path='url(#clip2)' transform='matrix(2.23974 0 0 1.37398 959 385)'><g clip-path='url(#clip4)'><use width='100%' height='100%' xlink:href='#img3' transform='matrix(1 0 0 1 -9.43567e-06 3.99351e-06)'></use></g></g></g><g clip-path='url(#clip6)'><use width='100%' height='100%' xlink:href='#img5' transform='translate(959 385)'></use></g></g>
*/
<defs>
<RadialGradient id='wu'>
<Stop offset='0%' style='stop-color:white'/>
<Stop offset='100%' style='stop-color:Grey'/>
</RadialGradient>
</defs>
<circle cx='"&X&"' cy='84.5' r='70' fill='url(#wu)' />
<line x1='0' y1='84.5' x2='"&X-70&"' y2='84.5' stroke='black' />
<text x='"&X&"' y='100.5' text-anchor='middle' font-size='50'>"&ROUND([业绩达成率]*100,0)&"%"&"</text>
</svg>"