controller.dart
1.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/*
* @Author: 卢靖康
* @Date: 2024-04-24 08:22:16
* @LastEditTime: 2024-04-24 11:05:00
* @LastEditors: 卢靖康
*/
import 'dart:convert';
import 'package:get/get.dart';
import 'package:flutter/material.dart';
import 'package:flutter_inappwebview/flutter_inappwebview.dart';
class MapController extends GetxController {
MapController();
GlobalKey webViewKey = GlobalKey();
InAppWebViewController? webViewController;
final InAppLocalhostServer localhostServer = InAppLocalhostServer(
documentRoot: './assets/',
);
_initData() {
update(["map"]);
}
setMapWebviewController(InAppWebViewController controller) {
webViewController = controller;
}
void _setupPostMessageListeners(InAppWebViewController controller) {}
void onWebViewCreated(InAppWebViewController controller) {
setMapWebviewController(controller);
_setupPostMessageListeners(controller);
}
void onLoadStart(controller, url) {}
void onLoadStop(controller, url) {}
@override
Future<void> onInit() async {
super.onInit();
await localhostServer.start();
}
@override
void onReady() {
super.onReady();
_initData();
}
// @override
// void onClose() {
// super.onClose();
// }
}
class JSBridge {
final InAppWebViewController _webViewController;
JSBridge(this._webViewController);
Future<void> callHandler(String handlerName,
[Map<String, dynamic> data = const {}]) async {
await _webViewController.evaluateJavascript(source: """
window.$handlerName(${jsonEncode(data)});
""");
}
Future<void> addListener(String eventName, callback) async {
_webViewController.addJavaScriptHandler(
handlerName: eventName,
callback: (result) {
callback(result);
});
}
Future<void> removeListener(String eventName) async {
_webViewController.removeJavaScriptHandler(handlerName: eventName);
}
}