Flutter - How to change TextField hint color?

后端 未结 3 1266
日久生厌
日久生厌 2021-01-31 14:15

I\'m a bit confused how to change the hint color of the textfield. Someone can guide me how to do it.Thanks

child: TextField(
   style: TextStyle(fontSize: 20),
         


        
3条回答
  •  滥情空心
    2021-01-31 14:33

    After digging the source code for the InputDecorator used to determine the label color, here's what I found.

    TextStyle _getFloatingLabelStyle(ThemeData themeData) {
      final Color color = decoration.errorText != null
        ? decoration.errorStyle?.color ?? themeData.errorColor
        : _getActiveColor(themeData);
      final TextStyle style = themeData.textTheme.subtitle1.merge(widget.baseStyle);
      return style
        .copyWith(color: decoration.enabled ? color : themeData.disabledColor)
        .merge(decoration.labelStyle);
    }
    
    Color _getActiveColor(ThemeData themeData) {
      if (isFocused) {
        switch (themeData.brightness) {
          case Brightness.dark:
            return themeData.accentColor;
          case Brightness.light:
            return themeData.primaryColor;
        }
      }
      return themeData.hintColor;
    }
    

    In short, to change the hint color, set hintColor using Theme and ThemeData.

    Another tip: to change the label color, set the primaryColor light theme, or accentColor for dark theme.

    ThemeData.dark().copyWith(
      primaryColor: Colors.red,
      accentColor: Colors.white,
      hintColor: Colors.pink,
    )
    

提交回复
热议问题