Skip to content

overflow65537/MFW-PyQt6

Repository files navigation

MFW-PyQt6

简体中文 | English

基于 PyQT6MAAFramework 通用 GUI 项目

license Python platform commit

开发环境

  • Python 3.12

使用方法

直接使用

  • pip install -r requirements.txt
  • python main.py

使用GitHub action 自动构建

  • depoly\deploy.py 中的项目名和项目地址修改为你的项目名和项目地址并上传至GitHub仓库根目录
  • deploy\install.yml 中MaaXXX修改为你的项目名并上传至GitHub仓库的.github/workflows目录
  • 推送新版本

功能说明

多配置启动

  • 在计划任务界面点击资源的添加按钮即可添加资源
  • 每个资源可以有多个配置,互相独立
  • 结束后操作可以选择启动其他资源中的某项配置文件
  • 配合启动后执行任务可以实现多资源的无缝启动

参数启动

  • -r参数可接受资源名称 例如 python main.py -r resource1或者 MFW.exe -r resource1
  • -c参数可接受配置文件名称 例如 python main.py -c config1或者 MFW.exe -c config1
  • -d参数可以直接启动 例如 python main.py -d或者 MFW.exe -d

外部通知

  • 目前支持 钉钉,飞书,SMTP,WxPusher 四种通知方式

更新资源

  • 添加资源时如果填写了更新地址,可以进行一键更新

动态加载自定义动作/识别器

  • 什么是自定义动作/识别器
  • 要求自定义动作/识别器使用python3.12
  • 如果自定义动作/识别器中含有第三方库,需要将第三方库安装到_internal(windows和Macos)或者MFW-PyQt6根目录(linux)
  • 将自定义动作/识别器文件按照要求命名和放置
  • 要求的结构:这是例子
项目文件夹/custom/
├── action/
│   ├── 动作1
│   │    └── main.py
│   └── 动作2
│        └── main.py
└── Recognition/
    ├── 识别器1
    │    └── main.py
    └── 识别器2
         └── main.py
  • 其中,动作1,动作2,识别器1,识别器2为在pipeline中所使用的名字,比如
"我的自定义任务": {
        "recognition": "Custom",
        "custom_recognition": "识别器1",
        "action": "Custom",
        "custom_action": "动作1"
    }
  • main.py中要求对象名和文件夹相同,比如
  class 识别器1(CustomRecognition):
    def analyze(context, ...):
        # 获取图片,然后进行自己的图像操作
        image = context.tasker.controller.cached_image
        # 返回图像分析结果
        return AnalyzeResult(box=(10, 10, 100, 100))

Custom 程序配置

  • 创建 ./config/custom.json
  • 内容为
{
    "option1": {
        "optionname": "option1",
        "optiontype": "switch",
        "optioncontent": false,
        "text": {
            "title": "开关",
            "content": "这是一个开关"
        }
    },
    "option2": {
        "optionname": "option2",
        "optiontype": "combox",
        "optioncontent": [
            "content1",
            "content2",
            "content3"
        ],
        "text": {
            "title": "下拉框",
            "content": "这是一个下拉框"
        }
    },
    "option3": {
        "optionname": "option3",
        "optiontype": "lineedit",
        "optioncontent": "content3",
        "text": {
            "title": "输入框",
            "content": "这是一个输入框"
        }
    }
}
  • 处理后的数据会保存至 ./config/custom_config.json 以供custom程序读取。

许可证

MFW-PyQt6 使用 GPL-3.0 许可证 开源。

致谢

开源项目

  • PyQt-Fluent-Widgets
    A fluent design widgets library based on C++ Qt/PyQt/PySide. Make Qt Great Again.
  • MaaFramework
    基于图像识别的自动化黑盒测试框架。

开发者

感谢所有为 MFW-PyQt6 做出贡献的开发者。

Contributors to MFW-PyQt6