Виджет 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
Другие вопросы по тегам