Вы можете скопировать вставку, запустить полный код и index.html
ниже
Вы можете использовать пакет https://pub.dev/packages/flutter_inappwebview
В рабочей демонстрации вы можете увидеть значок флаттера <img src="images/flutter-logo.svg" alt="flutter logo">
отображается правильно
Шаг 1: добавьте android:usesCleartextTraffic="true"
в AndroidManifest.xml
Шаг 2: pubspec.yaml
настройка
assets:
- assets/images/
- assets/
Шаг 3: Добавьте файлы и изображения в assets
папку
data:image/s3,"s3://crabby-images/70858/70858664a8f5b2f0acaddb211951c4c6948a622a" alt="enter image description here"
working demo
data:image/s3,"s3://crabby-images/9994c/9994ceb36d65e5899bcc83375ac5e72f50a2a634" alt="enter image description here"
full code
import 'package:flutter/material.dart';
import 'package:flutter_inappwebview/flutter_inappwebview.dart';
InAppLocalhostServer localhostServer = new InAppLocalhostServer();
Future main() async {
WidgetsFlutterBinding.ensureInitialized();
await localhostServer.start();
runApp(new MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: const Text('InAppWebView Example'),
),
body: Container(
child: Column(children: [
Expanded(
child: Container(
child: InAppWebView(
initialUrl: "http://localhost:8080/assets/index.html",
initialHeaders: {},
initialOptions: InAppWebViewGroupOptions(),
onWebViewCreated: (InAppWebViewController controller) {},
onLoadStart: (InAppWebViewController controller, String url) {},
onLoadStop: (InAppWebViewController controller, String url) {},
),
),
)
])),
),
);
}
}
index.html
Flutter InAppWebView