Виджет IconButton в моем приложении флаттера отображается за 2-3 секунды. Почему это происходит?
Я новичок во флаттере. У меня есть два IconButtons в моем приложении для Android. Когда я запускаю приложение, два IconButtons занимают 2 секунды для рендеринга после рендеринга всех других компонентов.
Это мой код, в конце используются IconButtons:
class MyHomePageState extends State<MyHomePage> {
late Widget _iconButton1;
late Widget _iconButton2;
@override
void initState() {
_iconButton1 = IconButton(
padding: const EdgeInsets.all(0),
iconSize: 80,
onPressed: () {
setTime();
setState(() {});
},
icon: Image.asset("assets/reset_big.png"),
);
_iconButton2 = IconButton(
padding: const EdgeInsets.all(0),
iconSize: 80,
onPressed: () {
datePicker();
setState(() {});
},
icon: Image.asset("assets/calendar_big.png"),
);
super.initState();
count();
setState(() {});
}
@override
Widget build(BuildContext context) {
return Container(
decoration: const BoxDecoration(
image: DecorationImage(
image: AssetImage("assets/bgimg.jpg"), fit: BoxFit.cover),
),
child: Scaffold(
backgroundColor: Colors.transparent,
appBar: AppBar(
title: Column(
children: <Widget>[
const SizedBox(
height: 20,
),
Text(
widget.title,
style: const TextStyle(
fontFamily: 'Poppins', fontSize: 40, color: Colors.white60),
),
],
),
elevation: 0,
backgroundColor: Colors.transparent,
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Stack(
alignment: Alignment.center,
children: [
BlurryContainer(
blur: 0,
height: 150,
width: 150,
color: Colors.transparent,
borderRadius: const BorderRadius.all(Radius.circular(100)),
child: Center(
child: Text(
'$curr',
style: const TextStyle(
fontFamily: 'Rubik',
fontSize: 80,
color: Color.fromARGB(255, 240, 238, 243)),
),
),
),
],
),
],
),
),
floatingActionButton: Column(
mainAxisAlignment: MainAxisAlignment.end,
children: [
Container(
decoration: const BoxDecoration(
shape: BoxShape.circle,
color: Colors.transparent,
),
child: _iconButton1),
const SizedBox(
height: 10,
),
_iconButton2
FloatingActionButton(onPressed: () {
Navigator.push(context,
MaterialPageRoute(builder: (context) => SettingsScreen()));
})
],
),
),
);
}
}
и когда я отлаживаю приложение, я получаю это в консоли. Не знаю, связано ли это с проблемой.
I/MSHandlerLifeCycle(16618): isMultiSplitHandlerRequested: windowingMode=1 isFullscreen=true isPopOver=false isHidden=false skipActivityType=false isHandlerType=true this: [email protected] [ MainActivity ]
Я думал, что это произошло из-за того, что виджеты перестраивались, и изменил мой код, поскольку в этом посте говорится « Предотвратить перестроение виджета» . Но это не имеет никакого эффекта.
Я хочу, чтобы кнопки отображались так же, как и другие компоненты.
1 ответ
Размер вашего изображения, вероятно, слишком велик.
"assets/calendar_big.png"
"assets/reset_big.png"
Пожалуйста, проверьте размеры.
Кроме того, предварительно кэшируйте изображение, подобное этому, внутри initState.
precacheImage(AssetImage("assets/calendar_big.png"), context);
precacheImage(AssetImage("assets/reset_big.png"), context);
Почему вы инициализируете виджеты внутри initState?
Удалите их из initState
_iconButton1 = IconButton(
padding: const EdgeInsets.all(0),
iconSize: 80,
onPressed: () {
setTime();
setState(() {});
},
icon: Image.asset("assets/reset_big.png"),
);
_iconButton2 = IconButton(
padding: const EdgeInsets.all(0),
iconSize: 80,
onPressed: () {
datePicker();
setState(() {});
},
icon: Image.asset("assets/calendar_big.png"),
);
Добавляйте их непосредственно там, где они необходимы, вместо_iconButton1
и_iconButton2
.
child: _iconButton1
_iconButton2