Unverified Commit e7a4e7c3 authored by Hans Muller's avatar Hans Muller Committed by GitHub

Update Switch doc: disabled state (#24941)

parent ab36f054
...@@ -35,6 +35,11 @@ enum _SwitchType { material, adaptive } ...@@ -35,6 +35,11 @@ enum _SwitchType { material, adaptive }
/// that use a switch will listen for the [onChanged] callback and rebuild the /// that use a switch will listen for the [onChanged] callback and rebuild the
/// switch with a new [value] to update the visual appearance of the switch. /// switch with a new [value] to update the visual appearance of the switch.
/// ///
/// If the [onChanged] callback is null, then the switch will be disabled (it
/// will not respond to input). A disabled switch's thumb and track are rendered
/// in shades of grey by default. The default appearance of a disabled switch
/// can be overridden with [inactiveThumbColor] and [inactiveTrackColor].
///
/// Requires one of its ancestors to be a [Material] widget. /// Requires one of its ancestors to be a [Material] widget.
/// ///
/// See also: /// See also:
...@@ -505,8 +510,7 @@ class _RenderSwitch extends RenderToggleable { ...@@ -505,8 +510,7 @@ class _RenderSwitch extends RenderToggleable {
@override @override
void paint(PaintingContext context, Offset offset) { void paint(PaintingContext context, Offset offset) {
final Canvas canvas = context.canvas; final Canvas canvas = context.canvas;
final bool isEnabled = onChanged != null;
final bool isActive = onChanged != null;
final double currentValue = position.value; final double currentValue = position.value;
double visualPosition; double visualPosition;
...@@ -519,7 +523,17 @@ class _RenderSwitch extends RenderToggleable { ...@@ -519,7 +523,17 @@ class _RenderSwitch extends RenderToggleable {
break; break;
} }
final Color trackColor = isActive ? Color.lerp(inactiveTrackColor, activeTrackColor, currentValue) : inactiveTrackColor; final Color trackColor = isEnabled
? Color.lerp(inactiveTrackColor, activeTrackColor, currentValue)
: inactiveTrackColor;
final Color thumbColor = isEnabled
? Color.lerp(inactiveColor, activeColor, currentValue)
: inactiveColor;
final ImageProvider thumbImage = isEnabled
? (currentValue < 0.5 ? inactiveThumbImage : activeThumbImage)
: inactiveThumbImage;
// Paint the track // Paint the track
final Paint paint = Paint() final Paint paint = Paint()
...@@ -544,8 +558,6 @@ class _RenderSwitch extends RenderToggleable { ...@@ -544,8 +558,6 @@ class _RenderSwitch extends RenderToggleable {
try { try {
_isPainting = true; _isPainting = true;
BoxPainter thumbPainter; BoxPainter thumbPainter;
final Color thumbColor = isActive ? Color.lerp(inactiveColor, activeColor, currentValue) : inactiveColor;
final ImageProvider thumbImage = isActive ? (currentValue < 0.5 ? inactiveThumbImage : activeThumbImage) : inactiveThumbImage;
if (_cachedThumbPainter == null || thumbColor != _cachedThumbColor || thumbImage != _cachedThumbImage) { if (_cachedThumbPainter == null || thumbColor != _cachedThumbColor || thumbImage != _cachedThumbImage) {
_cachedThumbColor = thumbColor; _cachedThumbColor = thumbColor;
_cachedThumbImage = thumbImage; _cachedThumbImage = thumbImage;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment