一直报错
[INFO:CONSOLE(17)] "Access to image at 'file:///android_asset/flutter_assets/assets/jump/box_bottom.png' from origin 'null' has been blocked by CORS policy: Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-untrusted, https.", source: file:///android_asset/flutter_assets/assets/jump/index.html (17)
flutter 的webview封装
下面的是加载本地html文件为网页展示
..loadFlutterAsset("assets/jump/index.html");
但是打包后的网页内图片访问 就出上面的问题了
想要解决
将图片转换成dataUrl 替换进前端代码中去
在线转换生成DataURL\DataUri、图片转为DataURL\DataUri--查错网
去掉file-loader
如
const box_bottom =
"";
const box_middle =
"";
const box_top =
"";
const Dot =
"";
const express =
"";
export { box_bottom, box_middle, box_top, Dot, express };
使用
import { express } from "../res/dataUrl";
import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
import 'package:webview_flutter/webview_flutter.dart';
enum GameStatus {
ready,
start,
stop,
}
class JumpGame extends StatefulWidget {
const JumpGame({super.key});
@override
State<JumpGame> createState() => _LocalViewState();
}
class _LocalViewState extends State<JumpGame> {
late WebViewController controller;
GameStatus curStatus = GameStatus.ready;
@override
void initState() {
super.initState();
controller = WebViewController()
..setJavaScriptMode(JavaScriptMode.unrestricted)
..setBackgroundColor(const Color(0x00000000))
..setNavigationDelegate(
NavigationDelegate(
onProgress: (int progress) {
// Update loading bar.
},
onPageStarted: (String url) {},
onPageFinished: (String url) {},
onWebResourceError: (WebResourceError error) {},
),
)
..addJavaScriptChannel('App', onMessageReceived: onMessageReceived)
..loadFlutterAsset("assets/jump/index.html");
}
void onMessageReceived(JavaScriptMessage message) async {
final messageJson = json.decode(message.message);
print(messageJson);
final messageMethod = messageJson["method"];
final messageData = messageJson["data"] ?? {};
switch (messageMethod) {
case "start":
show(
Column(
mainAxisSize: MainAxisSize.min,
children: [
Text("开始"),
ElevatedButton(
onPressed: () {
SmartDialog.dismiss();
},
child: Text("开始"))
],
),
);
break;
case 'jumpSuccess':
// await Future.delayed(const Duration(milliseconds: 500));
show(
Center(
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
ElevatedButton(
style:
ElevatedButton.styleFrom(backgroundColor: Colors.orange),
onPressed: () {
SmartDialog.dismiss();
},
child: Text("继续"),
),
],
),
),
);
break;
case 'gameOver':
// await Future.delayed(const Duration(milliseconds: 500));
// Get.bottomSheet(
// isScrollControlled: true,
// ignoreSafeArea: true,
// isDismissible: false,
// backgroundColor: Colors.transparent,
// enableDrag: false,
// Container(
// height: 1.sh,
// width: double.infinity,
// color: Colors.red,
// child:
// ),
// );
show(Center(
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
ElevatedButton(
style: ElevatedButton.styleFrom(backgroundColor: Colors.orange),
onPressed: () {
SmartDialog.dismiss();
controller.reload();
},
child: Text("重新开始"),
),
],
),
));
break;
}
// ScaffoldMessenger.of(context).showSnackBar(
// SnackBar(content: Text(message.message)),
// );
}
void show(Widget child) {
SmartDialog.show(builder: (context) {
return Container(
height: 1.sh,
width: 1.sw,
color: Colors.black26,
alignment: Alignment.center,
child: child,
);
});
}
@override
Widget build(BuildContext context) {
return SafeArea(
top: false,
bottom: false,
child: Scaffold(
appBar: AppBar(
title: const Text(
'跳一跳',
style: TextStyle(color: Color(0xff333333)),
),
),
body: WebViewWidget(controller: controller),
),
);
}
}