我是新手,我正在尝试一个简单的功能.. 我有一个带有文本和凸起按钮的页面,我想每次按下按钮时将文本大小增加1.0。 我已经尝试过了,但是没有用..
class _StoryDetailsState extends State<StoryDetails> {
@override
Widget build(BuildContext context) {
var textSize = 10.0;
return Scaffold(
backgroundColor: Color(0xffEA3A82),
appBar: AppBar(
elevation: 0.0,
backgroundColor: Color(0xffEA3A82),
title: Text(widget.story_title),
)
,body: SingleChildScrollView(
child: Column(
children: <Widget>[
Align(
alignment: Alignment.topLeft
,child: Image.network(widget.story_detail_pic , width: double.infinity,)
),
RaisedButton(
child: Text('enlarge text'),
onPressed: (){
setState(() {
textSize = textSize + 1.0;
print(textSize);
});
},
),
Padding(
padding: const EdgeInsets.all(10.0),
child: ClipRRect(borderRadius: BorderRadius.circular(10)
,child: Container(color: Colors.white.withOpacity(0.6) ,child: Padding(
padding: const EdgeInsets.all(8.0),
child: Text(widget.story , style: TextStyle(fontSize: textSize),),
))),
)
],
),
),
);
} }
答案 0 :(得分:1)
问题是您要在build方法内部声明textsize
。每次调用设置状态时,都会调用build方法,然后将textsize
再次设置为10。只需将var textSize = 10.0;
移至build方法之外,它将可以正常工作。
class _StoryDetailsState extends State<StoryDetails> {
var textSize = 10.0;
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: Color(0xffEA3A82),
appBar: AppBar(
elevation: 0.0,
backgroundColor: Color(0xffEA3A82),
title: Text("Title"),
),
body: SingleChildScrollView(
child: Column(
children: <Widget>[
Align(
alignment: Alignment.topLeft,
child: Image.network(
"http://via.placeholder.com/640x360",
width: double.infinity,
)),
RaisedButton(
child: Text('enlarge text'),
onPressed: () {
textSize = textSize + 1.0;
print(textSize);
setState(() {});
},
),
Padding(
padding: const EdgeInsets.all(10.0),
child: ClipRRect(
borderRadius: BorderRadius.circular(10),
child: Container(
color: Colors.white.withOpacity(0.6),
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Text(
"story",
style: TextStyle(fontSize: textSize),
),
))),
)
],
),
),
);
}
}