fixed pos raw and <-100 % issue, added external buffs + powder specials section, added buttons & functionality for all spell-based external buffs
This commit is contained in:
parent
a02cd0c794
commit
43aba4a720
7 changed files with 67 additions and 7 deletions
2
build.js
2
build.js
|
@ -173,7 +173,7 @@ class Build{
|
||||||
}
|
}
|
||||||
|
|
||||||
// 0 for melee damage.
|
// 0 for melee damage.
|
||||||
let results = calculateSpellDamage(stats, [100, 0, 0, 0, 0, 0], stats.get("mdRaw"), stats.get("mdPct"), 0, this.weapon, this.total_skillpoints);
|
let results = calculateSpellDamage(stats, [100, 0, 0, 0, 0, 0], stats.get("mdRaw"), stats.get("mdPct"), 0, this.weapon, this.total_skillpoints, this.damageMultiplier);
|
||||||
|
|
||||||
let dex = this.total_skillpoints[1];
|
let dex = this.total_skillpoints[1];
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
|
const damageMultipliers = new Map([ ["allytotem", .35], ["yourtotem", .35], ["vanish", 0.80], ["warscream", 0.10] ]);
|
||||||
// Calculate spell damage given a spell elemental conversion table, and a spell multiplier.
|
// Calculate spell damage given a spell elemental conversion table, and a spell multiplier.
|
||||||
// If spell mult is 0, its melee damage and we don't multiply by attack speed.
|
// If spell mult is 0, its melee damage and we don't multiply by attack speed.
|
||||||
function calculateSpellDamage(stats, spellConversions, rawModifier, pctModifier, spellMultiplier, weapon, total_skillpoints) {
|
function calculateSpellDamage(stats, spellConversions, rawModifier, pctModifier, spellMultiplier, weapon, total_skillpoints, damageMultiplier) {
|
||||||
// Array of neutral + ewtfa damages. Each entry is a pair (min, max).
|
// Array of neutral + ewtfa damages. Each entry is a pair (min, max).
|
||||||
let damages = [];
|
let damages = [];
|
||||||
for (const damage_string of stats.get("damageRaw")) {
|
for (const damage_string of stats.get("damageRaw")) {
|
||||||
|
@ -39,7 +40,7 @@ function calculateSpellDamage(stats, spellConversions, rawModifier, pctModifier,
|
||||||
damages[element+1][1] += powder.max;
|
damages[element+1][1] += powder.max;
|
||||||
}
|
}
|
||||||
|
|
||||||
let damageMult = 1;
|
let damageMult = damageMultiplier;
|
||||||
let melee = false;
|
let melee = false;
|
||||||
// If we are doing melee calculations:
|
// If we are doing melee calculations:
|
||||||
if (spellMultiplier == 0) {
|
if (spellMultiplier == 0) {
|
||||||
|
@ -99,6 +100,8 @@ function calculateSpellDamage(stats, spellConversions, rawModifier, pctModifier,
|
||||||
return [totalDamNorm, totalDamCrit, damages_results];
|
return [totalDamNorm, totalDamCrit, damages_results];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const spell_table = {
|
const spell_table = {
|
||||||
"wand": [
|
"wand": [
|
||||||
{ title: "Heal", cost: 6, parts: [
|
{ title: "Heal", cost: 6, parts: [
|
||||||
|
|
|
@ -273,7 +273,7 @@ function displayExpandedItem(item, parent_id){
|
||||||
stats.set("atkSpd", item.get("atkSpd"));
|
stats.set("atkSpd", item.get("atkSpd"));
|
||||||
stats.set("damageBonus", [0, 0, 0, 0, 0]);
|
stats.set("damageBonus", [0, 0, 0, 0, 0]);
|
||||||
stats.set("damageRaw", [item.get("nDam"), item.get("eDam"), item.get("tDam"), item.get("wDam"), item.get("fDam"), item.get("aDam")]);
|
stats.set("damageRaw", [item.get("nDam"), item.get("eDam"), item.get("tDam"), item.get("wDam"), item.get("fDam"), item.get("aDam")]);
|
||||||
let results = calculateSpellDamage(stats, [100, 0, 0, 0, 0, 0], 0, 0, 0, item, [0, 0, 0, 0, 0]);
|
let results = calculateSpellDamage(stats, [100, 0, 0, 0, 0, 0], 0, 0, 0, item, [0, 0, 0, 0, 0], 1);
|
||||||
let damages = results[2];
|
let damages = results[2];
|
||||||
let damage_keys = [ "nDam_", "eDam_", "tDam_", "wDam_", "fDam_", "aDam_" ];
|
let damage_keys = [ "nDam_", "eDam_", "tDam_", "wDam_", "fDam_", "aDam_" ];
|
||||||
for (const i in damage_keys) {
|
for (const i in damage_keys) {
|
||||||
|
@ -988,7 +988,7 @@ function displaySpellDamage(parent_elem, overallparent_elem, build, spell, spell
|
||||||
|
|
||||||
let _results = calculateSpellDamage(stats, part.conversion,
|
let _results = calculateSpellDamage(stats, part.conversion,
|
||||||
stats.get("sdRaw"), stats.get("sdPct"),
|
stats.get("sdRaw"), stats.get("sdPct"),
|
||||||
part.multiplier / 100, build.weapon, build.total_skillpoints);
|
part.multiplier / 100, build.weapon, build.total_skillpoints, build.damageMultiplier);
|
||||||
let totalDamNormal = _results[0];
|
let totalDamNormal = _results[0];
|
||||||
let totalDamCrit = _results[1];
|
let totalDamCrit = _results[1];
|
||||||
let results = _results[2];
|
let results = _results[2];
|
||||||
|
|
31
index.html
31
index.html
|
@ -176,6 +176,37 @@
|
||||||
Summary:
|
Summary:
|
||||||
</div>
|
</div>
|
||||||
<br><br>
|
<br><br>
|
||||||
|
<div class="externalBuffs" id="buff-box">
|
||||||
|
<table>
|
||||||
|
<tr>
|
||||||
|
<p class = "buffs-title itemp title">
|
||||||
|
Spell Boosts & Powder Specials:
|
||||||
|
</p>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<button class = "button toggleOff" id = "vanish-boost" onclick = "updateBoosts('vanish-boost')">
|
||||||
|
Vanish Boost (+80%)
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<button class = "button toggleOff" id = "warscream-boost" onclick = "updateBoosts('warscream-boost')">
|
||||||
|
War Scream (+10%)
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<button class = "button toggleOff" id = "yourtotem-boost" onclick = "updateBoosts('yourtotem-boost')">
|
||||||
|
Your Totem (+35%)
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<button class = "button toggleOff" id = "allytotem-boost" onclick = "updateBoosts('allytotem-boost')">
|
||||||
|
Ally Totem (+15%)
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="build-overall-container">
|
<div class="build-overall-container">
|
||||||
|
|
|
@ -236,3 +236,8 @@ input {
|
||||||
.restrict, .warning {
|
.restrict, .warning {
|
||||||
color: #ff8180;
|
color: #ff8180;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
button.toggleOn{
|
||||||
|
background-color:#0a0;
|
||||||
|
border: 3 px solid rgb(0, 70, 0);
|
||||||
|
}
|
23
test.js
23
test.js
|
@ -345,6 +345,8 @@ function decodeBuild(url_tag) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Stores the entire build in a string using B64 encryption and adds it to the URL.
|
||||||
|
*/
|
||||||
function encodeBuild() {
|
function encodeBuild() {
|
||||||
if (player_build) {
|
if (player_build) {
|
||||||
let build_string = "3_" + Base64.fromIntN(player_build.helmet.get("id"), 3) +
|
let build_string = "3_" + Base64.fromIntN(player_build.helmet.get("id"), 3) +
|
||||||
|
@ -445,6 +447,8 @@ function calculateBuild(save_skp, skp){
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Updates all build statistics based on (for now) the skillpoint input fields and then calculates build stats.
|
||||||
|
*/
|
||||||
function updateStats() {
|
function updateStats() {
|
||||||
//WILL BREAK WEBSITE IF NO BUILD HAS BEEN INITIALIZED! @HPP
|
//WILL BREAK WEBSITE IF NO BUILD HAS BEEN INITIALIZED! @HPP
|
||||||
let skillpoints = player_build.total_skillpoints;
|
let skillpoints = player_build.total_skillpoints;
|
||||||
|
@ -459,9 +463,26 @@ function updateStats() {
|
||||||
player_build.assigned_skillpoints += delta_total;
|
player_build.assigned_skillpoints += delta_total;
|
||||||
calculateBuildStats();
|
calculateBuildStats();
|
||||||
}
|
}
|
||||||
|
/* Updates all external boosts (boosts from spells + powders)
|
||||||
|
*/
|
||||||
|
function updateBoosts(buttonId) {
|
||||||
|
let elem = document.getElementById(buttonId);
|
||||||
|
if (elem.classList.contains("toggleOn")) {
|
||||||
|
player_build.damageMultiplier -= damageMultipliers.get(buttonId.split("-")[0]);
|
||||||
|
elem.classList.remove("toggleOn");
|
||||||
|
elem.classList.add("toggleOff");
|
||||||
|
}else{
|
||||||
|
player_build.damageMultiplier += damageMultipliers.get(buttonId.split("-")[0]);
|
||||||
|
elem.classList.remove("toggleOff");
|
||||||
|
elem.classList.add("toggleOn");
|
||||||
|
}
|
||||||
|
//displayPowderBoosts(); TODO WRITE
|
||||||
|
calculateBuildStats();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Calculates all build statistics and updates the entire display.
|
||||||
|
*/
|
||||||
function calculateBuildStats() {
|
function calculateBuildStats() {
|
||||||
|
|
||||||
const assigned = player_build.base_skillpoints;
|
const assigned = player_build.base_skillpoints;
|
||||||
const skillpoints = player_build.total_skillpoints;
|
const skillpoints = player_build.total_skillpoints;
|
||||||
let skp_effects = ["% more damage dealt.","% chance to crit.","% spell cost reduction.","% less damage taken.","% chance to dodge."];
|
let skp_effects = ["% more damage dealt.","% chance to crit.","% spell cost reduction.","% less damage taken.","% chance to dodge."];
|
||||||
|
|
2
utils.js
2
utils.js
|
@ -119,7 +119,7 @@ function rawToPct(raw, pct){
|
||||||
if (raw < 0){
|
if (raw < 0){
|
||||||
final = (Math.min(0, raw - (raw * pct) ));
|
final = (Math.min(0, raw - (raw * pct) ));
|
||||||
}else if(raw > 0){
|
}else if(raw > 0){
|
||||||
final = (Math.max(0, raw + (raw * pct)));
|
final = raw + (raw * pct);
|
||||||
}else{ //do nothing - final's already 0
|
}else{ //do nothing - final's already 0
|
||||||
}
|
}
|
||||||
return final;
|
return final;
|
||||||
|
|
Loading…
Reference in a new issue