mirror of
https://github.com/unanmed/HumanBreak.git
synced 2025-01-19 12:49:25 +08:00
feat: 苍蓝之殿上半部分完成 & fix: 缩略图显伤 & fix: 字体调整
This commit is contained in:
parent
d11699e06e
commit
c142cfca88
@ -1457,7 +1457,7 @@ control.prototype._updateDamage_extraDamage = function (floorId, onMap) {
|
||||
|
||||
////// 重绘地图显伤 //////
|
||||
control.prototype.drawDamage = function (ctx, floorId = core.status.floorId) {
|
||||
return;
|
||||
// return;
|
||||
if (core.status.gameOver || !core.status.damage || main.mode != 'play')
|
||||
return;
|
||||
var onMap = false;
|
||||
@ -1482,7 +1482,46 @@ control.prototype.drawDamage = function (ctx, floorId = core.status.floorId) {
|
||||
};
|
||||
|
||||
control.prototype._drawDamage_draw = function (ctx, onMap) {
|
||||
// Deprecated. See src/plugin/game/fx/checkblock.js
|
||||
if (!core.hasItem('book')) return;
|
||||
|
||||
core.setFont(ctx, '300 9px Verdana');
|
||||
core.setTextAlign(ctx, 'left');
|
||||
core.status.damage.data.forEach(function (one) {
|
||||
var px = one.px,
|
||||
py = one.py;
|
||||
if (onMap && core.bigmap.v2) {
|
||||
px -= core.bigmap.posX * 32;
|
||||
py -= core.bigmap.posY * 32;
|
||||
if (
|
||||
px < -32 * 2 ||
|
||||
px > core._PX_ + 32 ||
|
||||
py < -32 ||
|
||||
py > core._PY_ + 32
|
||||
)
|
||||
return;
|
||||
}
|
||||
core.fillBoldText(ctx, one.text, px, py, one.color);
|
||||
});
|
||||
|
||||
core.setTextAlign(ctx, 'center');
|
||||
core.status.damage.extraData.forEach(function (one) {
|
||||
var px = one.px,
|
||||
py = one.py;
|
||||
if (onMap && core.bigmap.v2) {
|
||||
px -= core.bigmap.posX * 32;
|
||||
py -= core.bigmap.posY * 32;
|
||||
if (
|
||||
px < -32 ||
|
||||
px > core._PX_ + 32 ||
|
||||
py < -32 ||
|
||||
py > core._PY_ + 32
|
||||
)
|
||||
return;
|
||||
}
|
||||
var alpha = core.setAlpha(ctx, one.alpha);
|
||||
core.fillBoldText(ctx, one.text, px, py, one.color);
|
||||
core.setAlpha(ctx, alpha);
|
||||
});
|
||||
};
|
||||
|
||||
// ------ 录像相关 ------ //
|
||||
|
@ -1506,7 +1506,7 @@ maps.prototype.redrawMap = function () {
|
||||
// core.clearMap(one);
|
||||
// });
|
||||
// this._drawMap_drawAll(null, { redraw: true });
|
||||
core.drawDamage();
|
||||
// core.drawDamage();
|
||||
};
|
||||
|
||||
maps.prototype._drawMap_drawAll = function (floorId, config) {
|
||||
@ -2609,7 +2609,7 @@ maps.prototype._drawThumbnail_realDrawTempCanvas = function (
|
||||
options.ctx.imageSmoothingEnabled = true;
|
||||
// 缩略图:显伤
|
||||
if (options.damage && core.hasItem('book')) {
|
||||
core.control.updateDamage(floorId, options.ctx);
|
||||
core.control.updateDamage(floorId, options.ctx, true);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -203,5 +203,5 @@ var enemys_fcae963b_31c9_42b4_b48c_bb48d09f3f80 =
|
||||
"E690": {"name":"新敌人","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[]},
|
||||
"E691": {"name":"新敌人","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[]},
|
||||
"E692": {"name":"苍蓝之灵-圣","hp":150000,"atk":15000,"def":5000,"money":20,"exp":5000,"point":0,"special":[4,28],"paleShield":25},
|
||||
"E693": {"name":"新敌人","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[]}
|
||||
"E693": {"name":"苍蓝之灵-战","hp":150000,"atk":15000,"def":4000,"money":20,"exp":5000,"point":0,"special":[32],"assimilateRange":6}
|
||||
}
|
@ -53,6 +53,12 @@ main.floors.MT59=
|
||||
"operator": "+=",
|
||||
"value": "1"
|
||||
},
|
||||
{
|
||||
"type": "setValue",
|
||||
"name": "flag:door_palace",
|
||||
"operator": "+=",
|
||||
"value": "1"
|
||||
},
|
||||
{
|
||||
"type": "if",
|
||||
"condition": "(flag:door_palaceSouth===2)",
|
||||
@ -96,6 +102,50 @@ main.floors.MT59=
|
||||
},
|
||||
"入口处的机关门已开启"
|
||||
]
|
||||
},
|
||||
{
|
||||
"type": "if",
|
||||
"condition": "(flag:door_palace===4)",
|
||||
"true": [
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
7,
|
||||
4
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
4,
|
||||
7
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
7,
|
||||
10
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
10,
|
||||
7
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "setValue",
|
||||
"name": "flag:door_palace",
|
||||
"value": "null"
|
||||
},
|
||||
"苍蓝之殿中心处的机关门已经开启,进入后会到达本章最后一个小区域"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
|
@ -33,14 +33,14 @@ main.floors.MT71=
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
10,
|
||||
1
|
||||
13
|
||||
]
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
10,
|
||||
13
|
||||
1
|
||||
]
|
||||
},
|
||||
{
|
||||
@ -49,6 +49,12 @@ main.floors.MT71=
|
||||
"operator": "+=",
|
||||
"value": "1"
|
||||
},
|
||||
{
|
||||
"type": "setValue",
|
||||
"name": "flag:door_palace",
|
||||
"operator": "+=",
|
||||
"value": "1"
|
||||
},
|
||||
{
|
||||
"type": "if",
|
||||
"condition": "(flag:door_palaceSouth===2)",
|
||||
@ -92,6 +98,50 @@ main.floors.MT71=
|
||||
},
|
||||
"入口处的机关门已开启"
|
||||
]
|
||||
},
|
||||
{
|
||||
"type": "if",
|
||||
"condition": "(flag:door_palace===4)",
|
||||
"true": [
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
7,
|
||||
4
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
4,
|
||||
7
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
7,
|
||||
10
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
10,
|
||||
7
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "setValue",
|
||||
"name": "flag:door_palace",
|
||||
"value": "null"
|
||||
},
|
||||
"苍蓝之殿中心处的机关门已经开启,进入后会到达本章最后一个小区域"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
|
@ -49,18 +49,18 @@ main.floors.MT75=
|
||||
"cannotMoveIn": {},
|
||||
"map": [
|
||||
[648,648,648,648,648,648,648,648,648,648,648,648,648,648,648],
|
||||
[648,491,491,494,491,494,657,676, 0,494,491,494,491,491,648],
|
||||
[648,648,648,648,648,648,644,682,659,648,648,648,648,648,648],
|
||||
[648,484,484,492,484,492,578,677,679,492,484,492,484,484,648],
|
||||
[648,648,648,648,648,648,618,249,513,648,648,648,648,648,648],
|
||||
[648, 0, 0, 0, 0,103,232,658,671,103, 0, 0, 0, 0,648],
|
||||
[648,491,491,494,491,494, 0, 0, 0,494,491,494,491,491,648],
|
||||
[648,648,648,648,648,648, 0, 0, 0,648,648,648,648,648,648],
|
||||
[648,484,484,492,484,492, 0, 0, 0,492,484,492,484,484,648],
|
||||
[648,648,648,648,648,648, 0, 0, 0,648,648,648,648,648,648],
|
||||
[648, 0, 0, 0, 0,103, 0, 0, 0,103, 0, 0, 0, 0,648],
|
||||
[648, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,648],
|
||||
[ 92, 0, 0,672, 0, 0, 0, 0, 0, 0, 0,599, 0, 0, 94],
|
||||
[ 92, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 94],
|
||||
[648, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,648],
|
||||
[648, 0, 0, 0, 0,103, 0, 0, 0,103, 0, 0, 0, 0,648],
|
||||
[648,648,648,648,648,648, 0, 0, 0,648,648,648,648,648,648],
|
||||
[648,484,484,492,484,492, 0, 0, 0,492,484,492,484,484,648],
|
||||
[648,648,648,648,648,648, 0,538, 0,648,648,648,648,648,648],
|
||||
[648,648,648,648,648,648, 0, 0, 0,648,648,648,648,648,648],
|
||||
[648,491,491,494,491,494, 0, 0, 0,494,491,494,491,491,648],
|
||||
[648,648,648,648,648,648,648, 93,648,648,648,648,648,648,648]
|
||||
],
|
||||
|
@ -27,7 +27,60 @@ main.floors.MT84=
|
||||
}
|
||||
},
|
||||
"beforeBattle": {},
|
||||
"afterBattle": {},
|
||||
"afterBattle": {
|
||||
"6,7": [
|
||||
{
|
||||
"type": "setValue",
|
||||
"name": "flag:door_palace",
|
||||
"operator": "+=",
|
||||
"value": "1"
|
||||
},
|
||||
{
|
||||
"type": "if",
|
||||
"condition": "(flag:door_palace===4)",
|
||||
"true": [
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
7,
|
||||
4
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
4,
|
||||
7
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
7,
|
||||
10
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
10,
|
||||
7
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "setValue",
|
||||
"name": "flag:door_palace",
|
||||
"value": "null"
|
||||
},
|
||||
"苍蓝之殿中心处的机关门已经开启,进入后会到达本章最后一个小区域"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
"afterGetItem": {},
|
||||
"afterOpenDoor": {},
|
||||
"autoEvent": {},
|
||||
@ -41,7 +94,7 @@ main.floors.MT84=
|
||||
[648,232,648,648,538,648,378,648, 28,648,513,648,648, 0,648],
|
||||
[648, 0,491,381, 0,648, 0,648, 0,648, 0, 29,484,677,648],
|
||||
[648,648,648,648,648,648,618,648,682,648,648,648,648,648,648],
|
||||
[648,466,467,468,695,692,487,648, 0, 0,484, 0,484, 0, 94],
|
||||
[648,466,467,468,695,664,692,648, 0, 0,484, 0,484, 0, 94],
|
||||
[648,648,648,648,648,648,618,648,682,648,648,648,648,648,648],
|
||||
[648, 0,491,381, 0,648, 0,648, 0,648, 0, 29,484,677,648],
|
||||
[648,232,648,648,538,648,376,648, 27,648,513,648,648, 0,648],
|
||||
|
@ -31,6 +31,13 @@ main.floors.MT91=
|
||||
7,
|
||||
0
|
||||
]
|
||||
},
|
||||
"14,7": {
|
||||
"floorId": "MT93",
|
||||
"loc": [
|
||||
0,
|
||||
7
|
||||
]
|
||||
}
|
||||
},
|
||||
"beforeBattle": {},
|
||||
|
@ -42,19 +42,19 @@ main.floors.MT92=
|
||||
"cannotMoveIn": {},
|
||||
"map": [
|
||||
[648,648,648,648,648,648,648, 91,648,648,648,648,648,648,648],
|
||||
[648,376, 0,491,679, 0,484, 0, 0,648, 0,381,648, 0,648],
|
||||
[648,376, 0,491,679, 0,484, 0, 0,648, 0,381,648, 27,648],
|
||||
[648,671,648,648,648,682,648,648,648,648,658,648,648, 0,648],
|
||||
[648,381,484,648,484, 0,648,482,494, 0, 0, 0,232, 0,648],
|
||||
[648,484,378,648, 0, 28,657, 0,648,648,648,648,648, 0,648],
|
||||
[648,648,648,648,658,648,648,492,648, 0,644, 0,648, 0,648],
|
||||
[648,381,484,648,484, 0,648,482,494,376, 0,491,232, 28,648],
|
||||
[648,484,378,492, 0, 28,657, 0,648,648,648,648,648, 0,648],
|
||||
[648,648,648,648,658,648,648,492,648, 0,644, 0,648,484,648],
|
||||
[648, 0,482,648,491,648, 28, 0,648,491,648,484,677, 0,648],
|
||||
[ 92, 0, 0,682, 0,658, 0,484,648,378,648,648,648,648,648],
|
||||
[ 92, 0, 0,682, 0,658, 0,484,648,378,648,648,648,494,648],
|
||||
[648,513,648,648,648,648,648,492,648, 0,679,491, 0, 27,648],
|
||||
[648, 27,648,484,578,484, 0,381,648,648,648,648,648,677,648],
|
||||
[648, 0,648, 0,648,648,648,682,648, 27,538,376,648,378,648],
|
||||
[648, 0,648, 0,648,648,648,682,648, 27,538,376,492,378,648],
|
||||
[648,484,249, 28,648, 28, 0,482,648, 0,648,484,648,484,648],
|
||||
[648,648,648,648,648,657,648,648,648,484,648,658,648,682,648],
|
||||
[648,487,376,378,618, 0,491, 0,513, 0,648, 0,682, 0,648],
|
||||
[648,487,376,378,618, 0,491, 0,513, 0,492, 0,682, 0,648],
|
||||
[648,648,648,648,648,648,648,648,648,648,648,648,648,648,648]
|
||||
],
|
||||
"bgmap": [
|
||||
|
@ -17,29 +17,102 @@ main.floors.MT93=
|
||||
"eachArrive": [],
|
||||
"parallelDo": "",
|
||||
"events": {},
|
||||
"changeFloor": {},
|
||||
"changeFloor": {
|
||||
"0,7": {
|
||||
"floorId": "MT91",
|
||||
"loc": [
|
||||
14,
|
||||
7
|
||||
]
|
||||
}
|
||||
},
|
||||
"beforeBattle": {},
|
||||
"afterBattle": {},
|
||||
"afterBattle": {
|
||||
"10,7": [
|
||||
{
|
||||
"type": "setValue",
|
||||
"name": "flag:door_palace",
|
||||
"operator": "+=",
|
||||
"value": "1"
|
||||
},
|
||||
{
|
||||
"type": "if",
|
||||
"condition": "(flag:door_palace===4)",
|
||||
"true": [
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
7,
|
||||
4
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
4,
|
||||
7
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
7,
|
||||
10
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "openDoor",
|
||||
"loc": [
|
||||
10,
|
||||
7
|
||||
],
|
||||
"floorId": "MT72"
|
||||
},
|
||||
{
|
||||
"type": "setValue",
|
||||
"name": "flag:door_palace",
|
||||
"value": "null"
|
||||
},
|
||||
"苍蓝之殿中心处的机关门已经开启,进入后会到达本章最后一个小区域"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
"afterGetItem": {},
|
||||
"afterOpenDoor": {},
|
||||
"autoEvent": {},
|
||||
"cannotMove": {},
|
||||
"cannotMoveIn": {},
|
||||
"map": [
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
|
||||
[648,648,648,648,648,648,648,648,648,648,648,648,648,648,648],
|
||||
[648, 0,491, 0,648, 0,648, 0,491, 0,648, 0,491, 0,648],
|
||||
[648, 28, 0, 29,578,491,648,378, 0,381,648,381, 0,376,648],
|
||||
[648,648,648,648,648, 0,648,648,648,232,648,648,648,671,648],
|
||||
[648, 27, 0, 29,249,491,648, 27, 0, 28, 0, 0, 0, 0,648],
|
||||
[648, 0,491, 0,648, 0,648, 0,491, 0,648,648,648,648,648],
|
||||
[648,648,648,648,648,682,648,648,648,677,648,466, 0,467,648],
|
||||
[ 92, 0, 0, 0, 0, 0,513, 0,487, 0,693, 0,665, 0,648],
|
||||
[648,648,648,648,648,682,648,648,648,677,648,468, 0,695,648],
|
||||
[648, 0,491, 0,648, 0,648, 0,491, 0,648,648,648,648,648],
|
||||
[648, 28, 0, 29,249,491,648, 28, 0, 27, 0, 0, 0, 0,648],
|
||||
[648,648,648,648,648, 0,648,648,648,232,648,648,648,671,648],
|
||||
[648, 27, 0, 29,578,491,648,376, 0,381,648,381, 0,378,648],
|
||||
[648, 0,491, 0,648, 0,648, 0,491, 0,648, 0,491, 0,648],
|
||||
[648,648,648,648,648,648,648,648,648,648,648,648,648,648,648]
|
||||
],
|
||||
"bgmap": [
|
||||
|
||||
],
|
||||
"fgmap": [
|
||||
|
||||
],
|
||||
"bg2map": [
|
||||
|
||||
],
|
||||
"fg2map": [
|
||||
|
||||
]
|
||||
}
|
@ -1263,14 +1263,32 @@ var items_296f5d02_12fd_4166_a7c1_b5e830c9ee3a =
|
||||
}
|
||||
},
|
||||
"I664": {
|
||||
"cls": "items",
|
||||
"name": "新物品",
|
||||
"canUseItemEffect": "true"
|
||||
"cls": "equips",
|
||||
"name": "极昼剑",
|
||||
"canUseItemEffect": "true",
|
||||
"text": "吸收白日之精华锻造而成。攻击+500,额外攻击+50",
|
||||
"equip": {
|
||||
"type": "武器",
|
||||
"value": {
|
||||
"mana": 50,
|
||||
"atk": 500
|
||||
},
|
||||
"percentage": {}
|
||||
}
|
||||
},
|
||||
"I665": {
|
||||
"cls": "items",
|
||||
"name": "新物品",
|
||||
"canUseItemEffect": "true"
|
||||
"cls": "equips",
|
||||
"name": "永夜盾",
|
||||
"canUseItemEffect": "true",
|
||||
"text": "集月光之精华锻造而成。防御+400,生命回复+25。",
|
||||
"equip": {
|
||||
"type": "盾牌",
|
||||
"value": {
|
||||
"def": 400,
|
||||
"hpmax": 25
|
||||
},
|
||||
"percentage": {}
|
||||
}
|
||||
},
|
||||
"I694": {
|
||||
"cls": "items",
|
||||
|
@ -150,7 +150,7 @@ export class Damage extends Sprite<EDamageEvent> {
|
||||
/** 伤害渲染层 */
|
||||
damageMap: MotaOffscreenCanvas2D = new MotaOffscreenCanvas2D();
|
||||
/** 默认伤害字体 */
|
||||
font: string = "14px 'normal'";
|
||||
font: string = '300 9px Verdana';
|
||||
/** 默认描边样式,当伤害文字不存在描边属性时会使用此属性 */
|
||||
strokeStyle: CanvasStyle = '#000';
|
||||
/** 默认描边宽度 */
|
||||
@ -347,7 +347,7 @@ export class Damage extends Sprite<EDamageEvent> {
|
||||
text: real.togetherNum.toString(),
|
||||
color: '#09FF5B',
|
||||
x: x * this.cellSize + this.cellSize - 1,
|
||||
y: y * this.cellSize - 2,
|
||||
y: y * this.cellSize + 2,
|
||||
strokeWidth: 3
|
||||
};
|
||||
block.add(dam3);
|
||||
@ -359,8 +359,9 @@ export class Damage extends Sprite<EDamageEvent> {
|
||||
text: '乾',
|
||||
color: '#FDCD0B',
|
||||
x: x * this.cellSize + 1,
|
||||
y: y * this.cellSize - 2,
|
||||
strokeWidth: 2
|
||||
y: y * this.cellSize + 2,
|
||||
strokeWidth: 2,
|
||||
font: '500 10px Verdana'
|
||||
};
|
||||
block.add(dam4);
|
||||
}
|
||||
@ -408,6 +409,7 @@ export class Damage extends Sprite<EDamageEvent> {
|
||||
// todo: 这个应当可以自定义,通过地图伤害注册实现
|
||||
let text = '';
|
||||
let color = '#fa3';
|
||||
let font = '300 9px Verdana';
|
||||
if (dam.damage > 0) {
|
||||
text = core.formatBigNumber(dam.damage, true);
|
||||
} else if (dam.mockery) {
|
||||
@ -418,9 +420,11 @@ export class Damage extends Sprite<EDamageEvent> {
|
||||
const dir = x > tx ? '←' : x < tx ? '→' : y > ty ? '↑' : '↓';
|
||||
text = '嘲' + dir;
|
||||
color = '#fd4';
|
||||
font = '500 11px Verdana';
|
||||
} else if (dam.hunt) {
|
||||
text = '猎';
|
||||
color = '#fd4';
|
||||
font = '500 11px Verdana';
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
@ -430,6 +434,7 @@ export class Damage extends Sprite<EDamageEvent> {
|
||||
baseline: 'middle',
|
||||
text,
|
||||
color,
|
||||
font,
|
||||
x: x * this.cellSize + this.cellSize / 2,
|
||||
y: y * this.cellSize + this.cellSize / 2
|
||||
};
|
||||
|
@ -284,7 +284,7 @@
|
||||
"<br>",
|
||||
"5. <span style=\"color: lightcoral\">当前勇士的攻击</span>,右方偏下为勇士的额外攻击",
|
||||
"<br>",
|
||||
"6. <span style=\"color: lightblue\">当前勇士的防御</span>",
|
||||
"6. <span style=\"color: lightblue\">当前勇士的防御</span>,当有魔法防御时,右方偏下为勇士的魔法防御",
|
||||
"<br>",
|
||||
"7. <span style=\"color: lightgreen\">当前勇士的智慧</span>,可以用于智慧加点等",
|
||||
"<br>",
|
||||
|
@ -139,6 +139,7 @@ export class EnemyCollection
|
||||
this.list = [];
|
||||
core.extractBlocks(this.floorId);
|
||||
core.status.maps[this.floorId].blocks.forEach(v => {
|
||||
if (v.disable) return;
|
||||
if (v.event.cls !== 'enemy48' && v.event.cls !== 'enemys') return;
|
||||
const enemy = core.material.enemys[v.event.id as EnemyIds];
|
||||
this.list.push(
|
||||
|
@ -1,7 +1,12 @@
|
||||
import { ensureFloorDamage } from '@/game/enemy/damage';
|
||||
import { EnemyCollection, ensureFloorDamage } from '@/game/enemy/damage';
|
||||
import { checkV2, formatDamage } from '../utils';
|
||||
|
||||
export function init() {
|
||||
core.control.updateDamage = function (floorId = core.status.floorId, ctx) {
|
||||
core.control.updateDamage = function (
|
||||
floorId = core.status.floorId,
|
||||
ctx,
|
||||
thumbnail: boolean = false
|
||||
) {
|
||||
if (!floorId || core.status.gameOver || main.mode !== 'play') return;
|
||||
const onMap = ctx == null;
|
||||
const floor = core.status.maps[floorId];
|
||||
@ -28,6 +33,101 @@ export function init() {
|
||||
// floor.enemy.render(true);
|
||||
|
||||
// getItemDetail(floorId, onMap); // 宝石血瓶详细信息
|
||||
// this.drawDamage(ctx, floorId);
|
||||
if (thumbnail) {
|
||||
renderThumbnailDamage(floor.enemy);
|
||||
this.drawDamage(ctx, floorId);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
function renderThumbnailDamage(col: EnemyCollection) {
|
||||
core.status.damage.data = [];
|
||||
core.status.damage.extraData = [];
|
||||
core.status.damage.dir = [];
|
||||
|
||||
// 怪物伤害
|
||||
col.list.forEach(v => {
|
||||
const { damage } = v.calDamage();
|
||||
|
||||
// 伤害全部相等,绘制在怪物本身所在位置
|
||||
const { damage: dam, color } = formatDamage(damage);
|
||||
const critical = v.calCritical(1)[0];
|
||||
core.status.damage.data.push({
|
||||
text: dam,
|
||||
px: 32 * v.x! + 1,
|
||||
py: 32 * (v.y! + 1) - 1,
|
||||
color: color
|
||||
});
|
||||
const setting = Mota.require('var', 'mainSetting');
|
||||
const criGem = setting.getValue('screen.criticalGem', false);
|
||||
const n = critical?.atkDelta ?? Infinity;
|
||||
const ratio = core.status.maps[col.floorId].ratio;
|
||||
const cri = criGem ? Math.ceil(n / ratio) : n;
|
||||
|
||||
core.status.damage.data.push({
|
||||
text: isFinite(cri) ? cri.toString() : '?',
|
||||
px: 32 * v.x! + 1,
|
||||
py: 32 * (v.y! + 1) - 11,
|
||||
color: '#fff'
|
||||
});
|
||||
});
|
||||
|
||||
// 地图伤害
|
||||
const floor = core.status.maps[col.floorId];
|
||||
const width = floor.width;
|
||||
const height = floor.height;
|
||||
const objs = core.getMapBlocksObj(col.floorId);
|
||||
|
||||
const startX = 0;
|
||||
const endX = width;
|
||||
const startY = 0;
|
||||
const endY = height;
|
||||
|
||||
for (let x = startX; x < endX; x++) {
|
||||
for (let y = startY; y < endY; y++) {
|
||||
const id = `${x},${y}` as LocString;
|
||||
const dam = col.mapDamage[id];
|
||||
if (!dam || objs[id]?.event.noPass) continue;
|
||||
|
||||
// 地图伤害
|
||||
if (dam.damage !== 0) {
|
||||
const damage = core.formatBigNumber(dam.damage, true);
|
||||
const color = dam.damage < 0 ? '#6eff6a' : '#fa3';
|
||||
core.status.damage.extraData.push({
|
||||
text: damage,
|
||||
px: 32 * x + 16,
|
||||
py: 32 * y + 16,
|
||||
color,
|
||||
alpha: 1
|
||||
});
|
||||
}
|
||||
|
||||
// 电摇嘲讽
|
||||
if (dam.mockery) {
|
||||
dam.mockery.sort((a, b) =>
|
||||
a[0] === b[0] ? a[1] - b[1] : a[0] - b[0]
|
||||
);
|
||||
const [tx, ty] = dam.mockery[0];
|
||||
const dir = x > tx ? '←' : x < tx ? '→' : y > ty ? '↑' : '↓';
|
||||
core.status.damage.extraData.push({
|
||||
text: '嘲' + dir,
|
||||
px: 32 * x + 16,
|
||||
py: 32 * (y + 1) - 14,
|
||||
color: '#fd4',
|
||||
alpha: 1
|
||||
});
|
||||
}
|
||||
|
||||
// 追猎
|
||||
if (dam.hunt) {
|
||||
core.status.damage.extraData.push({
|
||||
text: '猎',
|
||||
px: 32 * x + 16,
|
||||
py: 32 * (y + 1) - 14,
|
||||
color: '#fd4',
|
||||
alpha: 1
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -19,7 +19,7 @@ var ignoreInJump = {
|
||||
]
|
||||
};
|
||||
|
||||
export const jumpIgnoreFloor: FloorIds[] = [
|
||||
export const jumpIgnoreFloor: Set<FloorIds> = new Set([
|
||||
'MT31',
|
||||
'snowTown',
|
||||
'MT36',
|
||||
@ -45,14 +45,15 @@ export const jumpIgnoreFloor: FloorIds[] = [
|
||||
'MT73',
|
||||
'MT74',
|
||||
'MT75',
|
||||
'MT84'
|
||||
];
|
||||
'MT84',
|
||||
'MT93'
|
||||
]);
|
||||
// 跳跃
|
||||
export function jumpSkill() {
|
||||
if (core.status.floorId.startsWith('tower')) {
|
||||
return core.drawTip('当前无法使用该技能');
|
||||
}
|
||||
if (jumpIgnoreFloor.includes(core.status.floorId) || flags.onChase) {
|
||||
if (jumpIgnoreFloor.has(core.status.floorId) || flags.onChase) {
|
||||
return core.drawTip('当前楼层无法使用该技能');
|
||||
}
|
||||
if (!flags.skill2) return;
|
||||
|
@ -157,7 +157,7 @@ export const skills: Record<Chapter, Skill[]> = {
|
||||
],
|
||||
loc: [4, 1],
|
||||
max: 10,
|
||||
effect: level => [`学习怪物技能,持续${level * 3 + 2}场战斗`]
|
||||
effect: level => [`魔法防御 + ${level * 100}`]
|
||||
},
|
||||
{
|
||||
index: 12,
|
||||
|
4
src/source/items.d.ts
vendored
4
src/source/items.d.ts
vendored
@ -189,8 +189,8 @@ interface ItemDeclaration {
|
||||
I642: 'constants';
|
||||
I662: 'equips';
|
||||
I663: 'equips';
|
||||
I664: 'items';
|
||||
I665: 'items';
|
||||
I664: 'equips';
|
||||
I665: 'equips';
|
||||
I694: 'items';
|
||||
I695: 'items';
|
||||
I696: 'items';
|
||||
|
@ -146,7 +146,7 @@ const effect = computed(() => {
|
||||
return [0, 1].map(v => {
|
||||
const prefix = v === 0 ? '当前效果:' : '下一级效果:';
|
||||
const level = skillTree.getSkillLevel(skill.value.index);
|
||||
const content = skill.value.effect(level);
|
||||
const content = skill.value.effect(level + v);
|
||||
return prefix + content.join('');
|
||||
}) as [string, string];
|
||||
});
|
||||
|
@ -212,9 +212,7 @@ function update() {
|
||||
studyOpened.value = skillTree.getSkillLevel(11) > 0;
|
||||
jumpCnt.value =
|
||||
flags.skill2 &&
|
||||
!Mota.Plugin.require('skill_g').jumpIgnoreFloor.includes(
|
||||
core.status.floorId
|
||||
)
|
||||
!Mota.Plugin.require('skill_g').jumpIgnoreFloor.has(core.status.floorId)
|
||||
? 3 - (flags[`jump_${core.status.floorId}`] ?? 0)
|
||||
: void 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user