Screen orientation calculation in Google Data Studio
data:image/s3,"s3://crabby-images/c9d7e/c9d7e50cd3a0641683c8bf8abfdaff3f9287c4b8" alt=""
If you’re just here for the screen orientation CASE formula to use in Google Data Studio, here it is:
CASE
WHEN CAST(REGEXP_REPLACE(Screen Resolution, 'x.*', '') AS NUMBER)<CAST(REGEXP_REPLACE(Screen Resolution, '.*x', '') AS NUMBER) THEN "Portrait"
ELSE "Landscape"
END
Code language: PHP (php)
Digging into it a bit further, the way tis works is that it takes the bit before the ‘x’ of the Screen Resolution dimension (the x-axis), and sees if it’s smaller than the bit after the ‘x’ (the y-axis). So if the x-axis is less than the y-axis the screen orientation is portrait, otherwise it’s landscape.
I’m using the Universal Analytics dimension ‘Screen Resolution’ in this example, but you can swap out that for any other reference you have, as long as it has the same format of ‘AxB’ – i.e. 900×800. You can even swap out the ‘x’ if there is another delimiter in your data. This screen orientation calculation is agnostic and easily changed to fit whatever your data looks like.
In Data Studio, you can add this in the data source itself, or as a custom calculation in any chart as such:
data:image/s3,"s3://crabby-images/4f1ed/4f1edcab61ba5f79c3581f33aebbcf68acc662f3" alt="Data Studio interface with the calculation editor open with the formula for screen orientation visible"
Using this newly created dimension, you can use them in charts to break down any data into landscape and portrait.
data:image/s3,"s3://crabby-images/34cf3/34cf3aade1b561d9c030a05c30301753f4952572" alt="Data Studio bar and pie charts showing screen orientation (landscape and portrait) by day"
It’s also useful in tables where you can use it as a filter to give the viewer a different way to view device data. For example:
data:image/s3,"s3://crabby-images/7f84f/7f84fd1751a193a073c2117f56e3417b93f19d22" alt="Data Studio table showing a filter control for screen orientation with both portrait and landscape selected"
data:image/s3,"s3://crabby-images/0b230/0b230131fbb88773f6715cbf097097db9f360755" alt="Data Studio table showing a filter control for screen orientation with portrait selected"
A small improvement on the formula at the top of this post is below where it accounts for square resolutions too! Not that it occurs frequently to be honest, but it’s all about being precise.
CASE
WHEN CAST(REGEXP_REPLACE(Screen Resolution, 'x.*', '') AS NUMBER)<CAST(REGEXP_REPLACE(Screen Resolution, '.*x', '') AS NUMBER) THEN "Portrait"
WHEN CAST(REGEXP_REPLACE(Screen Resolution, 'x.*', '') AS NUMBER)>CAST(REGEXP_REPLACE(Screen Resolution, '.*x', '') AS NUMBER) THEN "Landscape"
ELSE "Square"
END
Code language: PHP (php)
They do exist though:
data:image/s3,"s3://crabby-images/af34c/af34cca78f0b45cbc109a5000c6f09710ee993a4" alt="Data Studio table showing a filter control for screen orientation with 'square' selected"
We cover this example and lots of others in our Data Studio Kickstarter training course. If you’d like to book in the training for your team, or have any questions about it, please get in touch.
Daniel Perry-Reed
Subscribe to our newsletter:
Further reading
data:image/s3,"s3://crabby-images/56490/56490ad18418675d0b34a3c112cba06ede707fc7" alt="layering data studio scorecards"
How to deal with the GA4 Data API quota limitations in Looker Studio
data:image/s3,"s3://crabby-images/c9d7e/c9d7e50cd3a0641683c8bf8abfdaff3f9287c4b8" alt="5 new GA4 features Google should introduce"
Calculating Session Days in Google Data Studio
data:image/s3,"s3://crabby-images/4a019/4a019785937474c1416d7ec2102e8b261f6413e2" alt="Streaming to Google BigQuery"