Merge pull request #117 from hppeng-wynn/damage-calc-update
Implement critDamPct, update melee modifiers to what we see ingame, f…
This commit is contained in:
commit
1763afc0cf
5 changed files with 28 additions and 46 deletions
|
@ -13,8 +13,9 @@ Additional Contributors, in no particular order:
|
|||
- ITechnically (coding emotional support / misc)
|
||||
- touhoku (best IM)
|
||||
- HeyZeer0 (huge help in getting our damage formulas right)
|
||||
- blankman (fin444 github) (beautifying atree visuals)
|
||||
- Lennon (Skill point formula reversing)
|
||||
- Phanta (WynnAtlas custom expression parser / item search)
|
||||
- nbcss (Crafted Item mechanics reverse engineering)
|
||||
- nbcss (and WIM team) (Crafted Item mechanics reverse engineering, testing)
|
||||
- dr_carlos (Hiding UI elements properly, fade animations, proper error handling)
|
||||
- Atlas Inc discord (feedback, ideas, damage calc, etc)
|
||||
|
|
|
@ -920,18 +920,12 @@ const atrees = {
|
|||
"cost": 1,
|
||||
"display": { "row": 2, "col": 4, "icon": "node_0"},
|
||||
"properties": {},
|
||||
"effects": [
|
||||
{
|
||||
"type": "raw_stat",
|
||||
"bonuses": [
|
||||
{
|
||||
"type": "stat",
|
||||
"name": "mdPct",
|
||||
"value": 5
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
"effects": [{
|
||||
"type": "add_spell_prop",
|
||||
"base_spell": 0,
|
||||
"target_part": "Single Shot",
|
||||
"multipliers": [5, 0, 0, 0, 0, 0]
|
||||
}]
|
||||
},
|
||||
{
|
||||
"display_name": "Cheaper Arrow Bomb",
|
||||
|
@ -2038,18 +2032,12 @@ const atrees = {
|
|||
"properties": {
|
||||
"melee_range": 1
|
||||
},
|
||||
"effects": [
|
||||
{
|
||||
"type": "raw_stat",
|
||||
"bonuses": [
|
||||
{
|
||||
"type": "stat",
|
||||
"name": "mdPct",
|
||||
"value": 5
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
"effects": [{
|
||||
"type": "add_spell_prop",
|
||||
"base_spell": 0,
|
||||
"target_part": "melee",
|
||||
"multipliers": [5, 0, 0, 0, 0, 0]
|
||||
}]
|
||||
},
|
||||
|
||||
{
|
||||
|
@ -2843,18 +2831,12 @@ const atrees = {
|
|||
"properties": {
|
||||
"melee_range": 1
|
||||
},
|
||||
"effects": [
|
||||
{
|
||||
"type": "raw_stat",
|
||||
"bonuses": [
|
||||
{
|
||||
"type": "stat",
|
||||
"name": "mdPct",
|
||||
"value": 5
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
"effects": [{
|
||||
"type": "add_spell_prop",
|
||||
"base_spell": 0,
|
||||
"target_part": "melee",
|
||||
"multipliers": [5, 0, 0, 0, 0, 0]
|
||||
}]
|
||||
},
|
||||
|
||||
{
|
||||
|
|
File diff suppressed because one or more lines are too long
|
@ -129,6 +129,7 @@ class Build{
|
|||
}
|
||||
}
|
||||
statMap.set("poisonPct", 100);
|
||||
statMap.set("critDamPct", 100);
|
||||
|
||||
// The stuff relevant for damage calculation!!! @ferricles
|
||||
statMap.set("atkSpd", this.weapon.statMap.get("atkSpd"));
|
||||
|
|
|
@ -151,15 +151,11 @@ function calculateSpellDamage(stats, weapon, _conversions, use_spell_damage, ign
|
|||
let min_boost = raw_boost;
|
||||
let max_boost = raw_boost;
|
||||
if (total_max > 0) { // TODO: what about total negative all raw?
|
||||
if (total_min > 0) {
|
||||
min_boost += (damages_obj[0] / total_min) * prop_raw;
|
||||
}
|
||||
max_boost += (damages_obj[1] / total_max) * prop_raw;
|
||||
}
|
||||
if (i != 0 && total_elem_max > 0) { // rainraw TODO above
|
||||
if (total_elem_min > 0) {
|
||||
min_boost += (damages_obj[0] / total_elem_min) * rainbow_raw;
|
||||
}
|
||||
max_boost += (damages_obj[1] / total_elem_max) * rainbow_raw;
|
||||
}
|
||||
damages_obj[0] += min_boost * total_convert;
|
||||
|
@ -185,12 +181,14 @@ function calculateSpellDamage(stats, weapon, _conversions, use_spell_damage, ign
|
|||
damage_mult *= (1 + v/100);
|
||||
}
|
||||
|
||||
const crit_mult = stats.get("critDamPct")/100;
|
||||
|
||||
for (const damage of damages) {
|
||||
const res = [
|
||||
damage[0] * strBoost * damage_mult, // Normal min
|
||||
damage[1] * strBoost * damage_mult, // Normal max
|
||||
damage[0] * (strBoost + 1) * damage_mult, // Crit min
|
||||
damage[1] * (strBoost + 1) * damage_mult, // Crit max
|
||||
damage[0] * (strBoost + crit_mult) * damage_mult, // Crit min
|
||||
damage[1] * (strBoost + crit_mult) * damage_mult, // Crit max
|
||||
];
|
||||
damages_results.push(res);
|
||||
total_dam_norm[0] += res[0];
|
||||
|
|
Loading…
Reference in a new issue