| // Copyright 2014 The Flutter Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| import 'dart:ui' show Brightness, Color; |
| |
| import '../../foundation.dart'; |
| import '../widgets/basic.dart'; |
| import '../widgets/framework.dart'; |
| import '../widgets/media_query.dart'; |
| import 'interface_level.dart'; |
| import 'theme.dart'; |
| |
| // Examples can assume: |
| // late Widget child; |
| // late BuildContext context; |
| |
| /// A palette of [Color] constants that describe colors commonly used when |
| /// matching the iOS platform aesthetics. |
| /// |
| /// ## Color palettes |
| /// |
| /// ### Basic Colors |
| /// ![](https://flutter.github.io/assets-for-api-docs/assets/cupertino/cupertino_basic_colors.png) |
| /// |
| /// ### Active Colors |
| /// ![](https://flutter.github.io/assets-for-api-docs/assets/cupertino/cupertino_active_colors.png) |
| /// |
| /// ### System Colors |
| /// ![](https://flutter.github.io/assets-for-api-docs/assets/cupertino/cupertino_system_colors_1.png) |
| /// ![](https://flutter.github.io/assets-for-api-docs/assets/cupertino/cupertino_system_colors_2.png) |
| /// ![](https://flutter.github.io/assets-for-api-docs/assets/cupertino/cupertino_system_colors_3.png) |
| /// |
| /// ### Label Colors |
| /// ![](https://flutter.github.io/assets-for-api-docs/assets/cupertino/cupertino_label_colors.png) |
| /// |
| /// ### Background Colors |
| /// ![](https://flutter.github.io/assets-for-api-docs/assets/cupertino/cupertino_background_colors.png) |
| /// |
| abstract final class CupertinoColors { |
| /// iOS 13's default blue color. Used to indicate active elements such as |
| /// buttons, selected tabs and your own chat bubbles. |
| /// |
| /// This is SystemBlue in the iOS palette. |
| static const CupertinoDynamicColor activeBlue = systemBlue; |
| |
| /// iOS 13's default green color. Used to indicate active accents such as |
| /// the switch in its on state and some accent buttons such as the call button |
| /// and Apple Map's 'Go' button. |
| /// |
| /// This is SystemGreen in the iOS palette. |
| static const CupertinoDynamicColor activeGreen = systemGreen; |
| |
| /// iOS 13's orange color. |
| /// |
| /// This is SystemOrange in the iOS palette. |
| static const CupertinoDynamicColor activeOrange = systemOrange; |
| |
| /// Opaque white color. Used for backgrounds and fonts against dark backgrounds. |
| /// |
| /// This is SystemWhiteColor in the iOS palette. |
| /// |
| /// See also: |
| /// |
| /// * [material.Colors.white], the same color, in the Material Design palette. |
| /// * [black], opaque black in the [CupertinoColors] palette. |
| static const Color white = Color(0xFFFFFFFF); |
| |
| /// Opaque black color. Used for texts against light backgrounds. |
| /// |
| /// This is SystemBlackColor in the iOS palette. |
| /// |
| /// See also: |
| /// |
| /// * [material.Colors.black], the same color, in the Material Design palette. |
| /// * [white], opaque white in the [CupertinoColors] palette. |
| static const Color black = Color(0xFF000000); |
| |
| /// Used in iOS 10 for light background fills such as the chat bubble background. |
| /// |
| /// This is SystemLightGrayColor in the iOS palette. |
| static const Color lightBackgroundGray = Color(0xFFE5E5EA); |
| |
| /// Used in iOS 12 for very light background fills in tables between cell groups. |
| /// |
| /// This is SystemExtraLightGrayColor in the iOS palette. |
| static const Color extraLightBackgroundGray = Color(0xFFEFEFF4); |
| |
| /// Used in iOS 12 for very dark background fills in tables between cell groups |
| /// in dark mode. |
| // Value derived from screenshot from the dark themed Apple Watch app. |
| static const Color darkBackgroundGray = Color(0xFF171717); |
| |
| /// Used in iOS 13 for unselected selectables such as tab bar items in their |
| /// inactive state or de-emphasized subtitles and details text. |
| /// |
| /// Not the same grey as disabled buttons etc. |
| /// |
| /// This is the disabled color in the iOS palette. |
| static const CupertinoDynamicColor inactiveGray = CupertinoDynamicColor.withBrightness( |
| debugLabel: 'inactiveGray', |
| color: Color(0xFF999999), |
| darkColor: Color(0xFF757575), |
| ); |
| |
| /// Used for iOS 13 for destructive actions such as the delete actions in |
| /// table view cells and dialogs. |
| /// |
| /// Not the same red as the camera shutter or springboard icon notifications |
| /// or the foreground red theme in various native apps such as HealthKit. |
| /// |
| /// This is SystemRed in the iOS palette. |
| static const Color destructiveRed = systemRed; |
| |
| /// A blue color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemBlue](https://developer.apple.com/documentation/uikit/uicolor/3173141-systemblue), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemBlue = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemBlue', |
| color: Color.fromARGB(255, 0, 122, 255), |
| darkColor: Color.fromARGB(255, 10, 132, 255), |
| highContrastColor: Color.fromARGB(255, 0, 64, 221), |
| darkHighContrastColor: Color.fromARGB(255, 64, 156, 255), |
| ); |
| |
| /// A green color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemGreen](https://developer.apple.com/documentation/uikit/uicolor/3173144-systemgreen), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemGreen = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemGreen', |
| color: Color.fromARGB(255, 52, 199, 89), |
| darkColor: Color.fromARGB(255, 48, 209, 88), |
| highContrastColor: Color.fromARGB(255, 36, 138, 61), |
| darkHighContrastColor: Color.fromARGB(255, 48, 219, 91), |
| ); |
| |
| /// A mint color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemMint](https://developer.apple.com/documentation/uikit/uicolor/3852741-systemmint), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemMint = |
| CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemMint', |
| color: Color.fromARGB(255, 0, 199, 190), |
| darkColor: Color.fromARGB(255, 99, 230, 226), |
| highContrastColor: Color.fromARGB(255, 12, 129, 123), |
| darkHighContrastColor: Color.fromARGB(255, 102, 212, 207), |
| ); |
| |
| /// An indigo color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemIndigo](https://developer.apple.com/documentation/uikit/uicolor/3173146-systemindigo), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemIndigo = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemIndigo', |
| color: Color.fromARGB(255, 88, 86, 214), |
| darkColor: Color.fromARGB(255, 94, 92, 230), |
| highContrastColor: Color.fromARGB(255, 54, 52, 163), |
| darkHighContrastColor: Color.fromARGB(255, 125, 122, 255), |
| ); |
| |
| /// An orange color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemOrange](https://developer.apple.com/documentation/uikit/uicolor/3173147-systemorange), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemOrange = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemOrange', |
| color: Color.fromARGB(255, 255, 149, 0), |
| darkColor: Color.fromARGB(255, 255, 159, 10), |
| highContrastColor: Color.fromARGB(255, 201, 52, 0), |
| darkHighContrastColor: Color.fromARGB(255, 255, 179, 64), |
| ); |
| |
| /// A pink color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemPink](https://developer.apple.com/documentation/uikit/uicolor/3173148-systempink), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemPink = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemPink', |
| color: Color.fromARGB(255, 255, 45, 85), |
| darkColor: Color.fromARGB(255, 255, 55, 95), |
| highContrastColor: Color.fromARGB(255, 211, 15, 69), |
| darkHighContrastColor: Color.fromARGB(255, 255, 100, 130), |
| ); |
| |
| /// A brown color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemBrown](https://developer.apple.com/documentation/uikit/uicolor/3173142-systembrown), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemBrown = |
| CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemBrown', |
| color: Color.fromARGB(255, 162, 132, 94), |
| darkColor: Color.fromARGB(255, 172, 142, 104), |
| highContrastColor: Color.fromARGB(255, 127, 101, 69), |
| darkHighContrastColor: Color.fromARGB(255, 181, 148, 105), |
| ); |
| |
| /// A purple color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemPurple](https://developer.apple.com/documentation/uikit/uicolor/3173149-systempurple), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemPurple = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemPurple', |
| color: Color.fromARGB(255, 175, 82, 222), |
| darkColor: Color.fromARGB(255, 191, 90, 242), |
| highContrastColor: Color.fromARGB(255, 137, 68, 171), |
| darkHighContrastColor: Color.fromARGB(255, 218, 143, 255), |
| ); |
| |
| /// A red color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemRed](https://developer.apple.com/documentation/uikit/uicolor/3173150-systemred), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemRed = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemRed', |
| color: Color.fromARGB(255, 255, 59, 48), |
| darkColor: Color.fromARGB(255, 255, 69, 58), |
| highContrastColor: Color.fromARGB(255, 215, 0, 21), |
| darkHighContrastColor: Color.fromARGB(255, 255, 105, 97), |
| ); |
| |
| /// A teal color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemTeal](https://developer.apple.com/documentation/uikit/uicolor/3173151-systemteal), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemTeal = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemTeal', |
| color: Color.fromARGB(255, 90, 200, 250), |
| darkColor: Color.fromARGB(255, 100, 210, 255), |
| highContrastColor: Color.fromARGB(255, 0, 113, 164), |
| darkHighContrastColor: Color.fromARGB(255, 112, 215, 255), |
| ); |
| |
| /// A cyan color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemCyan](https://developer.apple.com/documentation/uikit/uicolor/3852740-systemcyan), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemCyan = |
| CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemCyan', |
| color: Color.fromARGB(255, 50, 173, 230), |
| darkColor: Color.fromARGB(255, 100, 210, 255), |
| highContrastColor: Color.fromARGB(255, 0, 113, 164), |
| darkHighContrastColor: Color.fromARGB(255, 112, 215, 255), |
| ); |
| |
| /// A yellow color that can adapt to the given [BuildContext]. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemYellow](https://developer.apple.com/documentation/uikit/uicolor/3173152-systemyellow), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemYellow = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemYellow', |
| color: Color.fromARGB(255, 255, 204, 0), |
| darkColor: Color.fromARGB(255, 255, 214, 10), |
| highContrastColor: Color.fromARGB(255, 160, 90, 0), |
| darkHighContrastColor: Color.fromARGB(255, 255, 212, 38), |
| ); |
| |
| /// The base grey color. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemGray](https://developer.apple.com/documentation/uikit/uicolor/3173143-systemgray), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemGrey = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemGrey', |
| color: Color.fromARGB(255, 142, 142, 147), |
| darkColor: Color.fromARGB(255, 142, 142, 147), |
| highContrastColor: Color.fromARGB(255, 108, 108, 112), |
| darkHighContrastColor: Color.fromARGB(255, 174, 174, 178), |
| ); |
| |
| /// A second-level shade of grey. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemGray2](https://developer.apple.com/documentation/uikit/uicolor/3255071-systemgray2), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemGrey2 = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemGrey2', |
| color: Color.fromARGB(255, 174, 174, 178), |
| darkColor: Color.fromARGB(255, 99, 99, 102), |
| highContrastColor: Color.fromARGB(255, 142, 142, 147), |
| darkHighContrastColor: Color.fromARGB(255, 124, 124, 128), |
| ); |
| |
| /// A third-level shade of grey. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemGray3](https://developer.apple.com/documentation/uikit/uicolor/3255072-systemgray3), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemGrey3 = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemGrey3', |
| color: Color.fromARGB(255, 199, 199, 204), |
| darkColor: Color.fromARGB(255, 72, 72, 74), |
| highContrastColor: Color.fromARGB(255, 174, 174, 178), |
| darkHighContrastColor: Color.fromARGB(255, 84, 84, 86), |
| ); |
| |
| /// A fourth-level shade of grey. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemGray4](https://developer.apple.com/documentation/uikit/uicolor/3255073-systemgray4), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemGrey4 = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemGrey4', |
| color: Color.fromARGB(255, 209, 209, 214), |
| darkColor: Color.fromARGB(255, 58, 58, 60), |
| highContrastColor: Color.fromARGB(255, 188, 188, 192), |
| darkHighContrastColor: Color.fromARGB(255, 68, 68, 70), |
| ); |
| |
| /// A fifth-level shade of grey. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemGray5](https://developer.apple.com/documentation/uikit/uicolor/3255074-systemgray5), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemGrey5 = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemGrey5', |
| color: Color.fromARGB(255, 229, 229, 234), |
| darkColor: Color.fromARGB(255, 44, 44, 46), |
| highContrastColor: Color.fromARGB(255, 216, 216, 220), |
| darkHighContrastColor: Color.fromARGB(255, 54, 54, 56), |
| ); |
| |
| /// A sixth-level shade of grey. |
| /// |
| /// See also: |
| /// |
| /// * [UIColor.systemGray6](https://developer.apple.com/documentation/uikit/uicolor/3255075-systemgray6), |
| /// the `UIKit` equivalent. |
| static const CupertinoDynamicColor systemGrey6 = CupertinoDynamicColor.withBrightnessAndContrast( |
| debugLabel: 'systemGrey6', |
| color: Color.fromARGB(255, 242, 242, 247), |
| darkColor: Color.fromARGB(255, 28, 28, 30), |
| highContrastColor: Color.fromARGB(255, 235, 235, 240), |
| darkHighContrastColor: Color.fromARGB(255, 36, 36, 38), |
| ); |
| |
| /// The color for text labels containing primary content, equivalent to |
| /// [UIColor.label](https://developer.apple.com/documentation/uikit/uicolor/3173131-label). |
| static const CupertinoDynamicColor label = CupertinoDynamicColor( |
| debugLabel: 'label', |
| color: Color.fromARGB(255, 0, 0, 0), |
| darkColor: Color.fromARGB(255, 255, 255, 255), |
| highContrastColor: Color.fromARGB(255, 0, 0, 0), |
| darkHighContrastColor: Color.fromARGB(255, 255, 255, 255), |
| elevatedColor: Color.fromARGB(255, 0, 0, 0), |
| darkElevatedColor: Color.fromARGB(255, 255, 255, 255), |
| highContrastElevatedColor: Color.fromARGB(255, 0, 0, 0), |
| darkHighContrastElevatedColor: Color.fromARGB(255, 255, 255, 255), |
| ); |
| |
| /// The color for text labels containing secondary content, equivalent to |
| /// [UIColor.secondaryLabel](https://developer.apple.com/documentation/uikit/uicolor/3173136-secondarylabel). |
| static const CupertinoDynamicColor secondaryLabel = CupertinoDynamicColor( |
| debugLabel: 'secondaryLabel', |
| color: Color.fromARGB(153, 60, 60, 67), |
| darkColor: Color.fromARGB(153, 235, 235, 245), |
| highContrastColor: Color.fromARGB(173, 60, 60, 67), |
| darkHighContrastColor: Color.fromARGB(173, 235, 235, 245), |
| elevatedColor: Color.fromARGB(153, 60, 60, 67), |
| darkElevatedColor: Color.fromARGB(153, 235, 235, 245), |
| highContrastElevatedColor: Color.fromARGB(173, 60, 60, 67), |
| darkHighContrastElevatedColor: Color.fromARGB(173, 235, 235, 245), |
| ); |
| |
| /// The color for text labels containing tertiary content, equivalent to |
| /// [UIColor.tertiaryLabel](https://developer.apple.com/documentation/uikit/uicolor/3173153-tertiarylabel). |
| static const CupertinoDynamicColor tertiaryLabel = CupertinoDynamicColor( |
| debugLabel: 'tertiaryLabel', |
| color: Color.fromARGB(76, 60, 60, 67), |
| darkColor: Color.fromARGB(76, 235, 235, 245), |
| highContrastColor: Color.fromARGB(96, 60, 60, 67), |
| darkHighContrastColor: Color.fromARGB(96, 235, 235, 245), |
| elevatedColor: Color.fromARGB(76, 60, 60, 67), |
| darkElevatedColor: Color.fromARGB(76, 235, 235, 245), |
| highContrastElevatedColor: Color.fromARGB(96, 60, 60, 67), |
| darkHighContrastElevatedColor: Color.fromARGB(96, 235, 235, 245), |
| ); |
| |
| /// The color for text labels containing quaternary content, equivalent to |
| /// [UIColor.quaternaryLabel](https://developer.apple.com/documentation/uikit/uicolor/3173135-quaternarylabel). |
| static const CupertinoDynamicColor quaternaryLabel = CupertinoDynamicColor( |
| debugLabel: 'quaternaryLabel', |
| color: Color.fromARGB(45, 60, 60, 67), |
| darkColor: Color.fromARGB(40, 235, 235, 245), |
| highContrastColor: Color.fromARGB(66, 60, 60, 67), |
| darkHighContrastColor: Color.fromARGB(61, 235, 235, 245), |
| elevatedColor: Color.fromARGB(45, 60, 60, 67), |
| darkElevatedColor: Color.fromARGB(40, 235, 235, 245), |
| highContrastElevatedColor: Color.fromARGB(66, 60, 60, 67), |
| darkHighContrastElevatedColor: Color.fromARGB(61, 235, 235, 245), |
| ); |
| |
| /// An overlay fill color for thin and small shapes, equivalent to |
| /// [UIColor.systemFill](https://developer.apple.com/documentation/uikit/uicolor/3255070-systemfill). |
| static const CupertinoDynamicColor systemFill = CupertinoDynamicColor( |
| debugLabel: 'systemFill', |
| color: Color.fromARGB(51, 120, 120, 128), |
| darkColor: Color.fromARGB(91, 120, 120, 128), |
| highContrastColor: Color.fromARGB(71, 120, 120, 128), |
| darkHighContrastColor: Color.fromARGB(112, 120, 120, 128), |
| elevatedColor: Color.fromARGB(51, 120, 120, 128), |
| darkElevatedColor: Color.fromARGB(91, 120, 120, 128), |
| highContrastElevatedColor: Color.fromARGB(71, 120, 120, 128), |
| darkHighContrastElevatedColor: Color.fromARGB(112, 120, 120, 128), |
| ); |
| |
| /// An overlay fill color for medium-size shapes, equivalent to |
| /// [UIColor.secondarySystemFill](https://developer.apple.com/documentation/uikit/uicolor/3255069-secondarysystemfill). |
| static const CupertinoDynamicColor secondarySystemFill = CupertinoDynamicColor( |
| debugLabel: 'secondarySystemFill', |
| color: Color.fromARGB(40, 120, 120, 128), |
| darkColor: Color.fromARGB(81, 120, 120, 128), |
| highContrastColor: Color.fromARGB(61, 120, 120, 128), |
| darkHighContrastColor: Color.fromARGB(102, 120, 120, 128), |
| elevatedColor: Color.fromARGB(40, 120, 120, 128), |
| darkElevatedColor: Color.fromARGB(81, 120, 120, 128), |
| highContrastElevatedColor: Color.fromARGB(61, 120, 120, 128), |
| darkHighContrastElevatedColor: Color.fromARGB(102, 120, 120, 128), |
| ); |
| |
| /// An overlay fill color for large shapes, equivalent to |
| /// [UIColor.tertiarySystemFill](https://developer.apple.com/documentation/uikit/uicolor/3255076-tertiarysystemfill). |
| static const CupertinoDynamicColor tertiarySystemFill = CupertinoDynamicColor( |
| debugLabel: 'tertiarySystemFill', |
| color: Color.fromARGB(30, 118, 118, 128), |
| darkColor: Color.fromARGB(61, 118, 118, 128), |
| highContrastColor: Color.fromARGB(51, 118, 118, 128), |
| darkHighContrastColor: Color.fromARGB(81, 118, 118, 128), |
| elevatedColor: Color.fromARGB(30, 118, 118, 128), |
| darkElevatedColor: Color.fromARGB(61, 118, 118, 128), |
| highContrastElevatedColor: Color.fromARGB(51, 118, 118, 128), |
| darkHighContrastElevatedColor: Color.fromARGB(81, 118, 118, 128), |
| ); |
| |
| /// An overlay fill color for large areas containing complex content, equivalent |
| /// to [UIColor.quaternarySystemFill](https://developer.apple.com/documentation/uikit/uicolor/3255068-quaternarysystemfill). |
| static const CupertinoDynamicColor quaternarySystemFill = CupertinoDynamicColor( |
| debugLabel: 'quaternarySystemFill', |
| color: Color.fromARGB(20, 116, 116, 128), |
| darkColor: Color.fromARGB(45, 118, 118, 128), |
| highContrastColor: Color.fromARGB(40, 116, 116, 128), |
| darkHighContrastColor: Color.fromARGB(66, 118, 118, 128), |
| elevatedColor: Color.fromARGB(20, 116, 116, 128), |
| darkElevatedColor: Color.fromARGB(45, 118, 118, 128), |
| highContrastElevatedColor: Color.fromARGB(40, 116, 116, 128), |
| darkHighContrastElevatedColor: Color.fromARGB(66, 118, 118, 128), |
| ); |
| |
| /// The color for placeholder text in controls or text views, equivalent to |
| /// [UIColor.placeholderText](https://developer.apple.com/documentation/uikit/uicolor/3173134-placeholdertext). |
| static const CupertinoDynamicColor placeholderText = CupertinoDynamicColor( |
| debugLabel: 'placeholderText', |
| color: Color.fromARGB(76, 60, 60, 67), |
| darkColor: Color.fromARGB(76, 235, 235, 245), |
| highContrastColor: Color.fromARGB(96, 60, 60, 67), |
| darkHighContrastColor: Color.fromARGB(96, 235, 235, 245), |
| elevatedColor: Color.fromARGB(76, 60, 60, 67), |
| darkElevatedColor: Color.fromARGB(76, 235, 235, 245), |
| highContrastElevatedColor: Color.fromARGB(96, 60, 60, 67), |
| darkHighContrastElevatedColor: Color.fromARGB(96, 235, 235, 245), |
| ); |
| |
| /// The color for the main background of your interface, equivalent to |
| /// [UIColor.systemBackground](https://developer.apple.com/documentation/uikit/uicolor/3173140-systembackground). |
| /// |
| /// Typically used for designs that have a white primary background in a light environment. |
| static const CupertinoDynamicColor systemBackground = CupertinoDynamicColor( |
| debugLabel: 'systemBackground', |
| color: Color.fromARGB(255, 255, 255, 255), |
| darkColor: Color.fromARGB(255, 0, 0, 0), |
| highContrastColor: Color.fromARGB(255, 255, 255, 255), |
| darkHighContrastColor: Color.fromARGB(255, 0, 0, 0), |
| elevatedColor: Color.fromARGB(255, 255, 255, 255), |
| darkElevatedColor: Color.fromARGB(255, 28, 28, 30), |
| highContrastElevatedColor: Color.fromARGB(255, 255, 255, 255), |
| darkHighContrastElevatedColor: Color.fromARGB(255, 36, 36, 38), |
| ); |
| |
| /// The color for content layered on top of the main background, equivalent to |
| /// [UIColor.secondarySystemBackground](https://developer.apple.com/documentation/uikit/uicolor/3173137-secondarysystembackground). |
| /// |
| /// Typically used for designs that have a white primary background in a light environment. |
| static const CupertinoDynamicColor secondarySystemBackground = CupertinoDynamicColor( |
| debugLabel: 'secondarySystemBackground', |
| color: Color.fromARGB(255, 242, 242, 247), |
| darkColor: Color.fromARGB(255, 28, 28, 30), |
| highContrastColor: Color.fromARGB(255, 235, 235, 240), |
| darkHighContrastColor: Color.fromARGB(255, 36, 36, 38), |
| elevatedColor: Color.fromARGB(255, 242, 242, 247), |
| darkElevatedColor: Color.fromARGB(255, 44, 44, 46), |
| highContrastElevatedColor: Color.fromARGB(255, 235, 235, 240), |
| darkHighContrastElevatedColor: Color.fromARGB(255, 54, 54, 56), |
| ); |
| |
| /// The color for content layered on top of secondary backgrounds, equivalent |
| /// to [UIColor.tertiarySystemBackground](https://developer.apple.com/documentation/uikit/uicolor/3173154-tertiarysystembackground). |
| /// |
| /// Typically used for designs that have a white primary background in a light environment. |
| static const CupertinoDynamicColor tertiarySystemBackground = CupertinoDynamicColor( |
| debugLabel: 'tertiarySystemBackground', |
| color: Color.fromARGB(255, 255, 255, 255), |
| darkColor: Color.fromARGB(255, 44, 44, 46), |
| highContrastColor: Color.fromARGB(255, 255, 255, 255), |
| darkHighContrastColor: Color.fromARGB(255, 54, 54, 56), |
| elevatedColor: Color.fromARGB(255, 255, 255, 255), |
| darkElevatedColor: Color.fromARGB(255, 58, 58, 60), |
| highContrastElevatedColor: Color.fromARGB(255, 255, 255, 255), |
| darkHighContrastElevatedColor: Color.fromARGB(255, 68, 68, 70), |
| ); |
| |
| /// The color for the main background of your grouped interface, equivalent to |
| /// [UIColor.systemGroupedBackground](https://developer.apple.com/documentation/uikit/uicolor/3173145-systemgroupedbackground). |
| /// |
| /// Typically used for grouped content, including table views and platter-based designs. |
| static const CupertinoDynamicColor systemGroupedBackground = CupertinoDynamicColor( |
| debugLabel: 'systemGroupedBackground', |
| color: Color.fromARGB(255, 242, 242, 247), |
| darkColor: Color.fromARGB(255, 0, 0, 0), |
| highContrastColor: Color.fromARGB(255, 235, 235, 240), |
| darkHighContrastColor: Color.fromARGB(255, 0, 0, 0), |
| elevatedColor: Color.fromARGB(255, 242, 242, 247), |
| darkElevatedColor: Color.fromARGB(255, 28, 28, 30), |
| highContrastElevatedColor: Color.fromARGB(255, 235, 235, 240), |
| darkHighContrastElevatedColor: Color.fromARGB(255, 36, 36, 38), |
| ); |
| |
| /// The color for content layered on top of the main background of your grouped interface, |
| /// equivalent to [UIColor.secondarySystemGroupedBackground](https://developer.apple.com/documentation/uikit/uicolor/3173138-secondarysystemgroupedbackground). |
| /// |
| /// Typically used for grouped content, including table views and platter-based designs. |
| static const CupertinoDynamicColor secondarySystemGroupedBackground = CupertinoDynamicColor( |
| debugLabel: 'secondarySystemGroupedBackground', |
| color: Color.fromARGB(255, 255, 255, 255), |
| darkColor: Color.fromARGB(255, 28, 28, 30), |
| highContrastColor: Color.fromARGB(255, 255, 255, 255), |
| darkHighContrastColor: Color.fromARGB(255, 36, 36, 38), |
| elevatedColor: Color.fromARGB(255, 255, 255, 255), |
| darkElevatedColor: Color.fromARGB(255, 44, 44, 46), |
| highContrastElevatedColor: Color.fromARGB(255, 255, 255, 255), |
| darkHighContrastElevatedColor: Color.fromARGB(255, 54, 54, 56), |
| ); |
| |
| /// The color for content layered on top of secondary backgrounds of your grouped interface, |
| /// equivalent to [UIColor.tertiarySystemGroupedBackground](https://developer.apple.com/documentation/uikit/uicolor/3173155-tertiarysystemgroupedbackground). |
| /// |
| /// Typically used for grouped content, including table views and platter-based designs. |
| static const CupertinoDynamicColor tertiarySystemGroupedBackground = CupertinoDynamicColor( |
| debugLabel: 'tertiarySystemGroupedBackground', |
| color: Color.fromARGB(255, 242, 242, 247), |
| darkColor: Color.fromARGB(255, 44, 44, 46), |
| highContrastColor: Color.fromARGB(255, 235, 235, 240), |
| darkHighContrastColor: Color.fromARGB(255, 54, 54, 56), |
| elevatedColor: Color.fromARGB(255, 242, 242, 247), |
| darkElevatedColor: Color.fromARGB(255, 58, 58, 60), |
| highContrastElevatedColor: Color.fromARGB(255, 235, 235, 240), |
| darkHighContrastElevatedColor: Color.fromARGB(255, 68, 68, 70), |
| ); |
| |
| /// The color for thin borders or divider lines that allows some underlying content to be visible, |
| /// equivalent to [UIColor.separator](https://developer.apple.com/documentation/uikit/uicolor/3173139-separator). |
| static const CupertinoDynamicColor separator = CupertinoDynamicColor( |
| debugLabel: 'separator', |
| color: Color.fromARGB(73, 60, 60, 67), |
| darkColor: Color.fromARGB(153, 84, 84, 88), |
| highContrastColor: Color.fromARGB(94, 60, 60, 67), |
| darkHighContrastColor: Color.fromARGB(173, 84, 84, 88), |
| elevatedColor: Color.fromARGB(73, 60, 60, 67), |
| darkElevatedColor: Color.fromARGB(153, 84, 84, 88), |
| highContrastElevatedColor: Color.fromARGB(94, 60, 60, 67), |
| darkHighContrastElevatedColor: Color.fromARGB(173, 84, 84, 88), |
| ); |
| |
| /// The color for borders or divider lines that hide any underlying content, |
| /// equivalent to [UIColor.opaqueSeparator](https://developer.apple.com/documentation/uikit/uicolor/3173133-opaqueseparator). |
| static const CupertinoDynamicColor opaqueSeparator = CupertinoDynamicColor( |
| debugLabel: 'opaqueSeparator', |
| color: Color.fromARGB(255, 198, 198, 200), |
| darkColor: Color.fromARGB(255, 56, 56, 58), |
| highContrastColor: Color.fromARGB(255, 198, 198, 200), |
| darkHighContrastColor: Color.fromARGB(255, 56, 56, 58), |
| elevatedColor: Color.fromARGB(255, 198, 198, 200), |
| darkElevatedColor: Color.fromARGB(255, 56, 56, 58), |
| highContrastElevatedColor: Color.fromARGB(255, 198, 198, 200), |
| darkHighContrastElevatedColor: Color.fromARGB(255, 56, 56, 58), |
| ); |
| |
| /// The color for links, equivalent to |
| /// [UIColor.link](https://developer.apple.com/documentation/uikit/uicolor/3173132-link). |
| static const CupertinoDynamicColor link = CupertinoDynamicColor( |
| debugLabel: 'link', |
| color: Color.fromARGB(255, 0, 122, 255), |
| darkColor: Color.fromARGB(255, 9, 132, 255), |
| highContrastColor: Color.fromARGB(255, 0, 122, 255), |
| darkHighContrastColor: Color.fromARGB(255, 9, 132, 255), |
| elevatedColor: Color.fromARGB(255, 0, 122, 255), |
| darkElevatedColor: Color.fromARGB(255, 9, 132, 255), |
| highContrastElevatedColor: Color.fromARGB(255, 0, 122, 255), |
| darkHighContrastElevatedColor: Color.fromARGB(255, 9, 132, 255), |
| ); |
| } |
| |
| /// A [Color] subclass that represents a family of colors, and the correct effective |
| /// color in the color family. |
| /// |
| /// When used as a regular color, [CupertinoDynamicColor] is equivalent to the |
| /// effective color (i.e. [CupertinoDynamicColor.value] will come from the effective |
| /// color), which is determined by the [BuildContext] it is last resolved against. |
| /// If it has never been resolved, the light, normal contrast, base elevation variant |
| /// [CupertinoDynamicColor.color] will be the default effective color. |
| /// |
| /// Sometimes manually resolving a [CupertinoDynamicColor] is not necessary, because |
| /// the Cupertino Library provides built-in support for it. |
| /// |
| /// ### Using [CupertinoDynamicColor] in a Cupertino widget |
| /// |
| /// When a Cupertino widget is provided with a [CupertinoDynamicColor], either |
| /// directly in its constructor, or from an [InheritedWidget] it depends on (for example, |
| /// [DefaultTextStyle]), the widget will automatically resolve the color using |
| /// [CupertinoDynamicColor.resolve] against its own [BuildContext], on a best-effort |
| /// basis. |
| /// |
| /// {@tool snippet} |
| /// By default a [CupertinoButton] has no background color. The following sample |
| /// code shows how to build a [CupertinoButton] that appears white in light mode, |
| /// and changes automatically to black in dark mode. |
| /// |
| /// ```dart |
| /// CupertinoButton( |
| /// // CupertinoDynamicColor works out of box in a CupertinoButton. |
| /// color: const CupertinoDynamicColor.withBrightness( |
| /// color: CupertinoColors.white, |
| /// darkColor: CupertinoColors.black, |
| /// ), |
| /// onPressed: () { }, |
| /// child: child, |
| /// ) |
| /// ``` |
| /// {@end-tool} |
| /// |
| /// ### Using a [CupertinoDynamicColor] from a [CupertinoTheme] |
| /// |
| /// When referring to a [CupertinoTheme] color, generally the color will already |
| /// have adapted to the ambient [BuildContext], because [CupertinoTheme.of] |
| /// implicitly resolves all the colors used in the retrieved [CupertinoThemeData], |
| /// before returning it. |
| /// |
| /// {@tool snippet} |
| /// The following code sample creates a [Container] with the `primaryColor` of the |
| /// current theme. If `primaryColor` is a [CupertinoDynamicColor], the container |
| /// will be adaptive, thanks to [CupertinoTheme.of]: it will switch to `primaryColor`'s |
| /// dark variant once dark mode is turned on, and turns to primaryColor`'s high |
| /// contrast variant when [MediaQueryData.highContrast] is requested in the ambient |
| /// [MediaQuery], etc. |
| /// |
| /// ```dart |
| /// Container( |
| /// // Container is not a Cupertino widget, but CupertinoTheme.of implicitly |
| /// // resolves colors used in the retrieved CupertinoThemeData. |
| /// color: CupertinoTheme.of(context).primaryColor, |
| /// ) |
| /// ``` |
| /// {@end-tool} |
| /// |
| /// ### Manually Resolving a [CupertinoDynamicColor] |
| /// |
| /// When used to configure a non-Cupertino widget, or wrapped in an object opaque |
| /// to the receiving Cupertino component, a [CupertinoDynamicColor] may need to be |
| /// manually resolved using [CupertinoDynamicColor.resolve], before it can used |
| /// to paint. For example, to use a custom [Border] in a [CupertinoNavigationBar], |
| /// the colors used in the [Border] have to be resolved manually before being passed |
| /// to [CupertinoNavigationBar]'s constructor. |
| /// |
| /// {@tool snippet} |
| /// |
| /// The following code samples demonstrate two cases where you have to manually |
| /// resolve a [CupertinoDynamicColor]. |
| /// |
| /// ```dart |
| /// CupertinoNavigationBar( |
| /// // CupertinoNavigationBar does not know how to resolve colors used in |
| /// // a Border class. |
| /// border: Border( |
| /// bottom: BorderSide( |
| /// color: CupertinoDynamicColor.resolve(CupertinoColors.systemBlue, context), |
| /// ), |
| /// ), |
| /// ) |
| /// ``` |
| /// |
| /// ```dart |
| /// Container( |
| /// // Container is not a Cupertino widget. |
| /// color: CupertinoDynamicColor.resolve(CupertinoColors.systemBlue, context), |
| /// ) |
| /// ``` |
| /// {@end-tool} |
| /// |
| /// See also: |
| /// |
| /// * [CupertinoUserInterfaceLevel], an [InheritedWidget] that may affect color |
| /// resolution of a [CupertinoDynamicColor]. |
| /// * [CupertinoTheme.of], a static method that retrieves the ambient [CupertinoThemeData], |
| /// and then resolves [CupertinoDynamicColor]s used in the retrieved data. |
| @immutable |
| class CupertinoDynamicColor extends Color with Diagnosticable { |
| /// Creates an adaptive [Color] that changes its effective color based on the |
| /// [BuildContext] given. The default effective color is [color]. |
| /// |
| /// All the colors must not be null. |
| const CupertinoDynamicColor({ |
| String? debugLabel, |
| required Color color, |
| required Color darkColor, |
| required Color highContrastColor, |
| required Color darkHighContrastColor, |
| required Color elevatedColor, |
| required Color darkElevatedColor, |
| required Color highContrastElevatedColor, |
| required Color darkHighContrastElevatedColor, |
| }) : this._( |
| color, |
| color, |
| darkColor, |
| highContrastColor, |
| darkHighContrastColor, |
| elevatedColor, |
| darkElevatedColor, |
| highContrastElevatedColor, |
| darkHighContrastElevatedColor, |
| null, |
| debugLabel, |
| ); |
| |
| /// Creates an adaptive [Color] that changes its effective color based on the |
| /// given [BuildContext]'s brightness (from [MediaQueryData.platformBrightness] |
| /// or [CupertinoThemeData.brightness]) and accessibility contrast setting |
| /// ([MediaQueryData.highContrast]). The default effective color is [color]. |
| /// |
| /// All the colors must not be null. |
| const CupertinoDynamicColor.withBrightnessAndContrast({ |
| String? debugLabel, |
| required Color color, |
| required Color darkColor, |
| required Color highContrastColor, |
| required Color darkHighContrastColor, |
| }) : this( |
| debugLabel: debugLabel, |
| color: color, |
| darkColor: darkColor, |
| highContrastColor: highContrastColor, |
| darkHighContrastColor: darkHighContrastColor, |
| elevatedColor: color, |
| darkElevatedColor: darkColor, |
| highContrastElevatedColor: highContrastColor, |
| darkHighContrastElevatedColor: darkHighContrastColor, |
| ); |
| |
| /// Creates an adaptive [Color] that changes its effective color based on the given |
| /// [BuildContext]'s brightness (from [MediaQueryData.platformBrightness] or |
| /// [CupertinoThemeData.brightness]). The default effective color is [color]. |
| /// |
| /// All the colors must not be null. |
| const CupertinoDynamicColor.withBrightness({ |
| String? debugLabel, |
| required Color color, |
| required Color darkColor, |
| }) : this( |
| debugLabel: debugLabel, |
| color: color, |
| darkColor: darkColor, |
| highContrastColor: color, |
| darkHighContrastColor: darkColor, |
| elevatedColor: color, |
| darkElevatedColor: darkColor, |
| highContrastElevatedColor: color, |
| darkHighContrastElevatedColor: darkColor, |
| ); |
| |
| const CupertinoDynamicColor._( |
| this._effectiveColor, |
| this.color, |
| this.darkColor, |
| this.highContrastColor, |
| this.darkHighContrastColor, |
| this.elevatedColor, |
| this.darkElevatedColor, |
| this.highContrastElevatedColor, |
| this.darkHighContrastElevatedColor, |
| this._debugResolveContext, |
| this._debugLabel, |
| ) : // The super constructor has to be called with a dummy value in order to mark |
| // this constructor const. |
| // The field `value` is overridden in the class implementation. |
| super(0); |
| |
| /// The current effective color. |
| /// |
| /// Must not be null. Defaults to [color] if this [CupertinoDynamicColor] has |
| /// never been resolved. |
| final Color _effectiveColor; |
| |
| @override |
| int get value => _effectiveColor.value; |
| |
| final String? _debugLabel; |
| |
| final Element? _debugResolveContext; |
| |
| /// The color to use when the [BuildContext] implies a combination of light mode, |
| /// normal contrast, and base interface elevation. |
| /// |
| /// In other words, this color will be the effective color of the [CupertinoDynamicColor] |
| /// after it is resolved against a [BuildContext] that: |
| /// - has a [CupertinoTheme] whose [CupertinoThemeData.brightness] is [Brightness.light], |
| /// or a [MediaQuery] whose [MediaQueryData.platformBrightness] is [Brightness.light]. |
| /// - has a [MediaQuery] whose [MediaQueryData.highContrast] is `false`. |
| /// - has a [CupertinoUserInterfaceLevel] that indicates [CupertinoUserInterfaceLevelData.base]. |
| final Color color; |
| |
| /// The color to use when the [BuildContext] implies a combination of dark mode, |
| /// normal contrast, and base interface elevation. |
| /// |
| /// In other words, this color will be the effective color of the [CupertinoDynamicColor] |
| /// after it is resolved against a [BuildContext] that: |
| /// - has a [CupertinoTheme] whose [CupertinoThemeData.brightness] is [Brightness.dark], |
| /// or a [MediaQuery] whose [MediaQueryData.platformBrightness] is [Brightness.dark]. |
| /// - has a [MediaQuery] whose [MediaQueryData.highContrast] is `false`. |
| /// - has a [CupertinoUserInterfaceLevel] that indicates [CupertinoUserInterfaceLevelData.base]. |
| final Color darkColor; |
| |
| /// The color to use when the [BuildContext] implies a combination of light mode, |
| /// high contrast, and base interface elevation. |
| /// |
| /// In other words, this color will be the effective color of the [CupertinoDynamicColor] |
| /// after it is resolved against a [BuildContext] that: |
| /// - has a [CupertinoTheme] whose [CupertinoThemeData.brightness] is [Brightness.light], |
| /// or a [MediaQuery] whose [MediaQueryData.platformBrightness] is [Brightness.light]. |
| /// - has a [MediaQuery] whose [MediaQueryData.highContrast] is `true`. |
| /// - has a [CupertinoUserInterfaceLevel] that indicates [CupertinoUserInterfaceLevelData.base]. |
| final Color highContrastColor; |
| |
| /// The color to use when the [BuildContext] implies a combination of dark mode, |
| /// high contrast, and base interface elevation. |
| /// |
| /// In other words, this color will be the effective color of the [CupertinoDynamicColor] |
| /// after it is resolved against a [BuildContext] that: |
| /// - has a [CupertinoTheme] whose [CupertinoThemeData.brightness] is [Brightness.dark], |
| /// or a [MediaQuery] whose [MediaQueryData.platformBrightness] is [Brightness.dark]. |
| /// - has a [MediaQuery] whose [MediaQueryData.highContrast] is `true`. |
| /// - has a [CupertinoUserInterfaceLevel] that indicates [CupertinoUserInterfaceLevelData.base]. |
| final Color darkHighContrastColor; |
| |
| /// The color to use when the [BuildContext] implies a combination of light mode, |
| /// normal contrast, and elevated interface elevation. |
| /// |
| /// In other words, this color will be the effective color of the [CupertinoDynamicColor] |
| /// after it is resolved against a [BuildContext] that: |
| /// - has a [CupertinoTheme] whose [CupertinoThemeData.brightness] is [Brightness.light], |
| /// or a [MediaQuery] whose [MediaQueryData.platformBrightness] is [Brightness.light]. |
| /// - has a [MediaQuery] whose [MediaQueryData.highContrast] is `false`. |
| /// - has a [CupertinoUserInterfaceLevel] that indicates [CupertinoUserInterfaceLevelData.elevated]. |
| final Color elevatedColor; |
| |
| /// The color to use when the [BuildContext] implies a combination of dark mode, |
| /// normal contrast, and elevated interface elevation. |
| /// |
| /// In other words, this color will be the effective color of the [CupertinoDynamicColor] |
| /// after it is resolved against a [BuildContext] that: |
| /// - has a [CupertinoTheme] whose [CupertinoThemeData.brightness] is [Brightness.dark], |
| /// or a [MediaQuery] whose [MediaQueryData.platformBrightness] is [Brightness.dark]. |
| /// - has a [MediaQuery] whose [MediaQueryData.highContrast] is `false`. |
| /// - has a [CupertinoUserInterfaceLevel] that indicates [CupertinoUserInterfaceLevelData.elevated]. |
| final Color darkElevatedColor; |
| |
| /// The color to use when the [BuildContext] implies a combination of light mode, |
| /// high contrast, and elevated interface elevation. |
| /// |
| /// In other words, this color will be the effective color of the [CupertinoDynamicColor] |
| /// after it is resolved against a [BuildContext] that: |
| /// - has a [CupertinoTheme] whose [CupertinoThemeData.brightness] is [Brightness.light], |
| /// or a [MediaQuery] whose [MediaQueryData.platformBrightness] is [Brightness.light]. |
| /// - has a [MediaQuery] whose [MediaQueryData.highContrast] is `true`. |
| /// - has a [CupertinoUserInterfaceLevel] that indicates [CupertinoUserInterfaceLevelData.elevated]. |
| final Color highContrastElevatedColor; |
| |
| /// The color to use when the [BuildContext] implies a combination of dark mode, |
| /// high contrast, and elevated interface elevation. |
| /// |
| /// In other words, this color will be the effective color of the [CupertinoDynamicColor] |
| /// after it is resolved against a [BuildContext] that: |
| /// - has a [CupertinoTheme] whose [CupertinoThemeData.brightness] is [Brightness.dark], |
| /// or a [MediaQuery] whose [MediaQueryData.platformBrightness] is [Brightness.dark]. |
| /// - has a [MediaQuery] whose [MediaQueryData.highContrast] is `true`. |
| /// - has a [CupertinoUserInterfaceLevel] that indicates [CupertinoUserInterfaceLevelData.elevated]. |
| final Color darkHighContrastElevatedColor; |
| |
| /// Resolves the given [Color] by calling [resolveFrom]. |
| /// |
| /// If the given color is already a concrete [Color], it will be returned as is. |
| /// If the given color is a [CupertinoDynamicColor], but the given [BuildContext] |
| /// lacks the dependencies required to the color resolution, the default trait |
| /// value will be used ([Brightness.light] platform brightness, normal contrast, |
| /// [CupertinoUserInterfaceLevelData.base] elevation level). |
| /// |
| /// See also: |
| /// |
| /// * [maybeResolve], which is similar to this function, but will allow a |
| /// null `resolvable` color. |
| static Color resolve(Color resolvable, BuildContext context) { |
| return (resolvable is CupertinoDynamicColor) |
| ? resolvable.resolveFrom(context) |
| : resolvable; |
| } |
| |
| /// Resolves the given [Color] by calling [resolveFrom]. |
| /// |
| /// If the given color is already a concrete [Color], it will be returned as is. |
| /// If the given color is null, returns null. |
| /// If the given color is a [CupertinoDynamicColor], but the given [BuildContext] |
| /// lacks the dependencies required to the color resolution, the default trait |
| /// value will be used ([Brightness.light] platform brightness, normal contrast, |
| /// [CupertinoUserInterfaceLevelData.base] elevation level). |
| /// |
| /// See also: |
| /// |
| /// * [resolve], which is similar to this function, but returns a |
| /// non-nullable value, and does not allow a null `resolvable` color. |
| static Color? maybeResolve(Color? resolvable, BuildContext context) { |
| if (resolvable == null) { |
| return null; |
| } |
| return (resolvable is CupertinoDynamicColor) |
| ? resolvable.resolveFrom(context) |
| : resolvable; |
| } |
| |
| bool get _isPlatformBrightnessDependent { |
| return color != darkColor |
| || elevatedColor != darkElevatedColor |
| || highContrastColor != darkHighContrastColor |
| || highContrastElevatedColor != darkHighContrastElevatedColor; |
| } |
| |
| bool get _isHighContrastDependent { |
| return color != highContrastColor |
| || darkColor != darkHighContrastColor |
| || elevatedColor != highContrastElevatedColor |
| || darkElevatedColor != darkHighContrastElevatedColor; |
| } |
| |
| bool get _isInterfaceElevationDependent { |
| return color != elevatedColor |
| || darkColor != darkElevatedColor |
| || highContrastColor != highContrastElevatedColor |
| || darkHighContrastColor != darkHighContrastElevatedColor; |
| } |
| |
| /// Resolves this [CupertinoDynamicColor] using the provided [BuildContext]. |
| /// |
| /// Calling this method will create a new [CupertinoDynamicColor] that is almost |
| /// identical to this [CupertinoDynamicColor], except the effective color is |
| /// changed to adapt to the given [BuildContext]. |
| /// |
| /// For example, if the given [BuildContext] indicates the widgets in the |
| /// subtree should be displayed in dark mode (the surrounding |
| /// [CupertinoTheme]'s [CupertinoThemeData.brightness] or [MediaQuery]'s |
| /// [MediaQueryData.platformBrightness] is [Brightness.dark]), with a high |
| /// accessibility contrast (the surrounding [MediaQuery]'s |
| /// [MediaQueryData.highContrast] is `true`), and an elevated interface |
| /// elevation (the surrounding [CupertinoUserInterfaceLevel]'s `data` is |
| /// [CupertinoUserInterfaceLevelData.elevated]), the resolved |
| /// [CupertinoDynamicColor] will be the same as this [CupertinoDynamicColor], |
| /// except its effective color will be the `darkHighContrastElevatedColor` |
| /// variant from the original [CupertinoDynamicColor]. |
| /// |
| /// Calling this function may create dependencies on the closest instance of some |
| /// [InheritedWidget]s that enclose the given [BuildContext]. E.g., if [darkColor] |
| /// is different from [color], this method will call [CupertinoTheme.of], and |
| /// then [MediaQuery.of] if brightness wasn't specified in the theme data retrieved |
| /// from the previous [CupertinoTheme.of] call, in an effort to determine the |
| /// brightness value. |
| /// |
| /// If any of the required dependencies are missing from the given context, the |
| /// default value of that trait will be used ([Brightness.light] platform |
| /// brightness, normal contrast, [CupertinoUserInterfaceLevelData.base] elevation |
| /// level). |
| CupertinoDynamicColor resolveFrom(BuildContext context) { |
| Brightness brightness = Brightness.light; |
| if (_isPlatformBrightnessDependent) { |
| brightness = CupertinoTheme.maybeBrightnessOf(context) ?? Brightness.light; |
| } |
| bool isHighContrastEnabled = false; |
| if (_isHighContrastDependent) { |
| isHighContrastEnabled = MediaQuery.maybeHighContrastOf(context) ?? false; |
| } |
| |
| final CupertinoUserInterfaceLevelData level = _isInterfaceElevationDependent |
| ? CupertinoUserInterfaceLevel.maybeOf(context) ?? CupertinoUserInterfaceLevelData.base |
| : CupertinoUserInterfaceLevelData.base; |
| |
| final Color resolved; |
| switch (brightness) { |
| case Brightness.light: |
| switch (level) { |
| case CupertinoUserInterfaceLevelData.base: |
| resolved = isHighContrastEnabled ? highContrastColor : color; |
| case CupertinoUserInterfaceLevelData.elevated: |
| resolved = isHighContrastEnabled ? highContrastElevatedColor : elevatedColor; |
| } |
| case Brightness.dark: |
| switch (level) { |
| case CupertinoUserInterfaceLevelData.base: |
| resolved = isHighContrastEnabled ? darkHighContrastColor : darkColor; |
| case CupertinoUserInterfaceLevelData.elevated: |
| resolved = isHighContrastEnabled ? darkHighContrastElevatedColor : darkElevatedColor; |
| } |
| } |
| |
| Element? debugContext; |
| assert(() { |
| debugContext = context as Element; |
| return true; |
| }()); |
| return CupertinoDynamicColor._( |
| resolved, |
| color, |
| darkColor, |
| highContrastColor, |
| darkHighContrastColor, |
| elevatedColor, |
| darkElevatedColor, |
| highContrastElevatedColor, |
| darkHighContrastElevatedColor, |
| debugContext, |
| _debugLabel, |
| ); |
| } |
| |
| @override |
| bool operator ==(Object other) { |
| if (identical(this, other)) { |
| return true; |
| } |
| if (other.runtimeType != runtimeType) { |
| return false; |
| } |
| return other is CupertinoDynamicColor |
| && other.value == value |
| && other.color == color |
| && other.darkColor == darkColor |
| && other.highContrastColor == highContrastColor |
| && other.darkHighContrastColor == darkHighContrastColor |
| && other.elevatedColor == elevatedColor |
| && other.darkElevatedColor == darkElevatedColor |
| && other.highContrastElevatedColor == highContrastElevatedColor |
| && other.darkHighContrastElevatedColor == darkHighContrastElevatedColor; |
| } |
| |
| @override |
| int get hashCode => Object.hash( |
| value, |
| color, |
| darkColor, |
| highContrastColor, |
| elevatedColor, |
| darkElevatedColor, |
| darkHighContrastColor, |
| darkHighContrastElevatedColor, |
| highContrastElevatedColor, |
| ); |
| |
| @override |
| String toString({ DiagnosticLevel minLevel = DiagnosticLevel.info }) { |
| String toString(String name, Color color) { |
| final String marker = color == _effectiveColor ? '*' : ''; |
| return '$marker$name = $color$marker'; |
| } |
| |
| final List<String> xs = <String>[toString('color', color), |
| if (_isPlatformBrightnessDependent) toString('darkColor', darkColor), |
| if (_isHighContrastDependent) toString('highContrastColor', highContrastColor), |
| if (_isPlatformBrightnessDependent && _isHighContrastDependent) toString('darkHighContrastColor', darkHighContrastColor), |
| if (_isInterfaceElevationDependent) toString('elevatedColor', elevatedColor), |
| if (_isPlatformBrightnessDependent && _isInterfaceElevationDependent) toString('darkElevatedColor', darkElevatedColor), |
| if (_isHighContrastDependent && _isInterfaceElevationDependent) toString('highContrastElevatedColor', highContrastElevatedColor), |
| if (_isPlatformBrightnessDependent && _isHighContrastDependent && _isInterfaceElevationDependent) toString('darkHighContrastElevatedColor', darkHighContrastElevatedColor), |
| ]; |
| |
| return '${_debugLabel ?? objectRuntimeType(this, 'CupertinoDynamicColor')}(${xs.join(', ')}, resolved by: ${_debugResolveContext?.widget ?? "UNRESOLVED"})'; |
| } |
| |
| @override |
| void debugFillProperties(DiagnosticPropertiesBuilder properties) { |
| super.debugFillProperties(properties); |
| if (_debugLabel != null) { |
| properties.add(MessageProperty('debugLabel', _debugLabel!)); |
| } |
| properties.add(createCupertinoColorProperty('color', color)); |
| if (_isPlatformBrightnessDependent) { |
| properties.add(createCupertinoColorProperty('darkColor', darkColor)); |
| } |
| if (_isHighContrastDependent) { |
| properties.add(createCupertinoColorProperty('highContrastColor', highContrastColor)); |
| } |
| if (_isPlatformBrightnessDependent && _isHighContrastDependent) { |
| properties.add(createCupertinoColorProperty('darkHighContrastColor', darkHighContrastColor)); |
| } |
| if (_isInterfaceElevationDependent) { |
| properties.add(createCupertinoColorProperty('elevatedColor', elevatedColor)); |
| } |
| if (_isPlatformBrightnessDependent && _isInterfaceElevationDependent) { |
| properties.add(createCupertinoColorProperty('darkElevatedColor', darkElevatedColor)); |
| } |
| if (_isHighContrastDependent && _isInterfaceElevationDependent) { |
| properties.add(createCupertinoColorProperty('highContrastElevatedColor', highContrastElevatedColor)); |
| } |
| if (_isPlatformBrightnessDependent && _isHighContrastDependent && _isInterfaceElevationDependent) { |
| properties.add(createCupertinoColorProperty('darkHighContrastElevatedColor', darkHighContrastElevatedColor)); |
| } |
| |
| if (_debugResolveContext != null) { |
| properties.add(DiagnosticsProperty<Element>('last resolved', _debugResolveContext)); |
| } |
| } |
| } |
| |
| /// Creates a diagnostics property for [CupertinoDynamicColor]. |
| /// |
| /// The [showName], [style], and [level] arguments must not be null. |
| DiagnosticsProperty<Color> createCupertinoColorProperty( |
| String name, |
| Color? value, { |
| bool showName = true, |
| Object? defaultValue = kNoDefaultValue, |
| DiagnosticsTreeStyle style = DiagnosticsTreeStyle.singleLine, |
| DiagnosticLevel level = DiagnosticLevel.info, |
| }) { |
| if (value is CupertinoDynamicColor) { |
| return DiagnosticsProperty<CupertinoDynamicColor>( |
| name, |
| value, |
| description: value._debugLabel, |
| showName: showName, |
| defaultValue: defaultValue, |
| style: style, |
| level: level, |
| ); |
| } else { |
| return ColorProperty( |
| name, |
| value, |
| showName: showName, |
| defaultValue: defaultValue, |
| style: style, |
| level: level, |
| ); |
| } |
| } |