我正在构建我的第一个应用来计算工作所需的价值。 我已经在Python中工作过,但这确实有所不同。 我有一个textformfield,可以在其中输入所需的数据。 成功后,我从“ onPress”按钮调用一个类并传递数据。 计算后,我需要将计算出的值显示在文本字段(spev)中。 我如何才能从“ Buisber”类中获取价值回文本字段。 我正在搜索几天,但是找不到它。 我确定我在某处读了它,但听不懂。 这里是剥离的版本:
import 'package:flutter/material.dart';
void main() {
runApp(MaterialApp(
home: Buis(),
));
}
class Buis extends StatelessWidget {
@override
Widget build(BuildContext context) {
String spev = '0';
TextEditingController kapController = TextEditingController(text: '10.60');
return Scaffold(
appBar: AppBar(
title: Center(
child: Text("Power Outcome"),
),
),
body: Center(
child: Container(
decoration: BoxDecoration(
),
child: SingleChildScrollView(
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
SizedBox(height: 20),
Column(
mainAxisAlignment: MainAxisAlignment.end,
children: <Widget>[
// Calculate
Center(
child: RaisedButton(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(18.0),
side: BorderSide(color: Colors.red)),
onPressed: () {
Buisber(
kapController.text);
},
color: Colors.blue,
textColor: Colors.white,
child: Text("Calculate".toUpperCase(),
style: TextStyle(fontSize: 14)),
),
),
// Outcome Spev
Container(
alignment: Alignment(0, 0),
width: 80,
height: 30,
decoration: BoxDecoration(
borderRadius: BorderRadius.horizontal(
left: Radius.circular(40),
right: Radius.circular(40),
),
border: Border.all(width: 1.0),
),
child: Text(
'$spev',
style: TextStyle(
fontSize: 15,
),
),
),
SizedBox(height: 10),
],
),
],
),
),
),
),
);
}
}
class Buisber {
Buisber(kap) {
var kap1 = double.parse(kap);
print(kap1);
var spev = 1.7 * (50 / kap1);
spev = num.parse(spev.toStringAsFixed(2));
//testing (print works)
//how to send back Outcome Spev
print("Spev is " '$spev');
}
}
答案 0 :(得分:1)
@Pim,为什么不创建一个函数而不是类,并在Stateful小部件中接收值?然后,您可以像这样刷新状态以更新值,
void main() {
runApp(new Buis());
}
class Buis extends StatefulWidget {
@override
BuisState createState() => BuisState();
}
class BuisState extends State<Buis> {
var value = '';
@override
Widget build(BuildContext context) {
String spev = '0';
TextEditingController kapController = TextEditingController(text: '10.60');
return MaterialApp(home: Scaffold(
appBar: AppBar(
title: Center(
child: Text("Power Outcome"),
),
),
body: Center(
child: Container(
decoration: BoxDecoration(
),
child: SingleChildScrollView(
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
SizedBox(height: 20),
Column(
mainAxisAlignment: MainAxisAlignment.end,
children: <Widget>[
// Calculate
Center(
child: RaisedButton(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(18.0),
side: BorderSide(color: Colors.red)),
onPressed: () {
value = getValue(kapController.text).toString();
setState(() {});
},
color: Colors.blue,
textColor: Colors.white,
child: Text("Calculate".toUpperCase(),
style: TextStyle(fontSize: 14)),
),
),
// Outcome Spev
Container(
alignment: Alignment(0, 0),
width: 80,
height: 30,
decoration: BoxDecoration(
borderRadius: BorderRadius.horizontal(
left: Radius.circular(40),
right: Radius.circular(40),
),
border: Border.all(width: 1.0),
),
child: Text(
value.toString(),
style: TextStyle(
fontSize: 15,
),
),
),
SizedBox(height: 10),
],
),
],
),
),
),
),
)
);
}
}
// This can be within your BuisState
getValue (kap) {
var kap1 = double.parse(kap);
print(kap1);
var spev = 1.7 * (50 / kap1);
spev = num.parse(spev.toStringAsFixed(2));
//testing (print works)
//how to send back Outcome Spev
print("Spev is " '$spev');
return spev;
}
希望这会有所帮助。