fix(nandu): 难度选择时在状态栏点击以及鼠标移动有响应了

This commit is contained in:
bdf1 2023-01-04 05:45:33 +13:00
parent bb65e2471c
commit 3bd0b2eec9
2 changed files with 78 additions and 4 deletions

View File

@ -1004,7 +1004,13 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
if (core.isReplaying() && vertical != null) return vertical; if (core.isReplaying() && vertical != null) return vertical;
return core.domStyle.isVertical; return core.domStyle.isVertical;
} }
if (core.status.floorId == "nandu") {
var h = -1;
if (py >= 46 && py <= 430) h = Math.floor((py - 46) / 77) + 1;
if (h > 0) {
core.actions._clickAction(0, Math.floor(py / 16), 1, py)
}
}
// 如果正在执行事件,则忽略 // 如果正在执行事件,则忽略
if (core.status.lockControl) return; if (core.status.lockControl) return;
// 如果当前正在行走,则忽略;也可以使用 core.waitHeroToStop(callback) 来停止行走再回调执行脚本 // 如果当前正在行走,则忽略;也可以使用 core.waitHeroToStop(callback) 来停止行走再回调执行脚本
@ -1739,6 +1745,11 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
fill(step, 140, 455, '#ffffff'); fill(step, 140, 455, '#ffffff');
setTimeout(function(){core.ui.drawStatusBar();}, 100); setTimeout(function(){core.ui.drawStatusBar();}, 100);
} }
if (core.status.floorId == "nandu") {
core.dom.statusCanvas.width *= 1;
core.dom.statusCanvas.style.zIndex=80;
}
else core.dom.statusCanvas.style.zIndex=50;
} }
} else if (core.flags.extendToolbar && !core.domStyle.isVertical) { // 横屏且隐藏状态栏 } else if (core.flags.extendToolbar && !core.domStyle.isVertical) { // 横屏且隐藏状态栏
if (!core.dymCanvas['status']) if (!core.dymCanvas['status'])

View File

@ -1080,8 +1080,71 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.actions.registerAction('keyUp', '_sys_keyUp_lockControl', core.actions._sys_keyUp_lockControl, 50); core.actions.registerAction('keyUp', '_sys_keyUp_lockControl', core.actions._sys_keyUp_lockControl, 50);
core.actions.registerAction('ondown', '_sys_ondown_lockControl', core.actions._sys_ondown_lockControl, 30); core.actions.registerAction('ondown', '_sys_ondown_lockControl', core.actions._sys_ondown_lockControl, 30);
core.actions.registerAction('onmove', '_sys_onmove_choices', core.actions._sys_onmove_choices, 30); core.actions.registerAction('onmove', '_sys_onmove_choices', core.actions._sys_onmove_choices, 30);
main.dom.statusCanvas.onmousedown = main.dom.statusCanvas.onclick;
main.dom.statusCanvas.onclick = null;
main.dom.statusCanvas.onmousemove = function(e) {
try {
e.stopPropagation();
if (e == null) return;
var t = main.core.actions._getClickLoc(e.clientX, e.clientY);
px = Math.floor(t.x / core.domStyle.scale);
py = Math.floor(t.y / core.domStyle.scale);
if (core.status.floorId == "nandu") {
var h = -1;
if (py >= 46 && py <= 430) h = Math.floor((py - 46) / 77) + 1;
if (h > 0 && h != core.getFlag("hard") && px < 160) {
core.actions._clickAction(0, Math.floor(py / 16), 1, py);
}
}
} catch (ee) { console.error(ee) }
}
core.actions._sys_onmove = function (x, y, px, py) {
if (core.status.floorId == "nandu") {
var h = -1;
if (py >= 46 && py <= 430) h = Math.floor((py - 46) / 77) + 1;
if (h > 0 && h != core.getFlag("hard") && px < 160) {
core.actions._clickAction(0, Math.floor(py / 16), 1, py);
}
}
if (core.status.lockControl) return false;
if (core.status.preview.dragging) {
core.setViewport(core.bigmap.offsetX - px + core.status.preview.px, core.bigmap.offsetY - py + core.status.preview.py);
core.status.preview.px = px;
core.status.preview.py = py;
return true;
}
if (core.status.preview.prepareDragging) {
if (Math.abs(px - core.status.preview.px) <= 20 && Math.abs(py - core.status.preview.py) <= 20)
return true;
else core.status.preview.prepareDragging = false;
}
clearTimeout(core.timeout.onDownTimeout);
core.timeout.onDownTimeout = null;
if ((core.status.stepPostfix || []).length > 0) {
var pos = { 'x': parseInt((px + core.bigmap.offsetX) / 32), 'y': parseInt((py + core.bigmap.offsetY) / 32) };
var pos0 = core.status.stepPostfix[core.status.stepPostfix.length - 1];
var directionDistance = [pos.y - pos0.y, pos0.x - pos.x, pos0.y - pos.y, pos.x - pos0.x];
var max = 0, index = 4;
for (var ii = 0; ii < 4; ii++) {
if (directionDistance[ii] > max) {
index = ii;
max = directionDistance[ii];
}
}
pos = [{ 'x': 0, 'y': 1 }, { 'x': -1, 'y': 0 }, { 'x': 0, 'y': -1 }, { 'x': 1, 'y': 0 }, false][index]
if (pos) {
pos.x += pos0.x;
pos.y += pos0.y;
core.status.stepPostfix.push(pos);
core.fillRect('ui', pos.x * 32 + 12 - core.bigmap.offsetX, pos.y * 32 + 12 - core.bigmap.offsetY, 8, 8, '#bfbfbf');
}
}
return true;
}
core.actions.registerAction('onmove', '_sys_onmove', core.actions._sys_onmove, 0);
@ -3830,7 +3893,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
// 准备渐变 // 准备渐变
this.maskPrepare = function () { this.maskPrepare = function () {
// 执行后画面将凝固 // 执行后画面将凝固
core.createCanvas("mask", 0, 0, core.__PIXELS__, core.__PIXELS__, 155); core.ui.createCanvas2("mask", 0, 0, core.__PIXELS__, core.__PIXELS__, 155);
for (var m in core.canvas) { for (var m in core.canvas) {
core.dymCanvas.mask.drawImage(core.canvas[m].canvas, 0, 0); core.dymCanvas.mask.drawImage(core.canvas[m].canvas, 0, 0);
}; };