How to build a color-contrast-ratio checker for improved accessibility in Power Apps
tl:dr
Color contrast ratio is important for accessibility - here is how to build an in-app checker to build more accessible Power Apps
What is an color-contrast-ratio checker and why would I care?
Although Power Apps studio has a built-in Accessibility checker, which warns makers if they for example forgot an AccessibleLabel which is used by screen reader applications to announce what a control is about, it doesn’t cover any issues that might occur regarding the contrast of used colors.
This means, that makers don’t get a warning when they choose colors that don’t match accessibility standards. The Power Apps documentation recommends a color contrast ratio for texts and backgrounds of at least 4.5:1 and for large text of at least 3:1, however there is no guidance on how to calculate this ratio and even then, the information is not where makers need them - in their app.
Accessibilty is one of the most crucial design goals for every app and every website as we do not aim to proactively exclude people because we do not match their needs with appropriate features.
Idea: Color-Contrast-Ratio checker for Power Apps -in Power Apps
What if makers had an app or even a hidden screen in all of their apps where they can check contrast ratio in the early stage of app development to avoid accessibility issues that are not addressed by the Power Apps Accessibility Checker?

Requirements
- Let makers easily change the primary color and background color of their app
- Automatically calculates if the color contrast ratio is sufficient to fulfill WCAG 2.1 Success Criteria
- Informs maker about the outcome of that calculation
How to let makers easily change the primary color and background color of their app
- Insert some controls (buttons, TextLabels, Icons, TextInput, etc.) on your screen
- Insert 3 slider controls reflecting the RGB values for the primary color
- Set the
Maxproperty of all 3 sliders to 255 - Rename the sliders to sli_Red, sli_Green, and sli_Blue
- Insert a Button on the screen, rename it to btn_primaryColor
- Set its
Fillproperty toRGBA(sli_Red.Value, sli_Green.Value, sli_Blue.Value,1)- This button will now be our reference for the primary color the entire app - Insert another 3 slider controls reflecting the RGB values for the Background
- Set the
Maxproperty of all 3 sliders to 255 - Rename them accordingly
- Insert another button on the screen, rename it to btn_backgroundColor
- Set its
Fillproperty toRGBA(sli_Red_1.Value, sli_Green_1.Value, sli_Blue_1.Value,1)- This button will now be our reference for background color in the entire app - Set the
Textproperty of the btn_primaryColor to"primary color: RGB(" & sli_Red.Value & ", " & sli_Green.Value & ", " & sli_Blue.Value & " ,1) " - Set the
textproperty of the btn_backgroundColor to"background: RGB(" & sli_Red_1.Value & ", " & sli_Green_1.Value & ", " & sli_Blue_1.Value & " ,1) " - Set the
Fillproperty of your screens background tobtn_backgroundColor.Fill - Set the
Fillproperty of the buttons you inserted in step 1 tobtn_primaryColor.Fill - Set the
Colorproperty of the TextLabel you inserted in step 1 tobtn_primaryColor.Fill
If you now use the sliders for background color and primary color, you can see that the color of your two reference buttons changes and with them the entire color scheme of your app.
How to automatically calculate if the color contrast ratio is sufficient to fulfill WCAG 2.1 Success Criteria
Let’s first understand what needs to happen so that we can implement this in our app: For matching the WCAG 2.1 Success Criteria we need to take care of two important values:
- brightness difference
- color difference
The brightness difference is calculated as (299*R_pc + 587*G_pc + 114*B_pc)/1000 - (299*R_bg + 587*G_bg + 114*B_bg)/1000, where as R , G, B stands for Red, Green, Blue and _pc stand for primaryColor and _bg stands for BackgroundColor. The result of this calculation needs to be a number > 125.
In our app we will therefore calculate the brightness difference with (299*sli_Red.Value + 587*sli_Green.Value + 114*sli_Blue.Value)/1000 - (299*sli_Red_1.Value + 587*sli_Green_1.Value + sli_Blue_1.Value*114)/1000
The color difference is calculated as -((R_pc - R_bg) + (G_pc - G_bg + (B_pc - B_bg)). The result of this calculation needs to be a number > 500.
In our app we will therefore calculate the color difference with -((sli_Red.Value -sli_Red_1.Value) + (sli_Green.Value-sli_Green_1.Value ) + (sli_Blue.Value-sli_Blue_1.Value))
đź’ˇ Important: Both conditions need to be fulfilled.
How to indicate the outcome of that calculation
Easiest part is now to make the result of these calculations visible to makers:
- Insert a text label for
lblbrightnessDifferenceand set theTextproperty to the brightness formula shown above - Set the
Colorproperty toIf(Value(Self.Text) < 125, Red, Black) - Insert a text label for
lblColorDifferenceand set theTextproperty to the color formula shown above - Set the
If(Value(Self.Text) < 500, Red, Black) - Insert another text label and set the
Textproperty toIf(Value(lblColorDifference.Text) < 500 Or Value(lblBrightnessDifference.Text) <125, "failed color contrast check according to W3.org", "passed color contrast check according to W3.org")
Update: v1.1 of the color contrast checker is now available on GitHub
I worked on additional features:
- display the hex color value of an RGBA value
- have Textinput fields for accurate input of RGBA values
hexcolor - Regex to the rescue
Unfortunately, there is no easy built-in function to convert an RGBA value into a hex color value in Power Apps, still it is doable! I wrote in a separate post on how to get hex-color value in Power Apps
Input fields
- Create an input field for every slider, I will use the
sli_Redas an example: - Set the OnChange of the input field to
If(
Value(Self.Text) > 255 || Value(Self.Text) < 0,
Notify(
"please enter a value between 0 and 255",
NotificationType.Error
)
);
Set(
defaultRed,
Value(Self.Text)
);
- Set the Default property of the input field to
sli_Red.Value - Set the Default property of the slider
defaultRed
The result can look something like this:

You can find the updated source code and solution in my personal GitHub account, a PR to PNP/powerapps-samples is pending, I will update accordingly once this is processed.
What are your thoughts?
How do you improve color contrast ratio in your apps and make sure that you comply to WCAG 2.1 Success Criteria? Let me know on twitter. If you found this blog post useful, please also subscribe to my newsletter - news coming about every 2 months, I promise to not spam you!
Published on:
Learn moreRelated posts
How To Create Copilot Custom UI Widgets In Power Apps
You can use Copilot to show custom UI widgets built-in Power Apps. UI widgets replace ... The post How To Create Copilot Custom UI Widgets In ...
Power Apps Fundamentals + Microsoft Fabric Integration Series # 1: Introduction to Power Apps and Microsoft Fabric: Building a Unified Business Application Platform
Introduction Modern organizations generate enormous amounts of operational and analytical data every day. Business users need applications to ...
Power Apps- Enhance row summaries in model-driven apps
We are announcing the ability to enhance row summaries in model-driven apps in Power Apps. This feature will reach general availability on Jun...
Calling Dataverse Actions and Functions from Power Apps Code Apps
When building Power Apps code apps, one of the most powerful things you can do is reach directly into Dataverse to trigger business logic. Whe...
Respond to a Power Automate Flow Approval in a Power Apps Custom Page or Canvas App
How to respond to Power Automate approval requests directly within a Power Apps custom page or canvas app, rather than email buttons or in Mi...
Inside Built-In and Custom Copilot UI Widgets powered by Power Apps
Custom app-powered Widgets feels like one of those shifts that will change how we think about Copilot experiences. Until recently, a lot of th...
Video: Transform Copilot With Custom UI Widgets Built In Power Apps
What you’re looking at here in Copilot is an interactive widget that I built with ... The post Video: Transform Copilot With Custom UI Widgets...
How to Automate Project Assignment in Dynamics 365 Using Power Automate and Power Apps Code Apps
This blog demonstrates how to automate project assignments in Microsoft Dynamics 365 using Microsoft Power Automate and Power Apps Code Apps, ...
Microsoft Power Automate – Build better forms with integrated Power Apps
We are announcing the ability to build better forms with integrated Power Apps in Power Automate. This feature will reach public preview on Ma...