AccessibleColors 1.0.6

There is a newer version of this package available.
See the version list below for details.
dotnet add package AccessibleColors --version 1.0.6                
NuGet\Install-Package AccessibleColors -Version 1.0.6                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="AccessibleColors" Version="1.0.6" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add AccessibleColors --version 1.0.6                
#r "nuget: AccessibleColors, 1.0.6"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install AccessibleColors as a Cake Addin
#addin nuget:?package=AccessibleColors&version=1.0.6

// Install AccessibleColors as a Cake Tool
#tool nuget:?package=AccessibleColors&version=1.0.6                

AccessibleColors

NuGet NuGet Downloads Build License

AccessibleColors is a lightweight C# library that provides O(1) methods to compute WCAG-compliant contrast colors for foreground text or icons given a background color. It instantly returns a suitable foreground color that meets or exceeds the standard WCAG 2.2 contrast ratio of 4.5:1.

In addition to single contrast colors, AccessibleColors also offers a dynamic color ramp generator to produce a sequence ("ramp") of colors all meeting WCAG standards against a given background. This is especially useful for UI states (hover, pressed, disabled) or theming scenarios where you need multiple related accessible colors derived from a single base color.

Key Features

  • WCAG Compliance: Ensures at least a 4.5:1 contrast ratio by default, helping you create accessible user interfaces.
  • O(1) Performance (Single Contrast Calculation): Uses a precomputed lookup table (LUT) for sRGB-to-linear conversions, allowing instant single-color calculations.
  • Dynamic Accessible Ramps: Generate a sequence of WCAG-compliant colors from a single base color. The algorithm uses minimal searching and a few small adjustments to ensure compliance for every color in the ramp.
  • No External Dependencies: Relies only on System.Drawing types for colors, making integration straightforward.
  • Simple API:
    • A single GetContrastColor extension method on Color and an IsCompliant method let you easily ensure accessibility for individual colors.
    • A GenerateAccessibleRamp method to produce an entire ramp of related colors that remain accessible.

Getting Started

  1. Install: Add the library as a reference to your project. Since it's published on NuGet:

    dotnet add package AccessibleColors
    
  2. Use for Single Contrast Colors:

    using System.Drawing;
    using AccessibleColors;
    
    // Suppose you have a background color:
    var background = Color.FromArgb(255, 0, 0); // Bright red
    
    // Get a compliant foreground color:
    Color foreground = background.GetContrastColor();
    
    // Check compliance explicitly if needed:
    bool isAccessible = WcagContrastColor.IsCompliant(background, foreground);
    
  3. Generate Accessible Color Ramps:

    using System.Drawing;
    using AccessibleColors;
    
    // Generate a 5-step ramp suitable for dark mode UI:
    Color baseColor = Color.FromArgb(0, 120, 215); // Your brand accent
    int steps = 5;
    bool darkMode = true;
    
    IReadOnlyList<Color> ramp = AccessibleColors.GenerateAccessibleRamp(baseColor, steps, darkMode);
    
    // Each color in 'ramp' should meet WCAG compliance against the chosen background.
    // Use them for various UI states or theme elements.
    
  4. Integrate Into Your UI:

    Use GetContrastColor and GenerateAccessibleRamp anywhere you need accessible colors dynamically�custom themes, responsive adjustments, or design tools.

    For example:

    // Suppose you have a brand accent color and you want to theme your app's buttons for dark mode.
    // First, generate a 5-step accessible ramp:
    var baseAccent = Color.FromArgb(0, 120, 215);
    bool darkMode = true;
    int steps = 5;
    
    IReadOnlyList<Color> accessibleRamp = AccessibleColors.GenerateAccessibleRamp(baseAccent, steps, darkMode);
    
    // Now assign these ramp colors to different states of a custom button:
    myButton.NormalColor = accessibleRamp[0];
    myButton.HoverColor = accessibleRamp[1];
    myButton.PressedColor = accessibleRamp[2];
    myButton.FocusColor = accessibleRamp[3];
    myButton.DisabledColor = accessibleRamp[4];
    
    // Each color in the ramp maintains WCAG contrast standards against the chosen background,
    // ensuring your button remains readable and visually consistent in all interactive states.
    
    // For icons, text, or other elements over a known background, directly use GetContrastColor:
    var bg = Color.FromArgb(32, 32, 32); // Dark background
    var iconColor = bg.GetContrastColor(); 
    myIcon.ForeColor = iconColor; // Ensures the icon remains visible and accessible.
    

By leveraging GenerateAccessibleRamp and GetContrastColor, you ensure that every UI element�whether a button state or an icon�is accessible, readable, and adheres to WCAG guidelines, even as the theme or background colors change.

Example

using System.Drawing;
using AccessibleColors;

// Single Contrast Example:
var bg = Color.FromArgb(128,128,128); // Mid-gray background
var fg = bg.GetContrastColor();

Console.WriteLine($"Foreground: {fg}");
bool compliant = WcagContrastColor.IsCompliant(bg, fg);
Console.WriteLine($"Is compliant: {compliant}");

// Ramp Example:
var brandAccent = Color.FromArgb(50, 50, 50);
var rampColors = AccessibleColors.GenerateAccessibleRamp(brandAccent, 5, darkMode: false);
foreach (var c in rampColors)
{
    Console.WriteLine($"Ramp color: {c}, Compliant: {WcagContrastColor.IsCompliant(Color.White, c)}");
}

Why This Matters

Accessibility is not just a nice-to-have; it's an essential part of building inclusive applications. Ensuring proper contrast ratios improves readability for everyone, including users with visual impairments. AccessibleColors automates these standards:

  • Single Contrast Calculations: Instantly determine a compliant foreground color for any given background.
  • Ramps for Theming: Dynamically produce multiple related colors that all maintain compliance, streamlining UI state and theme development.

Contributing

Contributions are welcome! Feel free to open issues, suggest features, or submit pull requests.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

    • No dependencies.
  • net9.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.10 91 12/8/2024
1.0.9 86 12/8/2024
1.0.8 94 12/8/2024
1.0.7 96 12/8/2024
1.0.6 82 12/8/2024
1.0.5 89 12/7/2024
1.0.4 89 12/7/2024