Rename MaterialState to WidgetState
Summary
#MaterialState
, and its related APIs, have been moved out
of the Material library and renamed to WidgetState
.
Background
#Previously, MaterialState
provided logic for
handling multiple different states a widget could have,
like "hovered", "focused", and "disabled".
Because this functionality is useful outside the Material library,
namely for the base Widgets layer and Cupertino,
it was decided to move it outside of Material.
As part of the move, and to avoid future confusion,
the different MaterialState
classes have been renamed to WidgetState
.
The behavior of the two are the same.
Before | Now |
---|---|
MaterialState |
WidgetState |
MaterialStatePropertyResolver |
WidgetStatePropertyResolver |
MaterialStateColor |
WidgetStateColor |
MaterialStateMouseCursor |
WidgetStateColorMouseCursor |
MaterialStateBorderSide |
WidgetStateBorderSide |
MaterialStateOutlinedBorder |
WidgetStateOutlinedBorder |
MaterialStateTextStyle |
WidgetStateTextStyle |
MaterialStateProperty |
WidgetStateProperty |
MaterialStatePropertyAll |
WidgetStatePropertyAll |
MaterialStatesController |
WidgetStatesController |
The classes MaterialStateOutlineInputBorder
and
MaterialStateUnderlineInputBorder
were left in the
Material library with no WidgetState
equivalent, as
they are specific to Material design.
Migration guide
#A Flutter fix is available to help migrate the MaterialState
classes to WidgetState
.
To migrate, replace MaterialState
with WidgetState
.
Code before migration:
MaterialState selected = MaterialState.selected;
final MaterialStateProperty<Color> backgroundColor;
class _MouseCursor extends MaterialStateMouseCursor{
const _MouseCursor(this.resolveCallback);
final MaterialPropertyResolver<MouseCursor?> resolveCallback;
@override
MouseCursor resolve(Set<MaterialState> states) => resolveCallback(states) ?? MouseCursor.uncontrolled;
}
BorderSide side = MaterialStateBorderSide.resolveWith((Set<MaterialState> states) {
if (states.contains(MaterialState.selected)) {
return const BorderSide(color: Colors.red);
}
return null;
});
Code after migration:
WidgetState selected = WidgetState.selected;
final WidgetStateProperty<Color> backgroundColor;
class _MouseCursor extends WidgetStateMouseCursor{
const _MouseCursor(this.resolveCallback);
final WidgetPropertyResolver<MouseCursor?> resolveCallback;
@override
MouseCursor resolve(Set<WidgetState> states) => resolveCallback(states) ?? MouseCursor.uncontrolled;
}
BorderSide side = WidgetStateBorderSide.resolveWith((Set<WidgetState> states) {
if (states.contains(WidgetState.selected)) {
return const BorderSide(color: Colors.red);
}
return null;
});
Timeline
#Landed in version: 3.21.0-11.0.pre
In stable release: 3.22.0
References
#Relevant issues:
Relevant PRs:
除非另有说明,本文档之所提及适用于 Flutter 的最新稳定版本,本页面最后更新时间: 2024-10-09。 查看文档源码 或者 为本页面内容提出建议。