autojs实现ui和逻辑分离,简化业务逻辑

40 篇文章 14 订阅

QQ群698307198欢迎加入,和各位大神一同交流

正文部分

群里有人问。我就直接写个博客简单回答吧
ui布局该怎么写怎么写
代码部分你写好了直接剪贴到另一个js
然后在原来的文件里
直接require(“代码.js”);即可

在这里插入图片描述
我们先正常写一个

分离前

"ui";


ui.layout(
    <vertical>
    
        <appbar>
            <toolbar title="抖音刷金币"/>
        </appbar>
        
        <Switch id="autoService" text="无障碍服务" checked="{{auto.service != null}}" padding="8 8 8 8" textSize="25sp"/>
        <Switch id="overlayService" text="悬浮窗权限" checked="{{auto.service != null}}" padding="8 8 8 8"textSize="15sp" /> 
        
        <frame height="200" gravity="center">
            <text text="文本" gravity="center"/>
        </frame>
        
        <button id="start" text="开始运行"/>
        
    </vertical>
);




ui.autoService.on("check", function(checked) {
    // 用户勾选无障碍服务的选项时,跳转到页面让用户去开启
    if(checked && auto.service == null) {
        app.startActivity({
            action: "android.settings.ACCESSIBILITY_SETTINGS"
        });
    }
    if(!checked && auto.service != null){
        auto.service.disableSelf();
    }
});

// 当用户回到本界面时,resume事件会被触发
ui.emitter.on("resume", function() {
    // 此时根据无障碍服务的开启情况,同步开关的状态
    ui.autoService.checked = auto.service != null;
});
//开启悬浮窗权限
ui.overlayService.on("check", function (checked) {
    // 用户勾选无障碍服务的选项时,跳转到页面让用户去开启
    if (checked) {
        int = app.startActivity({
            packageName: "com.android.settings",
            className: "com.android.settings.Settings$AppDrawOverlaySettingsActivity",
            data: "package:" + auto.service.getPackageName().toString()
        });
        toast("请打开悬浮窗开关");
    }

     if (!checked && auto.service != null) {
         auto.service.disableSelf();
         toast("已关闭悬浮窗权限");
         }
    });

ui.start.on("click", function(){
    //程序开始运行之前判断无障碍服务
    if(auto.service == null) {
        toast("请先开启无障碍服务!");
        return;
    }
    main();
});





function main() {
   
    
threads.start(function() {
        toast("准备运行。这是没分离的")
       
 // 这里写脚本的主逻辑
        })
    
}

分离后

ui部分设置为main.js

"ui";


ui.layout(
    <vertical>
    
        <appbar>
            <toolbar title="抖音刷金币"/>
        </appbar>
        
        <Switch id="autoService" text="无障碍服务" checked="{{auto.service != null}}" padding="8 8 8 8" textSize="25sp"/>
        <Switch id="overlayService" text="悬浮窗权限" checked="{{auto.service != null}}" padding="8 8 8 8"textSize="15sp" /> 
        
        <frame height="200" gravity="center">
            <text text="文本" gravity="center"/>
        </frame>
        
        <button id="start" text="开始运行"/>
        
    </vertical>
);




ui.autoService.on("check", function(checked) {
    // 用户勾选无障碍服务的选项时,跳转到页面让用户去开启
    if(checked && auto.service == null) {
        app.startActivity({
            action: "android.settings.ACCESSIBILITY_SETTINGS"
        });
    }
    if(!checked && auto.service != null){
        auto.service.disableSelf();
    }
});

require('代码.js');

然后新建一个代码.js文件

ui.autoService.on("check", function(checked) {
    // 用户勾选无障碍服务的选项时,跳转到页面让用户去开启
    if(checked && auto.service == null) {
        app.startActivity({
            action: "android.settings.ACCESSIBILITY_SETTINGS"
        });
    }
    if(!checked && auto.service != null){
        auto.service.disableSelf();
    }
});

// 当用户回到本界面时,resume事件会被触发
ui.emitter.on("resume", function() {
    // 此时根据无障碍服务的开启情况,同步开关的状态
    ui.autoService.checked = auto.service != null;
});
//开启悬浮窗权限
ui.overlayService.on("check", function (checked) {
    // 用户勾选无障碍服务的选项时,跳转到页面让用户去开启
    if (checked) {
        int = app.startActivity({
            packageName: "com.android.settings",
            className: "com.android.settings.Settings$AppDrawOverlaySettingsActivity",
            data: "package:" + auto.service.getPackageName().toString()
        });
        toast("请打开悬浮窗开关");
    }

     if (!checked && auto.service != null) {
         auto.service.disableSelf();
         toast("已关闭悬浮窗权限");
         }
    });

ui.start.on("click", function(){
    //程序开始运行之前判断无障碍服务
    if(auto.service == null) {
        toast("请先开启无障碍服务!");
        return;
    }
    main();
});





function main() {
   
    
threads.start(function() {
        toast("准备运行,ui和逻辑分离成功")
       
 // 这里写脚本的主逻辑
        })
    
}

然后运行main.js这不就ok了嘛。

参考文章

所属软件

韶image.png

声明

部分内容来自网络
本教程仅用于学习, 禁止用于其他用途

QQ群

698307198
扫一扫二维码,加入群聊.QQ

在这里插入图片描述

  • 1
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
PyQt6是一个Python的GUI框架,它可以用来开发交互式的桌面应用程序。在PyQt6中,逻辑界面分离的。这种分离的好处是可以更好地组织代码,并且可以让不同的开发人员专注于不同的任务。 实现PyQt6逻辑界面分离的方法如下: 1. 使用Qt Designer创建UI文件。Qt Designer是一个可视化的工具,可以帮助我们快速创建GUI界面。将所有的界面元素都放在UI文件中,而不是在代码中硬编码。 2. 使用PyUIC将UI文件转换成Python代码。PyUIC是一个命令行工具,它可以将UI文件转换成Python代码。使用命令行运行PyUIC,将UI文件转换成Python代码,并将其保存到一个.py文件中。 3. 在Python代码中编写逻辑代码。将所有的逻辑代码都放在一个单独的.py文件中。这个文件可以包含所有与界面相关的逻辑代码,例如按钮点击事件、文本输入等等。 4. 使用PyQt6加载UI文件并连接逻辑代码。在主程序中,使用PyQt6加载UI文件并连接逻辑代码。使用QMainWindow或QDialog作为主窗口,并将UI文件中的所有控件添加到主窗口中。连接逻辑代码和信号槽,以便在用户与界面交互时执行逻辑代码。 下面是一个简单的示例代码,演示了如何在PyQt6中实现逻辑界面分离: ```python # main.py from PyQt6.QtWidgets import QApplication, QMainWindow from PyQt6.uic import loadUi from logic import Logic class MainWindow(QMainWindow): def __init__(self): super().__init__() # Load the UI file loadUi('ui/mainwindow.ui', self) # Create an instance of the logic class self.logic = Logic() # Connect the buttons to the logic functions self.pushButton.clicked.connect(self.logic.on_button_clicked) if __name__ == '__main__': app = QApplication([]) window = MainWindow() window.show() app.exec() ``` ```python # logic.py class Logic: def on_button_clicked(self): print('Button clicked') ``` 在这个示例中,我们将界面元素放在了ui/mainwindow.ui文件中。我们使用loadUi()方法将UI文件加载到主窗口中。我们还创建了一个Logic类,其中包含了所有与界面相关的逻辑代码。我们将按钮的点击事件连接到Logic类中的on_button_clicked()函数。这样,当用户点击按钮时,逻辑代码就会执行。 通过这种方式,我们可以将逻辑界面分离,使代码更清晰、更易于维护。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值