Как отображать графические ресурсы при переносе приложения-флаттера в веб-флаттер?
При попытке перенести приложение shrine на веб-страницу, но при миграции невозможно отобразить изображения (логотип shrine, помещенный в папку ресурсов) на локальном хосте, папка утверждений, содержащая изображения, помещается в веб-папку, как описано в руководстве по миграции Flutter Web, и обновляет дротик. код с правильным путем, но он по-прежнему не отображает изображения.
пожалуйста, предоставьте решение, спасибо!
login.dart
import 'package:flutter_web/material.dart';
class LoginPage extends StatefulWidget {
@override
_LoginPageState createState() => _LoginPageState();
}
class _LoginPageState extends State<LoginPage> {
// TODO: Add text editing controllers (101)
final _usernameController = TextEditingController();
final _passwordController = TextEditingController();
// TODO: Add text editing controllers (101)
@override
Widget build(BuildContext context) {
return Scaffold(
body: SafeArea(
child: ListView(
padding: EdgeInsets.symmetric(horizontal: 24.0),
children: <Widget>[
SizedBox(height: 80.0),
Column(
children: <Widget>[
Image.asset('web/assets/diamond.png'),
SizedBox(height: 16.0),
Text('SHRINE'),
],
),
SizedBox(height: 120.0),
// TODO: Wrap Username with AccentColorOverride (103)
// TODO: Remove filled: true values (103)
// TODO: Wrap Password with AccentColorOverride (103)
// TODO: Add TextField widgets (101)
// [Name]
TextField(
controller: _usernameController,
decoration: InputDecoration(
filled: true,
border: OutlineInputBorder(),
labelText: 'Username'),
),
SizedBox(
height: 12.0,
),
// [Password]
TextField(
controller: _passwordController,
decoration: InputDecoration(
filled: true,
border: OutlineInputBorder(),
labelText: 'Password',
),
obscureText: true,
),
// TODO: Add button bar (101)
ButtonBar(
children: <Widget>[
// Todo Add buttons (101)
RaisedButton(
child: Text('Cancel'),
onPressed: () {
// TODO: Clear the text fields (101)
_usernameController.clear();
_passwordController.clear();
}
),
// TODO: Add an elevation to NEXT (103)
// TODO: Add a beveled rectangular border to NEXT (103)
RaisedButton(
child: Text('NEXT'),
onPressed: () {
// TODO: Show the next page (101)
Navigator.pop(context);
},
),
],
),
],
),
),
);[enter image description here][1]
}
}
// TODO: Add AccentColorOverride (103)
1 ответ
Решение
Необходимо определить ресурс напрямую, не определяя его путь в ** предварительном просмотре веб-страниц **
Image.asset('diamond.png')