gpt4 book ai didi

Flutter - 如何在焦点上的 TextFormField 中添加阴影

转载 作者:行者123 更新时间:2023-12-02 02:58:33 25 4
gpt4 key购买 nike

在 Flutter 中聚焦时如何在 TextFormField 中添加阴影?我希望该字段具有以下外观:

field with shadow

到目前为止,我设法在聚焦时应用边框,但没有看到任何应用阴影的选项:

TextFormField(
decoration: InputDecoration(
fillColor: Colors.white,
hoverColor: Colors.white,
filled: true,
enabledBorder: OutlineInputBorder(borderSide: BorderSide.none),
focusedBorder: OutlineInputBorder(
borderSide: BorderSide(color: Colors.grey, width: 1))),
);

关于如何实现这种效果有什么想法吗?

最佳答案

重要提示:使用 Form 小部件包装您的 TextField 并分配 _formKey它有助于防止在 setState()

之后关闭键盘

完整示例:

import 'package:flutter/material.dart';
import 'package:flutter/widgets.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(),
body: Home(),
),
);
}
}

class Home extends StatefulWidget {
@override
_HomeState createState() => _HomeState();
}

class _HomeState extends State<Home> {
static GlobalKey<FormState> _formKey = new GlobalKey<FormState>();
FocusNode focusNode;

@override
void initState() {
super.initState();
focusNode = FocusNode();
focusNode.addListener(() => setState(() {}));
}

@override
Widget build(BuildContext context) {
return AnimatedContainer(
duration: Duration(seconds: 5),
margin: const EdgeInsets.all(16),
decoration: focusNode.hasFocus ? BoxDecoration(boxShadow: [BoxShadow(blurRadius: 6)]) : null,
child: Form(
key: _formKey,
child: TextFormField(
focusNode: focusNode,
decoration: InputDecoration(
fillColor: Colors.white,
hoverColor: Colors.white,
filled: true,
enabledBorder: OutlineInputBorder(borderSide: BorderSide.none),
focusedBorder: OutlineInputBorder(borderSide: BorderSide(color: Colors.grey, width: 1))),
),
),
);
}
}

/image/boS20.jpg

关于Flutter - 如何在焦点上的 TextFormField 中添加阴影,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60545779/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com