Compare commits

...

46 Commits

Author SHA1 Message Date
1204244136 bfaf96e7bf perf: 通行证领取流程优化 2025-06-18 13:47:30 +08:00
1204244136 638ae4d90e perf: 通行证滑动方式优化 2025-06-18 13:47:13 +08:00
1204244136 b7b68b26af perf: 大活动奖励领取流程优化 2025-06-18 13:46:48 +08:00
1204244136 745d020f2a fix: 协同作战不在活动期间内无法返回 2025-06-18 13:46:20 +08:00
1204244136 43f7f34b59 fix: 大活动关卡刷取异常 2025-06-18 13:45:45 +08:00
1204244136 898f0b7b3c fix: 大活动签到领取异常 2025-06-18 13:45:18 +08:00
1204244136 2433aaab25 fix: 大活动进入判定异常 2025-06-18 13:45:00 +08:00
1204244136 e20bf86961 perf: 每日任务收取流程优化 2025-06-18 13:43:14 +08:00
1204244136 801b2eee20 perf: 好友点数收取流程优化 2025-06-18 13:42:26 +08:00
1204244136 01042b8bff fix: 咨询判定异常 2025-06-18 13:41:52 +08:00
1204244136 f32254860e perf: 进入模拟室流程优化 2025-06-18 13:41:22 +08:00
1204244136 a811fa52b6 perf: 付费商店流程优化 2025-06-18 13:40:38 +08:00
1204244136 602698dbd5 perf: 检测自动爆裂流程优化 2025-06-18 13:40:13 +08:00
1204244136 7e6c73367f build: 基础控制函数优化 2025-06-18 13:39:18 +08:00
1204244136 a5805b5f10 build: 素材库更新 2025-06-18 13:38:36 +08:00
1204244136 0e7600c621 fix: 读取设置异常 2025-06-18 13:38:09 +08:00
1204244136 ef2b3c7dce perf: 暂停时也会保存配置 2025-06-18 13:37:52 +08:00
1204244136 f699336571 docs: 文本优化 2025-06-18 13:37:16 +08:00
1204244136 25fa4d63c6 fix: 大活动无法进入剧情活动页面 2025-06-18 00:11:47 +08:00
1204244136 e8512b8768 fix: 模拟室结算异常+ 2025-06-16 12:58:45 +08:00
1204244136 654ac8e4ed fix: 协同作战返回异常 2025-06-16 12:34:39 +08:00
1204244136 f04475b357 fix: 大活动挑战进入异常 2025-06-16 12:34:39 +08:00
1204244136 d30ee310cd fix: 大活动签到确认异常 2025-06-16 12:34:39 +08:00
1204244136 426af7b721 fix: 咨询进度异常 2025-06-16 12:34:39 +08:00
1204244136 00acbab4a6 fix: 模拟室结算异常 2025-06-16 12:34:39 +08:00
1204244136 461e614973 docs: 调整登录提示文本的位置 2025-06-16 12:34:39 +08:00
1204244136 bd72c67078 perf: 登录游戏功能解耦 2025-06-16 12:34:39 +08:00
1204244136 620bbaa388 fix: 咨询报错 2025-06-15 14:52:04 +08:00
1204244136 c4a913918d perf: 优化商店进入判定 2025-06-15 14:51:09 +08:00
1204244136 2c749d533f chore: 优化发行版映射表 2025-06-15 14:37:33 +08:00
1204244136 0d52239f11 perf: 代码超级重构 2025-06-15 14:24:36 +08:00
1204244136 8313bad0e3 test: 调整测试热键 2025-06-15 00:56:05 +08:00
1204244136 071278c447 docs: 优化提示文本 2025-06-15 00:55:49 +08:00
1204244136 10364dd246 perf: 优化人机验证 2025-06-15 00:46:51 +08:00
1204244136 59bc8e1452 chore: 优化依赖库 2025-06-15 00:46:51 +08:00
1204244136 d833cd9463 fix: 收菜异常 2025-06-13 23:53:18 +08:00
1204244136 a0cf7361fc fix: 派遣异常 2025-06-13 23:51:29 +08:00
1204244136 93be5d4898 fix: 咨询异常 2025-06-13 23:50:40 +08:00
1204244136 be047bf13a fix: 花絮鉴赏卡死 2025-06-13 23:49:38 +08:00
1204244136 76aa59d518 perf: 无法登录时检测窗口聚焦 2025-06-13 14:24:04 +08:00
1204244136 58ee1aeba1 docs: 自述文件添加友链 2025-06-13 09:51:52 +08:00
1204244136 8f738c31b5 build: 移除不必要的依赖 2025-06-13 09:51:08 +08:00
1204244136 c78906de64 perf: 快速战斗点击偏移 2025-06-12 12:10:19 +08:00
1204244136 76a0843bac revert: 检测完成战斗频率降低 2025-06-12 12:09:59 +08:00
1204244136 0f74f9ed10 fix: 挑战无法扫荡最后一关+ 2025-06-11 22:55:44 +08:00
1204244136 2118066156 fix: 无法收菜 2025-06-11 22:27:21 +08:00
5 changed files with 907 additions and 1173 deletions

23
.github/cliff.toml vendored
View File

@ -61,18 +61,17 @@ footer = """
conventional_commits = true
filter_unconventional = false
commit_parsers = [
{ message = "^feat", group = "✨ 新功能" },
{ message = "^fix", group = "🐛 Bug修复" },
{ message = "^perf", group = "🚀 性能优化" },
{ message = "^docs", group = "📚 文档" },
{ message = "^refactor", group = "🚜 代码重构" },
{ message = "^style", group = "🎨 样式" },
{ message = "^test", group = "🧪 测试" },
{ message = "^build", group = "📦 依赖更新" },
{ message = "^chore", group = "🔧 日常维护" },
{ message = "^ci", group = "⚙️ 持续集成" },
{ body = ".*security", group = "🔒 安全" },
{ message = "^revert", group = "◀️ 撤销" },
{ message = "^feat", group = "新增 | New" },
{ message = "^fix", group = "修复 | Fix" },
{ message = "^perf", group = "改进 | Improved" },
{ message = "^docs", group = "文档 | Docs" },
{ message = "^refactor", group = "重构 | Refactor" },
{ message = "^style", group = "样式 | Style" },
{ message = "^test", group = "测试 | Test" },
{ message = "^build", group = "依赖 | Build" },
{ message = "^chore", group = "维护 | Chore" },
{ message = "^ci", group = "集成 | Ci" },
{ message = "^revert", group = "撤销 | Revert" },
]
ignore_tags = "rc"

File diff suppressed because it is too large Load Diff

View File

@ -24,6 +24,8 @@ PC 端日常任务清理助手。一键清理多项日常事务。支持除**国
- 牢 D 功能类似的[模拟器脚本](https://github.com/takagisanmie/NIKKEAutoScript)
- 群友的[CDK 兑换网站](http://nikke.hayasa.link/)
## 新版本注意
下方的功能介绍均针对最新版本,老版本的对应功能请查看[legacy-v0.1.22](https://github.com/1204244136/DoroHelper/tree/legacy-v0.1.22)分支处的自述文件。
@ -120,14 +122,14 @@ Doro 只是想让你少被该死的读条、闪光弹和重复劳动折磨。一
## 要求
1. 游戏分辨率需要设置成 **16:9** 的分辨率,小于**等于** 1080p 可能有问题,暂不打算特殊支持
- 2k和4k包括异形屏用户请按ctrl+3按到画面不动为止不要开启全屏此时nikke应该是居中的图片缩放应该是1
- 2k 4k包括异形屏用户请按 ctrl+3 按到画面不动为止,不要开启全屏,此时 nikke 应该是居中的,图片缩放应该是 1
<!-- 2. ~~如果游戏使用**全屏模式**,则需要 显示器屏幕的分辨率也是**16:9**,否则只能使用窗口模式~~
- 异形屏或部分笔记本电脑用户需要特别注意这点 -->
2. 由于使用的是图像识别,请确保游戏画面完整在屏幕内,且**游戏画面没有任何遮挡**
- 多显示器请支持的显示器作为主显示器,将游戏放在主显示器内
- 不要使用微星小飞机、游戏加加等悬浮显示数据的软件
- 游戏画质越高,脚本出错的几率越低。
- 游戏帧数建议保持60帧数过低时部分场景的行动可能会被吞导致问题
- 游戏帧数建议保持 60帧数过低时部分场景的行动可能会被吞导致问题
3. 请不要开启会改变画面颜色相关的功能或设置,例如
- 软件层面:各种驱动的色彩滤镜,部分笔记本的真彩模式
- 设备层面显示器的护眼模式、色彩模式、色温调节、HDR 等。

View File

@ -1,325 +0,0 @@
#Requires AutoHotkey v2.0
#SingleInstance Force
; --- 全局变量定义 ---
Global MyGui := "" ; GUI 对象
Global gFocusedProgramEdit := "" ; 聚焦窗口编辑框
Global gCalculatedCoordsEdit := "" ; 换算坐标编辑框 (可编辑)
Global gStatusText := "" ; 状态信息文本
Global gMouseCoordsEdit := "" ; 鼠标屏幕坐标显示框
Global gRelativeMouseCoordsEdit := "" ; 鼠标窗口相对坐标显示框
Global gClientAreaEdit := "" ; 客户区矩形显示框
Global gPixelColorEdit := "" ; 位置颜色显示框 (十六进制)
Global gPixelCharacterBlock := "" ; 显示颜色字符的 Text 控件
Global gSelectedRefWidth := 3840 ; 默认目标宽度 (4K)
Global gSelectedRefHeight := 2160 ; 默认目标高度 (4K)
Global gTargethWnd := "" ; 存储上次记录的目标窗口句柄
; --- 目标分辨率映射表 ---
resolutions := Map(
"4K", [3840, 2160],
"2K", [2560, 1440],
"1080p", [1920, 1080]
)
defaultRefKey := "4K"
; --- 获取当前屏幕分辨率 ---
currentW := A_ScreenWidth
currentH := A_ScreenHeight
currentResText := "当前屏幕分辨率: " . currentW . "x" . currentH
; --- 创建图形用户界面 (GUI) ---
MyGui := Gui("+AlwaysOnTop")
MyGui.Title := "DDB v1.0"
; 提示信息
MyGui.Add("Text", "xm y+10", "注意:标题栏和边框均不属于客户区")
; --- 行 1: 当前分辨率 ---
MyGui.Add("Text", "xm y+10", currentResText)
; --- 行 2: 目标分辨率 ---
MyGui.Add("Text", "xm y+15", "目标分辨率:")
radio4k := MyGui.Add("Radio", "x+m yp vSelectedResName Checked Group", "4K")
radio2k := MyGui.Add("Radio", "x+m yp", "2K")
radio1080p := MyGui.Add("Radio", "x+m yp", "1080p")
; --- 行 3: 聚焦窗口 ---
MyGui.Add("Text", "xm y+15", "聚焦窗口:")
gFocusedProgramEdit := MyGui.Add("Edit", "x+m yp w150 ReadOnly Left")
; --- 行 4: 屏幕位置 ---
MyGui.Add("Text", "xm y+10", "屏幕位置:")
gMouseCoordsEdit := MyGui.Add("Edit", "x+m yp w150 ReadOnly Left")
; --- 行 5: 窗口位置 ---
MyGui.Add("Text", "xm y+10", "窗口位置:")
gRelativeMouseCoordsEdit := MyGui.Add("Edit", "x+m yp w150 ReadOnly Left")
; --- 行 6: 客户区矩形 ---
MyGui.Add("Text", "xm y+10", "客户区: ") ; 注意标签后的空格是用户特意加的
gClientAreaEdit := MyGui.Add("Edit", "x+m yp w150 ReadOnly Left")
; --- 行 7: 位置颜色 & 复制按钮 & 颜色字符 ---
MyGui.Add("Text", "xm y+10", "位置颜色:") ; 标签
gPixelColorEdit := MyGui.Add("Edit", "x+m yp w100 ReadOnly Left") ; 显示框
copyColorButton := MyGui.Add("Button", "x+m yp", "复制") ; 复制按钮
copyColorButton.OnEvent("Click", CopyPixelColor)
; 使用带颜色的文本字符 '■' 显示颜色,初始为灰色
myGui.SetFont("s12")
gPixelCharacterBlock := MyGui.Add("Text", "x+m yp c808080", "")
myGui.SetFont("")
; --- 行 8: 换算坐标 & 复制按钮 & 跳转按钮 ---
MyGui.Add("Text", "xm y+10", "换算坐标:")
gCalculatedCoordsEdit := MyGui.Add("Edit", "x+m yp w100 Left", "") ; 允许输入
copyCoordsButton := MyGui.Add("Button", "x+m yp", "复制")
copyCoordsButton.OnEvent("Click", CopyCalculatedCoords)
jumpButton := MyGui.Add("Button", "y+10", "跳转") ; 跳转按钮另起一行
jumpButton.OnEvent("Click", JumpToCoords)
; --- 行 9: 状态信息 ---
gStatusText := MyGui.Add("Text", "xm y+10 w300 vStatusMessage", "按 Ctrl+Alt+Q 获取鼠标信息") ; 初始提示
; --- 绑定其他 GUI 事件 ---
radio4k.OnEvent("Click", ResolutionChange)
radio2k.OnEvent("Click", ResolutionChange)
radio1080p.OnEvent("Click", ResolutionChange)
MyGui.OnEvent("Close", GuiClose)
; --- 显示 GUI ---
MyGui.Show()
; ==============================================================================
; --- 函数定义 ---
; ==============================================================================
; --- GUI 事件处理: 分辨率选择变化 ---
ResolutionChange(GuiCtrlObj, Info) {
global gSelectedRefWidth, gSelectedRefHeight, gStatusText, resolutions
selectedName := MyGui["SelectedResName"].Value
logMsg := ""
if RegExMatch(selectedName, "^\w+", &match) {
selectedKey := match[0]
if resolutions.Has(selectedKey) {
gSelectedRefWidth := resolutions[selectedKey][1]
gSelectedRefHeight := resolutions[selectedKey][2]
logMsg := "目标分辨率已更改为 " . selectedKey . " (" . gSelectedRefWidth . "x" . gSelectedRefHeight . ")"
gStatusText.Value := logMsg
}
}
}
; --- 热键定义: Ctrl+Alt+Q ---
; --- 热键定义: Ctrl+Alt+Q ---
^!Q:: {
; 引用全局变量
global MyGui, gFocusedProgramEdit, gCalculatedCoordsEdit, gStatusText, gSelectedRefWidth, gSelectedRefHeight, gMouseCoordsEdit, gRelativeMouseCoordsEdit, gClientAreaEdit, gTargethWnd, gPixelColorEdit, gPixelCharacterBlock
; 定义局部变量
local hWnd, progName, winTitle, displayProgInfo, mX, mY, winX, winY, winW, relX, relY, propX, propY, finalX, finalY, isInside := False
local pixelColorRGB, strColor, sixDigitColor
; 检查 gPixelCharacterBlock 是否有效 (保留)
if !IsObject(gPixelCharacterBlock) {
MsgBox("脚本错误: 颜色字符控件 'gPixelCharacterBlock' 未初始化。" . "请检查 GUI 创建部分代码是否正确执行。", "初始化错误", "IconError")
Return
}
; 强制坐标模式
CoordMode "Mouse", "Screen"
CoordMode "Pixel", "Screen"
; 清空或重置显示字段
gCalculatedCoordsEdit.Value := ""
gRelativeMouseCoordsEdit.Value := ""
gStatusText.Value := "正在处理..."
gMouseCoordsEdit.Value := ""
gClientAreaEdit.Value := ""
gPixelColorEdit.Value := ""
; --- ↓↓↓ 直接重置颜色,不再使用 try-catch ↓↓↓ ---
gPixelCharacterBlock.Opt("c808080") ; 重置字符颜色为灰色 (依赖上面的 IsObject 检查)
; 获取当前活动窗口
hWnd := WinActive("A")
if (!hWnd) {
gStatusText.Value := "错误: 未找到活动窗口。"
gFocusedProgramEdit.Value := "N/A"
gTargethWnd := ""
gPixelCharacterBlock.Opt("c808080") ; ★★★ 直接重置 ★★★
Return
}
gTargethWnd := hWnd
; 获取并显示窗口信息
progName := WinGetProcessName("A")
winTitle := WinGetTitle("A")
displayProgInfo := progName ? progName : (winTitle ? winTitle : "N/A")
gFocusedProgramEdit.Value := displayProgInfo
; 获取并显示鼠标屏幕坐标
MouseGetPos(&mX, &mY)
gMouseCoordsEdit.Value := mX . ", " . mY
; 获取并显示像素颜色 及 更新颜色字符 (保留此处的 try-catch)
try {
pixelColorRGB := PixelGetColor(mX, mY, "RGB")
sixDigitColor := Format("{:06X}", pixelColorRGB)
strColor := "0x" . sixDigitColor
gPixelCharacterBlock.Opt("c" . sixDigitColor) ; 设置字符颜色
gPixelColorEdit.Value := strColor
} catch Error as e {
gPixelColorEdit.Value := "获取失败: " e.Message
gPixelCharacterBlock.Opt("c808080") ; ★★★ 直接重置 ★★★
}
; 获取并显示窗口客户区信息 (保留此处的 try-catch)
try {
WinGetClientPos(&winX, &winY, &winW, &winH, hWnd)
gClientAreaEdit.Value := Format("{},{} {}x{}", winX, winY, winW, winH)
} catch Error as e {
gStatusText.Value := "错误: 获取客户区失败 - " . e.Message
gClientAreaEdit.Value := "Error"
gPixelCharacterBlock.Opt("c808080") ; ★★★ 直接重置 ★★★
Return
}
; 检查窗口尺寸是否有效
if (winW <= 0 or winH <= 0) {
gStatusText.Value := "错误: 无效窗口尺寸 W:" . winW . ", H:" . winH
gClientAreaEdit.Value := Format("{},{} {}x{}", winX, winY, winW, winH)
gPixelCharacterBlock.Opt("c808080") ; ★★★ 直接重置 ★★★
Return
}
; 进行边界检查
isInside := (mX >= winX and mX < (winX + winW) and mY >= winY and mY < (winY + winH))
; 根据边界检查结果进行计算和显示
if (isInside) {
relX := mX - winX
relY := mY - winY
gRelativeMouseCoordsEdit.Value := relX . ", " . relY
propX := relX / winW
propY := relY / winH
finalX := Round(propX * gSelectedRefWidth)
finalY := Round(propY * gSelectedRefHeight)
gCalculatedCoordsEdit.Value := finalX . ", " . finalY
gStatusText.Value := "边界检查: 内部"
} else {
gRelativeMouseCoordsEdit.Value := "N/A"
gCalculatedCoordsEdit.Value := ""
gStatusText.Value := "边界检查: 外部(请重新聚焦鼠标)"
}
} ; 热键函数结束 ; 热键函数结束
; --- 跳转按钮点击处理函数 ---
JumpToCoords(GuiCtrlObj, Info) {
; 引用全局变量
global MyGui, gCalculatedCoordsEdit, gStatusText, gSelectedRefWidth, gSelectedRefHeight, gTargethWnd
; 定义局部变量
local targetX, targetY, propX, propY, desiredRelX, desiredRelY, finalScreenX, finalScreenY
local hWnd, winX, winY, winW, winH
local inputText, match
gStatusText.Value := "正在处理跳转..."
; 检查并使用存储的目标窗口句柄
if (!gTargethWnd or !WinExist("ahk_id " . gTargethWnd)) {
gStatusText.Value := "错误: 请先用 Ctrl+Alt+Q 记录一个有效的目标窗口。"
gTargethWnd := ""
Return
}
hWnd := gTargethWnd
; 获取并验证用户输入的坐标
inputText := gCalculatedCoordsEdit.Value
if (!RegExMatch(inputText, "^\s*(-?\d+)\s*[,; ]\s*(-?\d+)\s*$", &match)) {
gStatusText.Value := "错误: 无效坐标格式 (请输入 X, Y)"
Return
}
targetX := Integer(match[1])
targetY := Integer(match[2])
; 可选: 检查输入坐标范围
if (targetX < 0 or targetX >= gSelectedRefWidth or targetY < 0 or targetY >= gSelectedRefHeight) {
gStatusText.Value := "提示: 输入坐标可能超出目标分辨率范围。"
}
; 获取目标窗口的客户区信息
try {
WinGetClientPos(&winX, &winY, &winW, &winH, hWnd)
if (winW <= 0 or winH <= 0) {
throw Error("无效窗口尺寸 W:" . winW . ", H:" . winH)
}
} catch Error as e {
gStatusText.Value := "错误: 获取目标窗口客户区失败 - " . e.Message
Return
}
; 执行反向换算
if (gSelectedRefWidth <= 0 or gSelectedRefHeight <= 0) {
gStatusText.Value := "错误: 无效的目标分辨率尺寸用于计算。"
Return
}
propX := targetX / gSelectedRefWidth
propY := targetY / gSelectedRefHeight
desiredRelX := propX * winW
desiredRelY := propY * winH
finalScreenX := Round(winX + desiredRelX)
finalScreenY := Round(winY + desiredRelY)
; 尝试重新激活目标窗口
try {
WinActivate("ahk_id " . hWnd)
Sleep 100
} catch Error as e {
gStatusText.Value := "警告: 激活目标窗口失败 - " e.Message ",仍尝试跳转。"
}
; 移动鼠标
CoordMode "Mouse", "Screen"
MouseMove finalScreenX, finalScreenY, 0
; 更新状态
gStatusText.Value := "鼠标已跳转至目标窗口对应坐标: " . finalScreenX . ", " . finalScreenY
}
; --- GUI 关闭处理函数 ---
GuiClose(GuiObj) {
ExitApp()
}
; --- 复制按钮事件处理函数 ---
CopyPixelColor(GuiCtrlObj, Info) {
global gPixelColorEdit, gStatusText
local colorValue
colorValue := gPixelColorEdit.Value
if (colorValue != "" && colorValue != "获取失败") { ; 检查是否有有效内容
A_Clipboard := colorValue
gStatusText.Value := "颜色值 '" colorValue "' 已复制!"
SetTimer(() => (gStatusText.Value == "颜色值 '" colorValue "' 已复制!" ? gStatusText.Value := "" : ""), -2000)
} else {
gStatusText.Value := "没有有效颜色值可复制。"
SetTimer(() => (gStatusText.Value == "没有有效颜色值可复制。" ? gStatusText.Value := "" : ""), -2000)
}
}
CopyCalculatedCoords(GuiCtrlObj, Info) {
global gCalculatedCoordsEdit, gStatusText
local coordsValue
coordsValue := gCalculatedCoordsEdit.Value
if (coordsValue != "") {
A_Clipboard := coordsValue
gStatusText.Value := "换算坐标 '" coordsValue "' 已复制!"
SetTimer(() => (gStatusText.Value == "换算坐标 '" coordsValue "' 已复制!" ? (gStatusText.Value := "") : ""), -2000)
} else {
gStatusText.Value := "没有换算坐标可复制。"
SetTimer(() => (gStatusText.Value == "没有换算坐标可复制。" ? (gStatusText.Value := "") : ""), -2000)
}
}

View File

@ -3032,8 +3032,9 @@ int __attribute__((__stdcall__)) PicFind(
. "`nWinGetClientPos &NikkeX, &NikkeY, &NikkeW, &NikkeH, nikkeID"
. "`nPicTolerance := 1"
. "`nTrueRatio := NikkeW / 2331"
. "`nt1:=A_TickCount, Text:=X:=Y:=`"`"" s
. "`nif (ok:=FindText(&X, &Y, NikkeX, NikkeY, NikkeX + NikkeW, NikkeY + NikkeH, 0.1*PicTolerance, 0.1*PicTolerance, Text,,,,,,, TrueRatio, TrueRatio)){"
. "`nFindText().PicLib(`"|<" Comment ">" color "$" txt "`", 1)`n"
. "`nt1:=A_TickCount, Text:=X:=Y:=`"`""
. "`nif (ok:=FindText(&X, &Y, NikkeX, NikkeY, NikkeX + NikkeW, NikkeY + NikkeH, 0.2*PicTolerance, 0.2*PicTolerance, FindText().PicLib(`"" Comment "`"),,,,,,, TrueRatio, TrueRatio)){"
. "`n `; FindText()." . "Click(" . "X, Y, `"L`")"
. "`n}`n"
. "`n`; ok:=FindText(&X:=`"wait`", &Y:=3, 0,0,0,0,0,0,Text) `; " r[7]