Compare commits

..

No commits in common. "bda8bb557087de8af8fdf1142d030fddd4d2d805" and "cef32273752e8418dcac573f7c10880f7e4f8c60" have entirely different histories.

8 changed files with 189 additions and 388 deletions

View File

@ -1,102 +1,20 @@
class JavaScriptString { class JavaScriptString {
/// ///
static String clickEventJSString = static String clickEventkJSString =
'''document.addEventListener('click', function(event) { '''document.addEventListener('click', function(event) {
var x = event.clientX; var x = event.clientX;
var y = event.clientY; var y = event.clientY;
console.log('点击坐标x=' + x + ', y=' + y); console.log('点击坐标x=' + x + ', y=' + y);
window.flutter_inappwebview.callHandler('click', x, y); window.flutter_inappwebview.callHandler('Click', x, y);
});'''; });''';
///
static String touchendEventJSString =
'''document.addEventListener('touchend', function(event) {
var x = event.changedTouches[0].clientX;
var y = event.changedTouches[0].clientY;
//
var target = event.target;
// class和id
var targetClass = target.className;
var targetId = target.id;
console.log('Class: ' + targetClass);
console.log('Id: ' + targetId);
console.log('触摸坐标x=' + x + ', y=' + y);
window.flutter_inappwebview.callHandler('touchend', x, y);
});''';
/// 退
static String loginOutJsString = '''
\$.ajax({
type: "GET",
url: "/api/logout.do",
success: function(t) {
"index.html" != location.pathname ? window.location.href = "index.html" : location.reload()
},
error: function(t) {
var e = \$.parseJSON(t.responseText + "");
alert(e.msg, 2)
}
})
''';
/// ///
static String clickJSString(int x, int y) { static String clickJSString(int x, int y) {
return 'document.elementFromPoint($x, $y).click();'; return 'document.elementFromPoint($x, $y).click();';
} }
///
static String touchendJsString(int x, int y) {
return '''
''';
}
///
static String getClassTouchendJsString(int x, int y) {
return '''
try{
//
var x = $x;
var y = $y;
// touchstart事件
var touchstartEvent = new TouchEvent('touchstart', {
bubbles: true,
cancelable: true,
view: window,
changedTouches: [new Touch({ identifier: Date.now(), target: document.body, clientX: x, clientY: y })],
targetTouches: [new Touch({ identifier: Date.now(), target: document.body, clientX: x, clientY: y })]
});
// touchstartEvent
document.body.dispatchEvent(touchstartEvent);
// touchend事件
var touchendEvent = new TouchEvent('touchend', {
bubbles: true,
cancelable: true,
view: window,
changedTouches: [new Touch({ identifier: Date.now(), target: document.body, clientX: x, clientY: y })],
targetTouches: [new Touch({ identifier: Date.now(), target: document.body, clientX: x, clientY: y })]
});
// touchend事件
document.body.dispatchEvent(touchendEvent);
} catch (t) {
console.log('模拟触摸错误 -- ' + t);
}
''';
}
/// ///
static String inputJsString(int value) { static String inputJsString(int value) {
return ''' return '''
@ -106,7 +24,7 @@ var inputEvent = new Event('input', {
cancelable: true, cancelable: true,
}); });
var inputElement = document.querySelector(".input"); var inputElement = document.querySelector(".bet-money");
inputElement.value = "$value"; inputElement.value = "$value";

View File

@ -1,12 +1,8 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:web_synchronization_tool/main_page.dart'; import 'package:web_synchronization_tool/main_page.dart';
import 'package:web_synchronization_tool/windows/windows_main_page.dart'; import 'package:web_synchronization_tool/windows/windows_main_page.dart';
import 'package:webview_windows/webview_windows.dart';
void main() async {
// await InAppWebViewController.setWebContentsDebuggingEnabled(true);
void main() {
runApp(const MyApp()); runApp(const MyApp());
} }
@ -22,8 +18,8 @@ class MyApp extends StatelessWidget {
colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple), colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
useMaterial3: true, useMaterial3: true,
), ),
// home: const MainPage(), home: const MainPage(),
home: const WindowsPage(), // home: const WindowsPage(),
); );
} }
} }

View File

@ -1,145 +1,116 @@
// import 'package:flutter/material.dart';
// import 'package:flutter/material.dart'; import 'package:flutter_inappwebview/flutter_inappwebview.dart';
// import 'package:flutter_inappwebview/flutter_inappwebview.dart'; import 'package:web_synchronization_tool/web_widget.dart';
// import 'package:web_synchronization_tool/web_widget.dart';
// import 'JavaScriptString.dart';
// import 'JavaScriptString.dart';
// class MainPage extends StatefulWidget {
// class MainPage extends StatefulWidget { const MainPage({super.key});
// const MainPage({super.key});
// @override
// @override State<MainPage> createState() => _MainPageState();
// State<MainPage> createState() => _MainPageState(); }
// }
// class _MainPageState extends State<MainPage> {
// class _MainPageState extends State<MainPage> {
// late InAppWebViewController mainController;
// late InAppWebViewController mainController; late InAppWebViewController controller;
// late InAppWebViewController controller;
// @override
// bool asyncState = false; void initState() {
// super.initState();
// @override
// void initState() {
// super.initState(); }
//
// } ///
// addClickEventJS(){
// @override
// void dispose() { final clickJsUS = UserScript(groupName: 'click',source: JavaScriptString.clickEventkJSString, injectionTime: UserScriptInjectionTime.AT_DOCUMENT_START);
// super.dispose();
// mainController.addUserScript(userScript: clickJsUS);
// WebStorageManager.instance().deleteAllData();
// } mainController.addJavaScriptHandler(handlerName: 'Click', callback: (args){
// controller.evaluateJavascript(source: JavaScriptString.clickJSString(args.first, args.last) );
// /// });
// addTouchendEventJS(){
// }
// final clickJsUS = UserScript(groupName: 'touchend',source: JavaScriptString.touchendEventJSString, injectionTime: UserScriptInjectionTime.AT_DOCUMENT_START);
// mainController.addUserScript(userScript: clickJsUS); @override
// Widget build(BuildContext context) {
// mainController.addJavaScriptHandler(handlerName: 'touchend', callback: (args){ return Scaffold(
// if (asyncState){ body: Column(
// int x = double.parse(args.first.toString()).toInt(); children: [
// int y = double.parse(args.last.toString()).toInt(); Container(
// controller.evaluateJavascript(source: JavaScriptString.clickJSString(x, y) ); height: 50,
// // controller.evaluateJavascript(source: JavaScriptString.touchendJsString(x, y) ); color: Colors.white,
// // controller.evaluateJavascript(source: JavaScriptString.getClassTouchendJsString(x, y) ); padding: const EdgeInsets.symmetric(horizontal: 50),
// } child: Row(
// }); children: [
// TextButton(
// } onPressed: () {
// controller.evaluateJavascript(source: JavaScriptString.clickJSString(600, 280) );
// @override },
// Widget build(BuildContext context) { child: const Text('模拟点击测试')),
// return Scaffold( TextButton(
// body: Column( onPressed: () {
// crossAxisAlignment: CrossAxisAlignment.stretch, mainController.evaluateJavascript(source: JavaScriptString.inputJsString(45) );
// children: [ controller.evaluateJavascript(source: JavaScriptString.inputJsString(45) );
// Container( },
// height: 50, child: const Text('模拟输入测试')),
// color: Colors.white, const SizedBox(
// padding: const EdgeInsets.symmetric(horizontal: 50), width: 50,
// child: Row( child: TextField(
// children: [ keyboardType: TextInputType.number,
// TextButton( decoration: InputDecoration(prefixText: '网页数量'),
// onPressed: () { ),
// controller.evaluateJavascript(source: JavaScriptString.clickJSString(50, 100) ); )
// }, ],
// child: const Text('模拟点击测试')), ),
// TextButton( ),
// onPressed: () { Expanded(child: pageViewWidget()),
// mainController.evaluateJavascript(source: JavaScriptString.inputJsString(45) ); ],
// controller.evaluateJavascript(source: JavaScriptString.inputJsString(45) ); ),
// }, );
// child: const Text('模拟输入测试')), }
// Row(
// children: [ Widget pageViewWidget() {
// const Text('同步'), return PageView(
// Switch(value: asyncState, onChanged: (value){ children: <Widget>[
// setState(() { KeepAlivePage(
// asyncState = value; child: WebWidget(controlerCallBack: (_mainController) {
// }); mainController = _mainController;
// })
// ], addClickEventJS();
// ) }),
// ], ),
// ), KeepAlivePage(
// ), child: WebWidget(controlerCallBack: (_controller) {
// Expanded(child: pageViewWidget()), controller = _controller;
// ], }),
// ), )
// ); ],
// } );
// }
// Widget pageViewWidget() {
// return Row( }
// children: <Widget>[
// Expanded( class KeepAlivePage extends StatefulWidget {
// child: Container( final Widget child;
// color: Colors.yellow,
// child: KeepAlivePage( KeepAlivePage({super.key , required this.child});
// child: WebWidget(controlerCallBack: (_mainController) {
// mainController = _mainController; @override
// _KeepAlivePageState createState() => _KeepAlivePageState();
// addTouchendEventJS(); }
//
// }), class _KeepAlivePageState extends State<KeepAlivePage> with AutomaticKeepAliveClientMixin {
// ), @override
// ), bool get wantKeepAlive => true;
// ),
// Expanded( @override
// child: Container( Widget build(BuildContext context) {
// color: Colors.blue, super.build(context);
// child: KeepAlivePage( return widget.child;
// child: WebWidget(controlerCallBack: (_controller) { }
// controller = _controller; }
// }),
// ),
// ),
// )
// ],
// );
// }
//
// }
//
// class KeepAlivePage extends StatefulWidget {
// final Widget child;
//
// KeepAlivePage({super.key , required this.child});
//
// @override
// _KeepAlivePageState createState() => _KeepAlivePageState();
// }
//
// class _KeepAlivePageState extends State<KeepAlivePage> with AutomaticKeepAliveClientMixin {
// @override
// bool get wantKeepAlive => true;
//
// @override
// Widget build(BuildContext context) {
// super.build(context);
// return widget.child;
// }
// }

View File

@ -1,42 +1,31 @@
// import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
// import 'package:flutter_inappwebview/flutter_inappwebview.dart'; import 'package:flutter_inappwebview/flutter_inappwebview.dart';
// import 'package:web_synchronization_tool/JavaScriptString.dart'; import 'package:web_synchronization_tool/JavaScriptString.dart';
//
// class WebWidget extends StatefulWidget { class WebWidget extends StatefulWidget {
// WebWidget({super.key, required this.controlerCallBack}); WebWidget({super.key, required this.controlerCallBack});
//
// final Function(InAppWebViewController) controlerCallBack; final Function(InAppWebViewController) controlerCallBack;
//
// @override @override
// State<WebWidget> createState() => _WebWidgetState(); State<WebWidget> createState() => _WebWidgetState();
// } }
//
// class _WebWidgetState extends State<WebWidget> { class _WebWidgetState extends State<WebWidget> {
// @override @override
// void initState() { void initState() {
// super.initState(); super.initState();
// } }
//
// @override @override
// Widget build(BuildContext context) { Widget build(BuildContext context) {
// return InAppWebView( return InAppWebView(
// initialUrlRequest: initialUrlRequest:
// URLRequest(url: WebUri('http://www.df6831.com/mobile')),// URLRequest(url: WebUri('http://www.df6831.com/game/')),
// initialSettings: InAppWebViewSettings( initialSettings: InAppWebViewSettings(initialScale: 200,loadWithOverviewMode: false,useWideViewPort: false),
// // initialScale: 180, onWebViewCreated: (_controller) {
// loadWithOverviewMode: false, widget.controlerCallBack(_controller);
// useWideViewPort: false, },
// // preferredContentMode: UserPreferredContentMode.MOBILE, );
// // cacheEnabled: false, // }
// // clearSessionCache: true,// }
// // databaseEnabled:false, //
// // domStorageEnabled: false,// dom
// incognito: true, //
// sharedCookiesEnabled: false, // Cookie
// ),
// onWebViewCreated: (_controller) {
// widget.controlerCallBack(_controller);
// },
// );
// }
// }

View File

@ -1,56 +0,0 @@
class WindowsJs {
///
static String clickEventJs = '''
document.addEventListener('click', function(event) {
var x = event.clientX;
var y = event.clientY;
var value = {"x":x,"y":y};
window.chrome.webview.postMessage(value);
// 'btn'
if (event.target.classList.contains('btn')) {
//
var buttonText = event.target.innerText;
var btn = {"x":"成功获取到btn","y":buttonText};
window.chrome.webview.postMessage(btn);
//
event.preventDefault();
//
window.location.href = "http://www.df6831.com/game/";
}
});''';
///
static String clickJs(int x, int y) {
return 'document.elementFromPoint($x, $y).click();';
}
///
static String inputJsString(int value) {
return '''
var inputEvent = new Event('input', {
bubbles: true,
cancelable: true,
});
var inputElement = document.querySelector(".input");
inputElement.value = "$value";
inputElement.dispatchEvent(inputEvent);
''';
}
static String zoom(int zoom){
assert(zoom >= 1 && zoom <= 100, 'zoom 1 到 100');
return '''
// document.body.style.zoom = "$zoom%";
document.body.style.transformOrigin = 'top left';
document.body.style.transform = 'scale(${zoom / 100})';
''';
}
}

View File

@ -1,5 +1,4 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:web_synchronization_tool/windows/windowsJs.dart';
import 'windows_web_page.dart'; import 'windows_web_page.dart';
import 'package:webview_windows/webview_windows.dart'; import 'package:webview_windows/webview_windows.dart';
@ -26,7 +25,6 @@ class _WindowsPageState extends State<WindowsPage> {
} }
Future controllerInit() async { Future controllerInit() async {
await mainController.initialize(); await mainController.initialize();
await controller.initialize(); await controller.initialize();
@ -35,6 +33,7 @@ class _WindowsPageState extends State<WindowsPage> {
controller.clearCache(); controller.clearCache();
controller.clearCookies(); controller.clearCookies();
mainController.loadUrl('http://www.df6831.com/'); mainController.loadUrl('http://www.df6831.com/');
controller.loadUrl('http://www.df6831.com/'); controller.loadUrl('http://www.df6831.com/');
@ -43,27 +42,22 @@ class _WindowsPageState extends State<WindowsPage> {
setState(() { setState(() {
initDone = true; initDone = true;
}); });
// controller.setUserAgent('Mobile');
///
mainController.webMessage.listen((event) {
print('mainController listen -- $event');
controller.executeScript(WindowsJs.clickJs(event['x'], event['y']));
});
///
controller.webMessage.listen((event) {
// print('controller listen -- $event');
});
} }
/// ///
addClickEventJS() { addClickEventJS() {
mainController.addScriptToExecuteOnDocumentCreated(WindowsJs.clickEventJs);
controller.addScriptToExecuteOnDocumentCreated(WindowsJs.clickEventJs); controller.executeScript('document.documentElement.innerHTML').then((value){
print(value);
});
mainController.addScriptToExecuteOnDocumentCreated(
JavaScriptString.clickEventkJSString).then((value){
print(value);
});
} }
@override @override
@ -81,39 +75,33 @@ class _WindowsPageState extends State<WindowsPage> {
children: [ children: [
TextButton( TextButton(
onPressed: () { onPressed: () {
mainController.executeScript(WindowsJs.clickJs(200, 900)); controller.executeScript(
// controller.executeScript(WindowsJs.clickJs(600, 100)); JavaScriptString.clickJSString(600, 280)).then((value){
print(value);
});
}, },
child: const Text('模拟点击测试')), child: const Text('模拟点击测试')),
TextButton( TextButton(
onPressed: () { onPressed: () {
mainController.executeScript(WindowsJs.inputJsString(45)); mainController
controller.executeScript(WindowsJs.inputJsString(45)); .executeScript(JavaScriptString.inputJsString(45));
controller
.executeScript(JavaScriptString.inputJsString(45));
}, },
child: const Text('模拟输入测试')), child: const Text('模拟输入测试')),
TextButton( TextButton(
onPressed: () { onPressed: () {
mainController.loadUrl('http://www.df6831.com/'); mainController.loadUrl('http://www.df6831.com/game/');
// controller.loadUrl('http://www.df6831.com/game/');
}, },
child: const Text('跳转首页')), child: const Text('跳转')),
TextButton( const SizedBox(
onPressed: () { width: 50,
mainController.executeScript(WindowsJs.zoom(70)); child: TextField(
controller.executeScript(WindowsJs.zoom(40)); keyboardType: TextInputType.number,
}, decoration: InputDecoration(prefixText: '网页数量'),
child: const Text('缩放')), ),
TextButton( )
onPressed: () {
mainController.openDevTools();
},
child: const Text('开发者')),
TextButton(
onPressed: () {
mainController.clearCookies();
mainController.clearCache();
},
child: const Text('清除缓存')),
], ],
), ),
), ),
@ -127,16 +115,12 @@ class _WindowsPageState extends State<WindowsPage> {
Widget pageViewWidget() { Widget pageViewWidget() {
return Row( return Row(
children: [ children: [
SizedBox( Expanded(
width: 1000,
height: 1000,
child: WindowsWebWidget( child: WindowsWebWidget(
controller: mainController, controller: mainController,
), ),
), ),
SizedBox( Expanded(
width: 500,
height:400,
child: WindowsWebWidget( child: WindowsWebWidget(
controller: controller, controller: controller,
), ),

View File

@ -21,7 +21,7 @@ class _WindowsWebWidgetState extends State<WindowsWebWidget> {
} }
Widget inWindowsWebView(){ Widget inWindowsWebView(){
return Webview(widget.controller); return Webview(widget.controller,);
} }
} }

View File

@ -12,9 +12,8 @@ dependencies:
sdk: flutter sdk: flutter
cupertino_icons: ^1.0.2 cupertino_icons: ^1.0.2
webview_windows: flutter_inappwebview: ^6.0.0
path: ../flutter-webview-windows-main webview_windows: ^0.4.0
window_manager:
dev_dependencies: dev_dependencies:
flutter_test: flutter_test: