Compare commits
No commits in common. "master" and "受控" have entirely different histories.
|
|
@ -24,10 +24,10 @@ class SynchronizationWebTool{
|
||||||
/// 设置控制器时 注入js
|
/// 设置控制器时 注入js
|
||||||
setChildController(List<WebviewController> childControllers){
|
setChildController(List<WebviewController> childControllers){
|
||||||
|
|
||||||
// for (var controller in childControllers) {
|
for (var controller in childControllers) {
|
||||||
// controller.addScriptToExecuteOnDocumentCreated(WindowsJs.clickEventJs);
|
controller.addScriptToExecuteOnDocumentCreated(WindowsJs.clickEventJs);
|
||||||
// // controller.addScriptToExecuteOnDocumentCreated(WindowsJs.onloadZoom(90));
|
// controller.addScriptToExecuteOnDocumentCreated(WindowsJs.onloadZoom(90));
|
||||||
// }
|
}
|
||||||
|
|
||||||
_childControllers = childControllers;
|
_childControllers = childControllers;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,27 +4,14 @@ import 'package:web_synchronization_tool/windows/synchronization_web_tool.dart';
|
||||||
import 'package:webview_windows/webview_windows.dart';
|
import 'package:webview_windows/webview_windows.dart';
|
||||||
|
|
||||||
class WebGridController {
|
class WebGridController {
|
||||||
Function(WebviewController controller)? addWebControllerBlack;
|
|
||||||
Function? addWebBlack;
|
|
||||||
Function? addAllWebBlack;
|
|
||||||
|
|
||||||
addMainController(WebviewController controller) {
|
Function(WebviewController controller)? addWebControllerBlack;
|
||||||
|
|
||||||
|
addWebController(WebviewController controller) {
|
||||||
if (addWebControllerBlack != null) {
|
if (addWebControllerBlack != null) {
|
||||||
addWebControllerBlack!(controller);
|
addWebControllerBlack!(controller);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
addWeb() {
|
|
||||||
if (addWebBlack != null) {
|
|
||||||
addWebBlack!();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
addAllWeb() {
|
|
||||||
if (addAllWebBlack != null) {
|
|
||||||
addAllWebBlack!();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class WebGridWidget extends StatefulWidget {
|
class WebGridWidget extends StatefulWidget {
|
||||||
|
|
@ -37,56 +24,41 @@ class WebGridWidget extends StatefulWidget {
|
||||||
}
|
}
|
||||||
|
|
||||||
class _WebGridWidgetState extends State<WebGridWidget> {
|
class _WebGridWidgetState extends State<WebGridWidget> {
|
||||||
|
|
||||||
List<WebviewController> controllers = [];
|
List<WebviewController> controllers = [];
|
||||||
|
|
||||||
bool initDone = false;
|
bool initDone = false;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
super.initState();
|
super.initState();
|
||||||
|
|
||||||
widget.controller.addWebBlack = () {
|
controllerInit();
|
||||||
addController();
|
|
||||||
};
|
|
||||||
|
|
||||||
widget.controller.addAllWebBlack = () {
|
|
||||||
addAllController();
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 提娜佳一个网页
|
/// 控制器初始化
|
||||||
addController() async {
|
Future controllerInit() async {
|
||||||
if (controllers.length >= 10) return;
|
|
||||||
|
|
||||||
|
for (var i = 0; i< 10 ; i++) {
|
||||||
var controller = WebviewController();
|
var controller = WebviewController();
|
||||||
await controller.initialize();
|
await controller.initialize();
|
||||||
controller.loadUrl('https://www.df6831.com/');
|
controller.loadUrl('https://www.df6831.com/');
|
||||||
|
|
||||||
controllers.add(controller);
|
// controller.executeScript(WindowsJs.zoom(35));
|
||||||
SynchronizationWebTool.getInstance().setChildController(controllers);
|
// controller.addScriptToExecuteOnDocumentCreated(WindowsJs.onloadZoom(35));
|
||||||
setState(() {});
|
|
||||||
}
|
|
||||||
|
|
||||||
// 将网页加满到10个
|
|
||||||
addAllController() async {
|
|
||||||
final num = 10 - controllers.length;
|
|
||||||
if (num < 1) return;
|
|
||||||
|
|
||||||
for (int i = 0; i < num; i++) {
|
|
||||||
var controller = WebviewController();
|
|
||||||
await controller.initialize();
|
|
||||||
controller.loadUrl('https://www.df6831.com/');
|
|
||||||
controllers.add(controller);
|
controllers.add(controller);
|
||||||
}
|
}
|
||||||
|
|
||||||
SynchronizationWebTool.getInstance().setChildController(controllers);
|
SynchronizationWebTool.getInstance().setChildController(controllers);
|
||||||
setState(() {});
|
|
||||||
|
setState(() {
|
||||||
|
initDone = true;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Stack(
|
return GridView.builder(
|
||||||
children: [
|
|
||||||
GridView.builder(
|
|
||||||
gridDelegate: const SliverGridDelegateWithFixedCrossAxisCount(
|
gridDelegate: const SliverGridDelegateWithFixedCrossAxisCount(
|
||||||
crossAxisCount: 5, // 两列
|
crossAxisCount: 5, // 两列
|
||||||
crossAxisSpacing: 8.0, // 水平间距
|
crossAxisSpacing: 8.0, // 水平间距
|
||||||
|
|
@ -101,6 +73,7 @@ class _WebGridWidgetState extends State<WebGridWidget> {
|
||||||
overlayColor: MaterialStateProperty.resolveWith(
|
overlayColor: MaterialStateProperty.resolveWith(
|
||||||
(states) => Colors.transparent)),
|
(states) => Colors.transparent)),
|
||||||
onPressed: () {
|
onPressed: () {
|
||||||
|
|
||||||
var controller = controllers[index];
|
var controller = controllers[index];
|
||||||
// controller.executeScript(WindowsJs.zoom(100));
|
// controller.executeScript(WindowsJs.zoom(100));
|
||||||
|
|
||||||
|
|
@ -113,59 +86,26 @@ class _WebGridWidgetState extends State<WebGridWidget> {
|
||||||
|
|
||||||
Navigator.of(context).push(PageRouteBuilder(
|
Navigator.of(context).push(PageRouteBuilder(
|
||||||
opaque: false, // 设置路由本身透明
|
opaque: false, // 设置路由本身透明
|
||||||
pageBuilder: (BuildContext context, _, __) =>
|
pageBuilder: (BuildContext context, _, __) => ShowWebWidget(controller: controller,main: index == 0,),
|
||||||
ShowWebWidget(
|
|
||||||
controller: controller,
|
|
||||||
main: index == 0,
|
|
||||||
allLoadUrl: (String url) {
|
|
||||||
controllers.forEach((controller) {
|
|
||||||
controller.loadUrl(url);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
),
|
|
||||||
));
|
));
|
||||||
|
|
||||||
},
|
},
|
||||||
child: Container(),
|
child: Container(),
|
||||||
),
|
|
||||||
Container(
|
|
||||||
alignment: Alignment.topRight,
|
|
||||||
child: TextButton(
|
|
||||||
style: TextButton.styleFrom(padding: const EdgeInsets.all(0)),
|
|
||||||
onPressed: () {
|
|
||||||
controllers.removeAt(index);
|
|
||||||
SynchronizationWebTool.getInstance()
|
|
||||||
.setChildController(controllers);
|
|
||||||
setState(() {});
|
|
||||||
},
|
|
||||||
child: Container(
|
|
||||||
width: 50,
|
|
||||||
height: 50,
|
|
||||||
color: Colors.blue[100],
|
|
||||||
alignment: Alignment.center,
|
|
||||||
child: const Icon(Icons.clear)),
|
|
||||||
),
|
|
||||||
)
|
)
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
itemCount: controllers.length, // 生成20个瀑布流瓦片
|
itemCount: controllers.length, // 生成20个瀑布流瓦片
|
||||||
)
|
|
||||||
],
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class ShowWebWidget extends StatefulWidget {
|
class ShowWebWidget extends StatefulWidget {
|
||||||
const ShowWebWidget(
|
const ShowWebWidget({super.key, required this.controller, this.main = false});
|
||||||
{super.key,
|
|
||||||
required this.controller,
|
|
||||||
this.main = false,
|
|
||||||
required this.allLoadUrl});
|
|
||||||
|
|
||||||
final WebviewController controller;
|
final WebviewController controller;
|
||||||
|
|
||||||
final Function(String url) allLoadUrl;
|
|
||||||
|
|
||||||
final bool main;
|
final bool main;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
|
|
@ -173,9 +113,9 @@ class ShowWebWidget extends StatefulWidget {
|
||||||
}
|
}
|
||||||
|
|
||||||
class _ShowWebWidgetState extends State<ShowWebWidget> {
|
class _ShowWebWidgetState extends State<ShowWebWidget> {
|
||||||
|
|
||||||
/// 网址
|
/// 网址
|
||||||
TextEditingController urlController = TextEditingController();
|
TextEditingController urlController = TextEditingController();
|
||||||
|
|
||||||
/// 服务器ip
|
/// 服务器ip
|
||||||
TextEditingController ipController = TextEditingController();
|
TextEditingController ipController = TextEditingController();
|
||||||
|
|
||||||
|
|
@ -223,34 +163,14 @@ class _ShowWebWidgetState extends State<ShowWebWidget> {
|
||||||
input(){
|
input(){
|
||||||
return Row(
|
return Row(
|
||||||
children: [
|
children: [
|
||||||
SizedBox(
|
SizedBox(width: 400, child: TextField(style: const TextStyle(fontSize: 14),controller: urlController,)),
|
||||||
width: 400,
|
TextButton(onPressed: (){
|
||||||
child: TextField(
|
|
||||||
style: const TextStyle(fontSize: 14),
|
|
||||||
controller: urlController,
|
|
||||||
)),
|
|
||||||
TextButton(
|
|
||||||
onPressed: () {
|
|
||||||
String url = urlController.text;
|
String url = urlController.text;
|
||||||
// if (!url.startsWith("https://") ) {
|
// if (!url.startsWith("https://") ) {
|
||||||
// url = "https://$url";
|
// url = "https://$url";
|
||||||
// }
|
// }
|
||||||
widget.controller.loadUrl(url);
|
widget.controller.loadUrl(url);
|
||||||
},
|
}, child: const Text('跳转',style: TextStyle(fontSize: 14),))
|
||||||
child: const Text(
|
|
||||||
'跳转',
|
|
||||||
style: TextStyle(fontSize: 14),
|
|
||||||
)),
|
|
||||||
TextButton(
|
|
||||||
onPressed: () {
|
|
||||||
String url = urlController.text;
|
|
||||||
|
|
||||||
widget.allLoadUrl(url);
|
|
||||||
},
|
|
||||||
child: const Text(
|
|
||||||
'全部跳转',
|
|
||||||
style: TextStyle(fontSize: 14),
|
|
||||||
)),
|
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
@ -259,22 +179,15 @@ class _ShowWebWidgetState extends State<ShowWebWidget> {
|
||||||
ipController.text = SocketUtils.getInstance().url;
|
ipController.text = SocketUtils.getInstance().url;
|
||||||
return Row(
|
return Row(
|
||||||
children: [
|
children: [
|
||||||
SizedBox(
|
SizedBox(width: 100, child: TextField(style: const TextStyle(fontSize: 14),controller: ipController,)),
|
||||||
width: 100,
|
TextButton(onPressed: (){
|
||||||
child: TextField(
|
|
||||||
style: const TextStyle(fontSize: 14),
|
|
||||||
controller: ipController,
|
|
||||||
)),
|
|
||||||
TextButton(
|
|
||||||
onPressed: () {
|
|
||||||
SocketUtils.getInstance().url = ipController.text;
|
SocketUtils.getInstance().url = ipController.text;
|
||||||
SocketUtils.getInstance().connect();
|
SocketUtils.getInstance().connect();
|
||||||
},
|
}, child: const Text('保存服务器ip',style: TextStyle(fontSize: 14),))
|
||||||
child: const Text(
|
|
||||||
'保存服务器ip',
|
|
||||||
style: TextStyle(fontSize: 14),
|
|
||||||
))
|
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -52,7 +52,7 @@ class _WindowsPageState extends State<WindowsPage> {
|
||||||
|
|
||||||
mainController.loadUrl('http://www.df6831.com/');
|
mainController.loadUrl('http://www.df6831.com/');
|
||||||
|
|
||||||
gridController.addMainController(mainController);
|
gridController.addWebController(mainController);
|
||||||
|
|
||||||
setState(() {
|
setState(() {
|
||||||
initDone = true;
|
initDone = true;
|
||||||
|
|
@ -61,35 +61,13 @@ class _WindowsPageState extends State<WindowsPage> {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
|
|
||||||
|
if (initDone == false) return Container();
|
||||||
|
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
body: WebGridWidget(
|
body: WebGridWidget(
|
||||||
controller: gridController,
|
controller: gridController,
|
||||||
),
|
),
|
||||||
floatingActionButton: Row(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.end,
|
|
||||||
children: [
|
|
||||||
FloatingActionButton(
|
|
||||||
onPressed: (){
|
|
||||||
gridController.addWeb();
|
|
||||||
},
|
|
||||||
heroTag: 1,
|
|
||||||
tooltip: '添加网页',
|
|
||||||
child: const Icon(Icons.add),
|
|
||||||
),
|
|
||||||
const SizedBox(width: 20,)
|
|
||||||
,
|
|
||||||
FloatingActionButton(
|
|
||||||
onPressed: (){
|
|
||||||
gridController.addAllWeb();
|
|
||||||
},
|
|
||||||
heroTag: 2,
|
|
||||||
tooltip: '添加10个网页',
|
|
||||||
child: const Row(
|
|
||||||
children: [Icon(Icons.add),Text('10')],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue