Power BI: toggle button to switch between linear and log scale
There are 2 ways to switch between linear and log scale:
- we can use bookmarks to switch between 2 different charts
- we can use DAX to enable/disable log scale on a chart
I’ll show how we can use DAX.
Let’s say we have Data table with Data[Day] and Data[Value] columns and we want to show this data on a linear graph.
Add Data[Day] column to the Axis field and Data[Value] column to the Values field of a Line chart visual:
data:image/s3,"s3://crabby-images/e0758/e0758d12c438edfe02c78f57c07b2419ef5ae947" alt=""
Then change Y axis scale type to Log:
data:image/s3,"s3://crabby-images/4b3a1/4b3a19d989b6804cf46b075cc844033c070fc4f1" alt=""
We have a chart with Log scale. The only problem – Power BI doesn’t allow to change scale type dynamically. But there is a workaround.
Zero values are not allowed on Log scale. If there is any point with value = 0 on a line, then Power BI will switch Log scale back to Linear scale automatically. So, we need a measure that will return either 0 or BLANK() depends of our ‘toggle button’ state.
We will use a slicer as a ‘toggle button’.
Create a table (I used DAX table) with only one column and two values (“Linear” and “Log”):
Log / Linear Switch :=DATATABLE ( “Scale”, STRING, { { “Linear” }, { “Log” } } )
Now use this table to create a slicer:
data:image/s3,"s3://crabby-images/34b43/34b43b4a5c9921ffe350b0cfe02cf32d4875ad98" alt=""
Make sure it’s a single select horizontal slicer:
data:image/s3,"s3://crabby-images/a3ac4/a3ac44deb2706541487fe8b2ddf635b514970cbc" alt=""
data:image/s3,"s3://crabby-images/3624b/3624bc7f1e12a8b3e2592380059e5a0005b83836" alt=""
data:image/s3,"s3://crabby-images/8d391/8d3916cb974fcd4038dc8ed024f513743b73957f" alt=""
Now create a measure:
Scale Value :=VAR _scale =
SELECTEDVALUE ( ‘Log / Linear Switch'[Scale], “Log” )
VAR _blank0 =
IF ( SELECTEDVALUE ( Data[Day] ) = 1, 0, BLANK () )
VAR _result =
SWITCH ( _scale, “Log”, BLANK (), “Linear”, _blank0 )
RETURN
_result
This measure returns BLANK() values if “Log” value selected on the slicer and 0 (only for Data[Day] = 1, because we need only one point with Value = 0 to change graph scale to “Linear”) if “Linear” value selected on the slicer.
Add this measure to the graph. I also added a table visual with Data[Day] and [Scale Value] columns to show what values the measure returns depends on our ‘toggle button’ slicer (only for demonstration purpose):
data:image/s3,"s3://crabby-images/b99f0/b99f0627cd6e9358d81a84902d4cf402d7504caf" alt=""
When “Log” selected on the slicer, the measure returns only BLANK() values and doesn’t affect the chart at all.
Now select “Linear”:
data:image/s3,"s3://crabby-images/7a294/7a294f2765d64253295eb64e72c46300bf38c461" alt=""
Power BI changed axis Y to linear and we see our [Scale Value] = 0 point on the graph.
Final touches.
Make [Scale Value] point invisible (e.g. change it’s color to white):
data:image/s3,"s3://crabby-images/84835/84835459501348a1626d09dc1a8caab2794498d5" alt=""
And create one more measure:
Title Log / Linear Chart :=VAR _scale =
SELECTEDVALUE ( ‘Log / Linear Switch'[Scale], “Log” )
VAR _title = “Value by day (“ & _scale & ” scale)”
RETURN
_title
Use this measure as a title for the chart:
data:image/s3,"s3://crabby-images/7300f/7300ff2994e22d969879bd93c9d520e95196ab44" alt=""
data:image/s3,"s3://crabby-images/48676/4867630e3fa1e7efc68a4be4f4bfcaefacf48b20" alt=""