Flutter AssetImage не может загружаться в первый раз при построении дерева виджетов - PullRequest
1 голос
/ 07 мая 2020

Я создаю приложение Hangman во Flutter и хочу, чтобы основное изображение обновлялось до другого, когда жизнь уменьшается. Проблема в том, что когда я впервые запускаю приложение, я получаю эту ошибку:

I/flutter (21336): ══╡ EXCEPTION CAUGHT BY IMAGE RESOURCE SERVICE ╞════════════════════════════════════════════════════
I/flutter (21336): The following assertion was thrown resolving an image codec:
I/flutter (21336): Unable to load asset: assets/Hangman 10.png
I/flutter (21336): 
I/flutter (21336): When the exception was thrown, this was the stack:
I/flutter (21336): #0      PlatformAssetBundle.load (package:flutter/src/services/asset_bundle.dart:221:7)
I/flutter (21336): <asynchronous suspension>
I/flutter (21336): #1      AssetBundleImageProvider._loadAsync (package:flutter/src/painting/image_provider.dart:484:44)
I/flutter (21336): #2      AssetBundleImageProvider.load (package:flutter/src/painting/image_provider.dart:469:14) 
I/flutter (21336): #3      ImageProvider.resolve.<anonymous closure>.<anonymous closure>.<anonymous closure> (package:flutter/src/painting/image_provider.dart:327:17)
I/flutter (21336): #4      ImageCache.putIfAbsent (package:flutter/src/painting/image_cache.dart:160:22)
I/flutter (21336): #5      ImageProvider.resolve.<anonymous closure>.<anonymous closure> (package:flutter/src/painting/image_provider.dart:325:84)
I/flutter (21336): (elided 13 frames from package dart:async)
I/flutter (21336):
I/flutter (21336): Image provider: AssetImage(bundle: null, name: "assets/Hangman 10.png")
I/flutter (21336): Image key: AssetBundleImageKey(bundle: PlatformAssetBundle#133ec(), name: "assets/Hangman 10.png",
I/flutter (21336):   scale: 1.0)
I/flutter (21336): ════════════════════════════════════════════════════════════════════════════════════════════════════

А затем, если я просто перезагружаю, изображение загружается, и приложение работает нормально. Мой врач-флаттер говорит, что все в порядке:

Doctor summary (to see all details, run flutter doctor -v):
[√] Flutter (Channel stable, v1.12.13+hotfix.9, on Microsoft Windows [Version 10.0.18363.778], locale en-US)

[√] Android toolchain - develop for Android devices (Android SDK version 29.0.3)
[√] Android Studio (version 3.6)
[√] VS Code (version 1.44.2)
[√] Connected device (1 available)

• No issues found!

Это структура моих папок имя и расположение изображения актива

И мой файл main.dart

import 'package:flutter/material.dart';
import 'nouns.dart';
import 'keyboard_ws.dart';

void main() => runApp(MaterialApp(home: Home()));

String word = 'wordToBeGuessed'
int lives = 10;
List<String> lettersEntered = [];


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

String word = 'savannah';
int lives = 10;
List<String> lettersEntered = [];
List<String> wordShowList = List.filled(word.length, '_');
String displayWord = wordShowList.join(' ');

class HomeState extends State<Home> {
@override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Hangman'),
        centerTitle: true,
      ),
      body: Column(
        crossAxisAlignment: CrossAxisAlignment.stretch,
        children: <Widget>[
          Expanded(
              child: Container(
            padding: EdgeInsets.symmetric(vertical: 30, horizontal: 20),
            child: Image(
              image: AssetImage('assets/Hangman $lives.png'),
              gaplessPlayback: true,
            ),
          )),
          Container(
            child: Text(
              displayWord,
              style: TextStyle(fontSize: 30),
            ),
          ),
          Keyboard(lettersEntered, sendKey)
        ],
      ),
    );
  }
}

На папку с моими ресурсами имеется ссылка в моем файле pubspe c .yaml, например:

flutter:
  assets:
  - assets/

1 Ответ

1 голос
/ 07 мая 2020

Причина: в имени вашего изображения есть пробел
Решение: Unable to load asset" when the asset path contains a space https://github.com/flutter/flutter/issues/47705#issuecomment -621728294
Уже исправлено в текущей бета-версии v1.17.0-3.2.pre и dev v1.18.0-6.0.pre (но не в стабильной v1.12.13+hotfix.9)
Вы можете рассмотреть возможность перехода на новую версию

рабочая демонстрация

enter image description here

полный код

import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {  
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(       
        primarySwatch: Colors.blue,       
        visualDensity: VisualDensity.adaptivePlatformDensity,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key, this.title}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int _counter = 0;

  void _incrementCounter() {
    setState(() {     
      _counter++;
    });
  }

  @override
  Widget build(BuildContext context) {    
    return Scaffold(
      appBar: AppBar(       
        title: Text(widget.title),
      ),
      body: Center(        
        child: Column(          
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Expanded(
                child: Container(
                  padding: EdgeInsets.symmetric(vertical: 30, horizontal: 20),
                  child: Image(
                    image: AssetImage('assets/images/alarm space.png'),
                    gaplessPlayback: true,
                  ),
                )),
            Text(
              'You have pushed the button this many times:',
            ),
            Text(
              '$_counter',
              style: Theme.of(context).textTheme.headline4,
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: _incrementCounter,
        tooltip: 'Increment',
        child: Icon(Icons.add),
      ),
    );
  }
}
...