@rpgjs/action-battle 5.0.0-beta.4 → 5.0.0-beta.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +115 -0
- package/dist/ai.server.d.ts +17 -2
- package/dist/client/index.js +13 -8
- package/dist/client/index10.js +54 -136
- package/dist/client/index11.js +52 -23
- package/dist/client/index12.js +101 -1217
- package/dist/client/index13.js +139 -42
- package/dist/client/index14.js +23 -8
- package/dist/client/index15.js +68 -444
- package/dist/client/index16.js +1281 -0
- package/dist/client/index17.js +13 -0
- package/dist/client/index18.js +60 -0
- package/dist/client/index19.js +10 -0
- package/dist/client/index2.js +25 -87
- package/dist/client/index20.js +504 -0
- package/dist/client/index3.js +45 -83
- package/dist/client/index4.js +98 -297
- package/dist/client/index5.js +81 -33
- package/dist/client/index6.js +284 -78
- package/dist/client/index7.js +33 -74
- package/dist/client/index8.js +95 -55
- package/dist/client/index9.js +75 -96
- package/dist/core/attack-profile.d.ts +9 -0
- package/dist/core/attack-runtime.d.ts +20 -0
- package/dist/core/enemy-attack-profiles.d.ts +6 -0
- package/dist/core/equipment.d.ts +2 -0
- package/dist/core/hit-reaction.d.ts +5 -0
- package/dist/index.d.ts +6 -1
- package/dist/server/index.js +12 -7
- package/dist/server/index10.js +1278 -8
- package/dist/server/index11.js +37 -0
- package/dist/server/index12.js +60 -0
- package/dist/server/index13.js +13 -0
- package/dist/server/index14.js +503 -0
- package/dist/server/index15.js +10 -0
- package/dist/server/index3.js +25 -87
- package/dist/server/index4.js +45 -141
- package/dist/server/index5.js +104 -21
- package/dist/server/index6.js +137 -1215
- package/dist/server/index7.js +22 -34
- package/dist/server/index8.js +70 -44
- package/dist/server/index9.js +44 -437
- package/dist/server.d.ts +7 -1
- package/package.json +5 -5
- package/src/ai.server.ts +172 -43
- package/src/client.ts +21 -12
- package/src/config.ts +17 -2
- package/src/core/attack-profile.spec.ts +118 -0
- package/src/core/attack-profile.ts +100 -0
- package/src/core/attack-runtime.spec.ts +103 -0
- package/src/core/attack-runtime.ts +83 -0
- package/src/core/contracts.ts +3 -0
- package/src/core/enemy-attack-profiles.spec.ts +35 -0
- package/src/core/enemy-attack-profiles.ts +103 -0
- package/src/core/equipment.spec.ts +37 -0
- package/src/core/equipment.ts +17 -0
- package/src/core/hit-reaction.spec.ts +43 -0
- package/src/core/hit-reaction.ts +70 -0
- package/src/core/hit.spec.ts +54 -1
- package/src/core/hit.ts +26 -0
- package/src/index.ts +36 -0
- package/src/server.ts +180 -33
- package/src/types.ts +62 -6
package/dist/client/index13.js
CHANGED
|
@@ -1,46 +1,143 @@
|
|
|
1
|
-
//#region src/core/
|
|
2
|
-
var
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
1
|
+
//#region src/core/defaults.ts
|
|
2
|
+
var DEFAULT_CORE_KNOCKBACK = {
|
|
3
|
+
force: 50,
|
|
4
|
+
duration: 300
|
|
5
|
+
};
|
|
6
|
+
var CoreAttackPattern = {
|
|
7
|
+
Melee: "melee",
|
|
8
|
+
Combo: "combo",
|
|
9
|
+
Charged: "charged",
|
|
10
|
+
Zone: "zone",
|
|
11
|
+
DashAttack: "dashAttack"
|
|
12
|
+
};
|
|
13
|
+
var CoreEnemyType = {
|
|
14
|
+
Aggressive: "aggressive",
|
|
15
|
+
Defensive: "defensive",
|
|
16
|
+
Ranged: "ranged",
|
|
17
|
+
Tank: "tank",
|
|
18
|
+
Berserker: "berserker"
|
|
19
|
+
};
|
|
20
|
+
var DEFAULT_ZELDA_PLAYER_HITBOXES = {
|
|
21
|
+
up: {
|
|
22
|
+
offsetX: -16,
|
|
23
|
+
offsetY: -48,
|
|
24
|
+
width: 32,
|
|
25
|
+
height: 32
|
|
26
|
+
},
|
|
27
|
+
down: {
|
|
28
|
+
offsetX: -16,
|
|
29
|
+
offsetY: 16,
|
|
30
|
+
width: 32,
|
|
31
|
+
height: 32
|
|
32
|
+
},
|
|
33
|
+
left: {
|
|
34
|
+
offsetX: -48,
|
|
35
|
+
offsetY: -16,
|
|
36
|
+
width: 32,
|
|
37
|
+
height: 32
|
|
38
|
+
},
|
|
39
|
+
right: {
|
|
40
|
+
offsetX: 16,
|
|
41
|
+
offsetY: -16,
|
|
42
|
+
width: 32,
|
|
43
|
+
height: 32
|
|
44
|
+
},
|
|
45
|
+
default: {
|
|
46
|
+
offsetX: 0,
|
|
47
|
+
offsetY: -32,
|
|
48
|
+
width: 32,
|
|
49
|
+
height: 32
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
var resolveEquippedWeapon = (entity) => {
|
|
53
|
+
const equipments = entity?.equipments?.() || [];
|
|
54
|
+
for (const item of equipments) {
|
|
55
|
+
const itemId = item?.id?.() ?? item?.id;
|
|
56
|
+
const itemData = entity?.databaseById?.(itemId);
|
|
57
|
+
if (itemData?._type === "weapon") return itemData;
|
|
58
|
+
}
|
|
59
|
+
return null;
|
|
60
|
+
};
|
|
61
|
+
var resolveDirection = (attacker, target) => {
|
|
62
|
+
const dx = target.x() - attacker.x();
|
|
63
|
+
const dy = target.y() - attacker.y();
|
|
64
|
+
const distance = Math.sqrt(dx * dx + dy * dy);
|
|
65
|
+
if (distance <= 0) return void 0;
|
|
66
|
+
return {
|
|
67
|
+
x: dx / distance,
|
|
68
|
+
y: dy / distance
|
|
69
|
+
};
|
|
70
|
+
};
|
|
71
|
+
var createDefaultPlayerHitboxResolver = (hitboxes = DEFAULT_ZELDA_PLAYER_HITBOXES) => (context) => {
|
|
72
|
+
const attacker = context.attacker;
|
|
73
|
+
const config = hitboxes[context.direction ?? (typeof attacker.getDirection === "function" ? attacker.getDirection() : "default")] || hitboxes.default;
|
|
74
|
+
return [{
|
|
75
|
+
x: attacker.x() + config.offsetX,
|
|
76
|
+
y: attacker.y() + config.offsetY,
|
|
77
|
+
width: config.width,
|
|
78
|
+
height: config.height
|
|
79
|
+
}];
|
|
80
|
+
};
|
|
81
|
+
var defaultRpgjsDamageResolver = (context) => {
|
|
82
|
+
const target = context.target;
|
|
83
|
+
const raw = target.applyDamage(context.attacker, context.skill);
|
|
84
|
+
return {
|
|
85
|
+
damage: raw?.damage ?? 0,
|
|
86
|
+
defeated: target.hp <= 0,
|
|
87
|
+
raw
|
|
14
88
|
};
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
hitContext.damage = damage;
|
|
23
|
-
const afterDamage = system.hooks?.afterDamage?.(hitContext);
|
|
24
|
-
if (afterDamage) hitContext = afterDamage;
|
|
25
|
-
const knockback = hitContext.knockback ?? system.resolveKnockback({
|
|
26
|
-
attacker: hitContext.attacker,
|
|
27
|
-
target: hitContext.target,
|
|
28
|
-
damage
|
|
29
|
-
});
|
|
30
|
-
hitContext.knockback = knockback;
|
|
31
|
-
if (!damage.defeated && knockback.force > 0 && knockback.direction) hitContext.target.knockback?.(knockback.direction, knockback.force, knockback.duration);
|
|
32
|
-
const result = {
|
|
33
|
-
damage: damage.damage,
|
|
34
|
-
knockbackForce: knockback.force,
|
|
35
|
-
knockbackDuration: knockback.duration,
|
|
36
|
-
defeated: damage.defeated,
|
|
37
|
-
attacker: hitContext.attacker,
|
|
38
|
-
target: hitContext.target,
|
|
39
|
-
rawDamage: damage.raw,
|
|
40
|
-
metadata: hitContext.metadata
|
|
89
|
+
};
|
|
90
|
+
var defaultKnockbackResolver = (context) => {
|
|
91
|
+
const weapon = context.weapon ?? resolveEquippedWeapon(context.attacker);
|
|
92
|
+
return {
|
|
93
|
+
force: weapon?.knockbackForce ?? DEFAULT_CORE_KNOCKBACK.force,
|
|
94
|
+
duration: weapon?.knockbackDuration ?? DEFAULT_CORE_KNOCKBACK.duration,
|
|
95
|
+
direction: resolveDirection(context.attacker, context.target)
|
|
41
96
|
};
|
|
42
|
-
|
|
43
|
-
|
|
97
|
+
};
|
|
98
|
+
var defaultCombatSystem = {
|
|
99
|
+
resolveHitboxes: createDefaultPlayerHitboxResolver(),
|
|
100
|
+
resolveDamage: defaultRpgjsDamageResolver,
|
|
101
|
+
resolveKnockback: defaultKnockbackResolver
|
|
102
|
+
};
|
|
103
|
+
var defaultEnemyBehaviors = {
|
|
104
|
+
[CoreEnemyType.Aggressive]: ({ hpPercent }) => ({
|
|
105
|
+
mode: hpPercent !== null && hpPercent < .15 ? "retreat" : "assault",
|
|
106
|
+
attackPatterns: [
|
|
107
|
+
CoreAttackPattern.Melee,
|
|
108
|
+
CoreAttackPattern.Combo,
|
|
109
|
+
CoreAttackPattern.DashAttack
|
|
110
|
+
]
|
|
111
|
+
}),
|
|
112
|
+
[CoreEnemyType.Defensive]: ({ hpPercent }) => ({
|
|
113
|
+
mode: hpPercent !== null && hpPercent < .3 ? "retreat" : "tactical",
|
|
114
|
+
attackPatterns: [CoreAttackPattern.Melee, CoreAttackPattern.Charged]
|
|
115
|
+
}),
|
|
116
|
+
[CoreEnemyType.Ranged]: ({ distance }) => ({
|
|
117
|
+
mode: distance !== null && distance < 80 ? "retreat" : "tactical",
|
|
118
|
+
attackPatterns: [CoreAttackPattern.Melee, CoreAttackPattern.Zone]
|
|
119
|
+
}),
|
|
120
|
+
[CoreEnemyType.Tank]: () => ({
|
|
121
|
+
mode: "assault",
|
|
122
|
+
attackPatterns: [
|
|
123
|
+
CoreAttackPattern.Melee,
|
|
124
|
+
CoreAttackPattern.Charged,
|
|
125
|
+
CoreAttackPattern.Zone
|
|
126
|
+
]
|
|
127
|
+
}),
|
|
128
|
+
[CoreEnemyType.Berserker]: ({ hpPercent }) => ({
|
|
129
|
+
mode: "assault",
|
|
130
|
+
attackCooldown: hpPercent === null ? void 0 : Math.max(250, 800 * Math.max(.3, hpPercent)),
|
|
131
|
+
attackPatterns: [
|
|
132
|
+
CoreAttackPattern.Melee,
|
|
133
|
+
CoreAttackPattern.Combo,
|
|
134
|
+
CoreAttackPattern.DashAttack
|
|
135
|
+
]
|
|
136
|
+
})
|
|
137
|
+
};
|
|
138
|
+
var defaultActionBattleSystems = {
|
|
139
|
+
combat: defaultCombatSystem,
|
|
140
|
+
ai: { behaviors: defaultEnemyBehaviors }
|
|
44
141
|
};
|
|
45
142
|
//#endregion
|
|
46
|
-
export {
|
|
143
|
+
export { DEFAULT_ZELDA_PLAYER_HITBOXES, createDefaultPlayerHitboxResolver, defaultActionBattleSystems, defaultCombatSystem, defaultEnemyBehaviors, defaultKnockbackResolver, defaultRpgjsDamageResolver };
|
package/dist/client/index14.js
CHANGED
|
@@ -1,10 +1,25 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
var
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
import { defaultActionBattleSystems } from "./index13.js";
|
|
2
|
+
//#region src/core/context.ts
|
|
3
|
+
var mergeSystems = (options = {}) => ({
|
|
4
|
+
combat: {
|
|
5
|
+
...defaultActionBattleSystems.combat,
|
|
6
|
+
resolveDamage: options.systems?.combat?.damage ?? defaultActionBattleSystems.combat.resolveDamage,
|
|
7
|
+
resolveKnockback: options.systems?.combat?.knockback ?? defaultActionBattleSystems.combat.resolveKnockback,
|
|
8
|
+
hooks: {
|
|
9
|
+
...defaultActionBattleSystems.combat.hooks,
|
|
10
|
+
...options.systems?.combat?.hooks
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
ai: { behaviors: {
|
|
14
|
+
...defaultActionBattleSystems.ai.behaviors,
|
|
15
|
+
...options.systems?.ai?.behaviors
|
|
16
|
+
} }
|
|
17
|
+
});
|
|
18
|
+
var currentActionBattleSystems = mergeSystems();
|
|
19
|
+
var setActionBattleSystems = (options = {}) => {
|
|
20
|
+
currentActionBattleSystems = mergeSystems(options);
|
|
8
21
|
};
|
|
22
|
+
var getActionBattleSystems = () => currentActionBattleSystems;
|
|
23
|
+
var createActionBattleSystems = mergeSystems;
|
|
9
24
|
//#endregion
|
|
10
|
-
export {
|
|
25
|
+
export { createActionBattleSystems, getActionBattleSystems, setActionBattleSystems };
|