SliderThemeData.fromPrimaryColors constructor
Generates a SliderThemeData from three main colors.
Usually these are the primary, dark and light colors from a ThemeData.
The opacities of these colors will be overridden with the Material Design defaults when assigning them to the slider theme component colors.
This is used to generate the default slider theme for a ThemeData.
Implementation
factory SliderThemeData.fromPrimaryColors({
required Color primaryColor,
required Color primaryColorDark,
required Color primaryColorLight,
required TextStyle valueIndicatorTextStyle,
}) {
// These are Material Design defaults, and are used to derive
// component Colors (with opacity) from base colors.
const activeTrackAlpha = 0xff;
const inactiveTrackAlpha = 0x3d; // 24% opacity
const secondaryActiveTrackAlpha = 0x8a; // 54% opacity
const disabledActiveTrackAlpha = 0x52; // 32% opacity
const disabledInactiveTrackAlpha = 0x1f; // 12% opacity
const disabledSecondaryActiveTrackAlpha = 0x1f; // 12% opacity
const activeTickMarkAlpha = 0x8a; // 54% opacity
const inactiveTickMarkAlpha = 0x8a; // 54% opacity
const disabledActiveTickMarkAlpha = 0x1f; // 12% opacity
const disabledInactiveTickMarkAlpha = 0x1f; // 12% opacity
const thumbAlpha = 0xff;
const disabledThumbAlpha = 0x52; // 32% opacity
const overlayAlpha = 0x1f; // 12% opacity
const valueIndicatorAlpha = 0xff;
return SliderThemeData(
trackHeight: 2.0,
activeTrackColor: primaryColor.withAlpha(activeTrackAlpha),
inactiveTrackColor: primaryColor.withAlpha(inactiveTrackAlpha),
secondaryActiveTrackColor: primaryColor.withAlpha(secondaryActiveTrackAlpha),
disabledActiveTrackColor: primaryColorDark.withAlpha(disabledActiveTrackAlpha),
disabledInactiveTrackColor: primaryColorDark.withAlpha(disabledInactiveTrackAlpha),
disabledSecondaryActiveTrackColor: primaryColorDark.withAlpha(
disabledSecondaryActiveTrackAlpha,
),
activeTickMarkColor: primaryColorLight.withAlpha(activeTickMarkAlpha),
inactiveTickMarkColor: primaryColor.withAlpha(inactiveTickMarkAlpha),
disabledActiveTickMarkColor: primaryColorLight.withAlpha(disabledActiveTickMarkAlpha),
disabledInactiveTickMarkColor: primaryColorDark.withAlpha(disabledInactiveTickMarkAlpha),
thumbColor: primaryColor.withAlpha(thumbAlpha),
overlappingShapeStrokeColor: Colors.white,
disabledThumbColor: primaryColorDark.withAlpha(disabledThumbAlpha),
overlayColor: primaryColor.withAlpha(overlayAlpha),
valueIndicatorColor: primaryColor.withAlpha(valueIndicatorAlpha),
valueIndicatorStrokeColor: primaryColor.withAlpha(valueIndicatorAlpha),
overlayShape: const RoundSliderOverlayShape(),
tickMarkShape: const RoundSliderTickMarkShape(),
thumbShape: const RoundSliderThumbShape(),
trackShape: const RoundedRectSliderTrackShape(),
valueIndicatorShape: const PaddleSliderValueIndicatorShape(),
rangeTickMarkShape: const RoundRangeSliderTickMarkShape(),
rangeThumbShape: const RoundRangeSliderThumbShape(),
rangeTrackShape: const RoundedRectRangeSliderTrackShape(),
rangeValueIndicatorShape: const PaddleRangeSliderValueIndicatorShape(),
valueIndicatorTextStyle: valueIndicatorTextStyle,
showValueIndicator: ShowValueIndicator.onlyForDiscrete,
);
}