Я делаю свое первое приложение Flutter, и у меня есть вопрос. Я использую плагин flutter_inappwebview и хочу показать полноэкранную заставку/экран загрузки. Желательно с анимацией Лотти. Код, который у меня есть до сих пор:
Widget build(BuildContext context) {
SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle.dark);
return Scaffold(
body: Container(
child: Column(children: <Widget>[
Expanded(
child: Stack(
children: [
InAppWebView(
key: webViewKey,
initialUrlRequest:
URLRequest(url: Uri.parse("https://www.google.com")),
initialUserScripts: UnmodifiableListView<UserScript>([]),
initialOptions: options,
pullToRefreshController: pullToRefreshController,
onWebViewCreated: (controller) {
webViewController = controller;
},
onLoadStart: (controller, url) async {
setState(() {
this.url = url.toString();
urlController.text = this.url;
});
},
androidOnPermissionRequest:
(controller, origin, resources) async {
return PermissionRequestResponse(
resources: resources,
action: PermissionRequestResponseAction.GRANT);
},
shouldOverrideUrlLoading:
(controller, navigationAction) async {
var uri = navigationAction.request.url!;
if (![
"http",
"https",
"file",
"chrome",
"data",
"javascript",
"about"
].contains(uri.scheme)) {
if (await canLaunch(url)) {
// Launch the App
await launch(
url,
);
// and cancel the request
return NavigationActionPolicy.CANCEL;
}
}
return NavigationActionPolicy.ALLOW;
},
onLoadStop: (controller, url) async {
},
onLoadError: (controller, url, code, message) {
pullToRefreshController.endRefreshing();
},
onProgressChanged: (controller, progress) {
if (progress == 100) {
pullToRefreshController.endRefreshing();
}
setState(() {
this.progress = progress / 100;
urlController.text = this.url;
});
},
onUpdateVisitedHistory: (controller, url, androidIsReload) {
setState(() {
this.url = url.toString();
urlController.text = this.url;
});
},
onConsoleMessage: (controller, consoleMessage) {
print(consoleMessage);
},
),
],
),
),
])));
}
}
Я новичок во Flutter, поэтому, если у вас есть решение, сделайте его простым. Заранее спасибо!





Параметр onLoadStart позволяет узнать, когда начинается загрузка, поэтому вы никогда не сможете разместить там заставку, ваш второй вариант — использовать метод isLoading, который исходит из webviewController, он возвращает true or false, когда страница полностью загружается и когда загружается.
Таким образом, вы можете использовать это и настроить заставку, а затем показать заставку, когда она есть true, и убрать ее, когда она есть false.
bool _isLoading = false;
@override
Widget build(BuildContext context) {
return Scaffold(
body:
Container(
child: _isLoading
? Center(
child: SpinKitChasingDots(
size: 50,
color: Colors.black,
))
: Column(children: <Widget>[
Expanded(
child: Stack(
children: [
InAppWebView(
key: webViewKey,
initialUrlRequest: URLRequest(
url: Uri.parse("https://www.google.com")),
initialUserScripts:
UnmodifiableListView<UserScript>([]),
initialOptions: options,
pullToRefreshController:
pullToRefreshController,
onWebViewCreated: (controller) {
webViewController = controller;
},
onLoadStart: (controller, url) async {
setState(() {
_isLoading = true;
});
},
androidOnPermissionRequest:
(controller, origin, resources) async {
return PermissionRequestResponse(
resources: resources,
action: PermissionRequestResponseAction
.GRANT);
},
shouldOverrideUrlLoading:
(controller, navigationAction) async {
var uri = navigationAction.request.url!;
if (![
"http",
"https",
"file",
"chrome",
"data",
"javascript",
"about"
].contains(uri.scheme)) {
if (await canLaunch(url)) {
// Launch the App
await launch(
url,
);
// and cancel the request
return NavigationActionPolicy.CANCEL;
}
}
return NavigationActionPolicy.ALLOW;
},
onLoadStop: (controller, url) async {
print("We are no longer loading");
setState(() {
_isLoading = false;
});
},
onLoadError: (controller, url, code, message) {
pullToRefreshController.endRefreshing();
},
onProgressChanged: (controller, progress) async{
setState(() {
_isLoading = false;
});
SpinKitChasingDots();
if (progress == 100) {
pullToRefreshController.endRefreshing();
}
setState(() {
this.progress = progress / 100;
urlController.text = this.url;
});
},
onUpdateVisitedHistory:
(controller, url, androidIsReload) {
setState(() {
this.url = url.toString();
// urlController.text = this.url;
});
},
onConsoleMessage: (controller, consoleMessage) {
print(consoleMessage);
},
),
],
),
),
])));
}
В этом примере я вручную устанавливаю _isLoading на true и false.
Это потому, что я понял, что вы мало что можете сделать с контроллером, если контроллер не собран, вот пример, если вы запустите его, вы заметите, что застряли на заставке.
bool _isLoading = false;
@override
Widget build(BuildContext context) {
return Scaffold(
body:
Container(
child: _isLoading
? Center(
child: SpinKitChasingDots(
size: 50,
color: Colors.black,
))
: Column(children: <Widget>[
Expanded(
child: Stack(
children: [
InAppWebView(
// key: webViewKey,
initialUrlRequest: URLRequest(
url: Uri.parse("https://www.google.com")),
initialUserScripts:
UnmodifiableListView<UserScript>([]),
// initialOptions: options,
pullToRefreshController:
pullToRefreshController,
onWebViewCreated: (controller) {
webViewController = controller;
},
onLoadStart: (controller, url) async {
setState(() {
_isLoading = true;
});
// setState(() {
// this.url = url.toString();
// urlController.text = this.url;
// });
},
androidOnPermissionRequest:
(controller, origin, resources) async {
return PermissionRequestResponse(
resources: resources,
action: PermissionRequestResponseAction
.GRANT);
},
shouldOverrideUrlLoading:
(controller, navigationAction) async {
var uri = navigationAction.request.url!;
if (![
"http",
"https",
"file",
"chrome",
"data",
"javascript",
"about"
].contains(uri.scheme)) {
if (await canLaunch(url)) {
// Launch the App
await launch(
url,
);
// and cancel the request
return NavigationActionPolicy.CANCEL;
}
}
return NavigationActionPolicy.ALLOW;
},
onLoadStop: (controller, url) async {
_isLoading = await controller.isLoading();
},
onLoadError: (controller, url, code, message) {
// pullToRefreshController.endRefreshing();
},
onProgressChanged: (controller, progress) async{
print("Gozimasu");
// bool loading = await controller.isLoading();
// setState(() {
_isLoading = await controller.isLoading();
// });
// SpinKitChasingDots();
// if (progress == 100) {
// pullToRefreshController.endRefreshing();
// }
// setState(() {
// this.progress = progress / 100;
// urlController.text = this.url;
// });
},
onUpdateVisitedHistory:
(controller, url, androidIsReload) {
setState(() {
this.url = url.toString();
// urlController.text = this.url;
});
},
onConsoleMessage: (controller, consoleMessage) {
print(consoleMessage);
},
),
],
),
),
])));
}
Вы тоже можете сделать это, вам просто нужно сначала создать виджет
Привет! Спасибо за ответ. Это сработало для меня! Спасибо за помощь мне. Можно ли сделать затухание анимации загрузки?