updated spell multipliers to 1.20, crafting now has attack speed tiers
This commit is contained in:
parent
c1e2753aa6
commit
cb200279c4
6 changed files with 58 additions and 12 deletions
16
craft.js
16
craft.js
|
@ -10,12 +10,12 @@ class Craft{
|
||||||
@param mat_tiers: [1->3, 1->3]. An array with 2 numbers.
|
@param mat_tiers: [1->3, 1->3]. An array with 2 numbers.
|
||||||
@param ingreds: []. An array with 6 entries, each with an ingredient Map.
|
@param ingreds: []. An array with 6 entries, each with an ingredient Map.
|
||||||
*/
|
*/
|
||||||
constructor(recipe, mat_tiers, ingreds) {
|
constructor(recipe, mat_tiers, ingreds, attackSpeed) {
|
||||||
this.recipe = recipe;
|
this.recipe = recipe;
|
||||||
this.mat_tiers = mat_tiers;
|
this.mat_tiers = mat_tiers;
|
||||||
this.ingreds = ingreds;
|
this.ingreds = ingreds;
|
||||||
this.statMap = new Map(); //can use the statMap as an expanded Item
|
this.statMap = new Map(); //can use the statMap as an expanded Item
|
||||||
|
this.atkSpd = attackSpeed;
|
||||||
this.initCraftStats();
|
this.initCraftStats();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -83,6 +83,7 @@ class Craft{
|
||||||
}
|
}
|
||||||
//statMap.set("damageBonus", [statMap.get("eDamPct"), statMap.get("tDamPct"), statMap.get("wDamPct"), statMap.get("fDamPct"), statMap.get("aDamPct")]);
|
//statMap.set("damageBonus", [statMap.get("eDamPct"), statMap.get("tDamPct"), statMap.get("wDamPct"), statMap.get("fDamPct"), statMap.get("aDamPct")]);
|
||||||
statMap.set("category","weapon");
|
statMap.set("category","weapon");
|
||||||
|
statMap.set("atkSpd",this.atkSpd);
|
||||||
}
|
}
|
||||||
statMap.set("powders","");
|
statMap.set("powders","");
|
||||||
/* Change certain IDs based on material tier.
|
/* Change certain IDs based on material tier.
|
||||||
|
@ -142,8 +143,17 @@ class Craft{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//apply material tiers - the good thing is that this should be symmetric.
|
//apply material tiers - the good thing is that this should be symmetric.
|
||||||
|
let matmult = 1;
|
||||||
for (const mat of this.mat_tiers) {
|
for (const mat of this.mat_tiers) {
|
||||||
|
|
||||||
|
}
|
||||||
|
if (statMap.get("category") === "consumable") {
|
||||||
|
//duration modifier
|
||||||
|
} else {
|
||||||
|
//durability modifier
|
||||||
|
}
|
||||||
|
if (statMap.get("category") === "weapon") {
|
||||||
|
//attack damages oh boy
|
||||||
}
|
}
|
||||||
|
|
||||||
//apply ingredient effectivness - on ids, and reqs (itemIDs). NOT on durability, duration, or charges.
|
//apply ingredient effectivness - on ids, and reqs (itemIDs). NOT on durability, duration, or charges.
|
||||||
|
|
20
crafter.html
20
crafter.html
|
@ -100,6 +100,26 @@
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
<label for = "atkSpdChoices"> Attack Speed (weapons only):</label>
|
||||||
|
<table class = "center" id = "atkSpdChoices">
|
||||||
|
<tr>
|
||||||
|
<td class = "center">
|
||||||
|
<button class = "button" id = "slow-atk-button" onclick = "toggleAtkSpd('slow-atk-button')">
|
||||||
|
Slow
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
<td class = "center">
|
||||||
|
<button class = "button" id = "normal-atk-button" onclick = "toggleAtkSpd('normal-atk-button')">
|
||||||
|
Normal
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
<td class = "center">
|
||||||
|
<button class = "button" id = "fast-atk-button" onclick = "toggleAtkSpd('fast-atk-button')">
|
||||||
|
Fast
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
<table class = "center">
|
<table class = "center">
|
||||||
<tr>
|
<tr>
|
||||||
<td class = "center">
|
<td class = "center">
|
||||||
|
|
22
crafter.js
22
crafter.js
|
@ -86,6 +86,18 @@ function updateMaterials() {
|
||||||
document.getElementById("mat-2").textContent = "Material 2 Tier:";
|
document.getElementById("mat-2").textContent = "Material 2 Tier:";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
function toggleAtkSpd(buttonId) {
|
||||||
|
let buttons = ["slow-atk-button", "normal-atk-button", "fast-atk-button"];
|
||||||
|
let elem = document.getElementById(buttonId);
|
||||||
|
if (elem.classList.contains("toggleOn")) {
|
||||||
|
elem.classList.remove("toggleOn");
|
||||||
|
} else {
|
||||||
|
for (const button of buttons) {
|
||||||
|
document.getElementById(button).classList.remove("toggleOn");
|
||||||
|
}
|
||||||
|
elem.classList.add("toggleOn");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function calculateCraft() {
|
function calculateCraft() {
|
||||||
//Make things display.
|
//Make things display.
|
||||||
|
@ -117,9 +129,15 @@ function calculateCraft() {
|
||||||
for (i = 1; i < 7; i++) {
|
for (i = 1; i < 7; i++) {
|
||||||
getValue("ing-choice-" + i) === "" ? ingreds.push(expandIngredient(ingMap.get("No Ingredient"))) : ingreds.push(expandIngredient(ingMap.get(getValue("ing-choice-" + i))));
|
getValue("ing-choice-" + i) === "" ? ingreds.push(expandIngredient(ingMap.get("No Ingredient"))) : ingreds.push(expandIngredient(ingMap.get(getValue("ing-choice-" + i))));
|
||||||
}
|
}
|
||||||
|
let atkSpd = "NORMAL"; //default attack speed will be normal.
|
||||||
|
for (const b of ["slow-atk-button", "normal-atk-button", "fast-atk-button"]) {
|
||||||
|
button = document.getElementById(b);
|
||||||
|
if (button.classList.contains("toggleOn")) {
|
||||||
|
atkSpd = b.split("-")[0].toUpperCase();
|
||||||
|
}
|
||||||
|
}
|
||||||
//create the craft
|
//create the craft
|
||||||
player_craft = new Craft(recipe,mat_tiers,ingreds);
|
player_craft = new Craft(recipe,mat_tiers,ingreds,atkSpd);
|
||||||
console.log(player_craft);
|
console.log(player_craft);
|
||||||
/*console.log(recipe)
|
/*console.log(recipe)
|
||||||
console.log(levelrange)
|
console.log(levelrange)
|
||||||
|
|
|
@ -146,7 +146,7 @@ const spell_table = {
|
||||||
{ title: "Charge", cost: 4, parts: [
|
{ title: "Charge", cost: 4, parts: [
|
||||||
{ subtitle: "Total Damage", type: "damage", multiplier: 150, conversion: [60, 0, 0, 0, 40, 0], summary: true },
|
{ subtitle: "Total Damage", type: "damage", multiplier: 150, conversion: [60, 0, 0, 0, 40, 0], summary: true },
|
||||||
] },
|
] },
|
||||||
{ title: "Uppercut", cost: 10, parts: [
|
{ title: "Uppercut", cost: 9, parts: [
|
||||||
{ subtitle: "First Damage", type: "damage", multiplier: 300, conversion: [70, 20, 10, 0, 0, 0] },
|
{ subtitle: "First Damage", type: "damage", multiplier: 300, conversion: [70, 20, 10, 0, 0, 0] },
|
||||||
{ subtitle: "Fireworks Damage", type: "damage", multiplier: 50, conversion: [60, 0, 40, 0, 0, 0] },
|
{ subtitle: "Fireworks Damage", type: "damage", multiplier: 50, conversion: [60, 0, 40, 0, 0, 0] },
|
||||||
{ subtitle: "Crash Damage", type: "damage", multiplier: 50, conversion: [80, 0, 20, 0, 0, 0] },
|
{ subtitle: "Crash Damage", type: "damage", multiplier: 50, conversion: [80, 0, 20, 0, 0, 0] },
|
||||||
|
@ -177,7 +177,7 @@ const spell_table = {
|
||||||
{ title: "Spin Attack", cost: 6, parts: [
|
{ title: "Spin Attack", cost: 6, parts: [
|
||||||
{ subtitle: "Total Damage", type: "damage", multiplier: 150, conversion: [70, 0, 30, 0, 0, 0], summary: true},
|
{ subtitle: "Total Damage", type: "damage", multiplier: 150, conversion: [70, 0, 30, 0, 0, 0], summary: true},
|
||||||
] },
|
] },
|
||||||
{ title: "Vanish", cost: 1, parts: [
|
{ title: "Vanish", cost: 2, parts: [
|
||||||
{ subtitle: "No Damage", type: "none", summary: true }
|
{ subtitle: "No Damage", type: "none", summary: true }
|
||||||
] },
|
] },
|
||||||
{ title: "Multihit", cost: 8, parts: [
|
{ title: "Multihit", cost: 8, parts: [
|
||||||
|
@ -194,7 +194,7 @@ const spell_table = {
|
||||||
{ title: "Totem", cost: 4, parts: [
|
{ title: "Totem", cost: 4, parts: [
|
||||||
{ subtitle: "Smash Damage", type: "damage", multiplier: 100, conversion: [80, 0, 0, 0, 20, 0]},
|
{ subtitle: "Smash Damage", type: "damage", multiplier: 100, conversion: [80, 0, 0, 0, 20, 0]},
|
||||||
{ subtitle: "Damage Tick", type: "damage", multiplier: 20, conversion: [80, 0, 0, 0, 0, 20]},
|
{ subtitle: "Damage Tick", type: "damage", multiplier: 20, conversion: [80, 0, 0, 0, 0, 20]},
|
||||||
{ subtitle: "Heal Tick", type: "heal", strength: 0.04, summary: true },
|
{ subtitle: "Heal Tick", type: "heal", strength: 0.03, summary: true },
|
||||||
] },
|
] },
|
||||||
{ title: "Haul", cost: 1, parts: [
|
{ title: "Haul", cost: 1, parts: [
|
||||||
{ subtitle: "Total Damage", type: "damage", multiplier: 100, conversion: [80, 0, 20, 0, 0, 0], summary: true },
|
{ subtitle: "Total Damage", type: "damage", multiplier: 100, conversion: [80, 0, 20, 0, 0, 0], summary: true },
|
||||||
|
@ -203,7 +203,7 @@ const spell_table = {
|
||||||
{ subtitle: "One Wave", type: "damage", multiplier: 200, conversion: [70, 0, 0, 30, 0, 0], summary: true },
|
{ subtitle: "One Wave", type: "damage", multiplier: 200, conversion: [70, 0, 0, 30, 0, 0], summary: true },
|
||||||
] },
|
] },
|
||||||
{ title: "Uproot", cost: 6, parts: [
|
{ title: "Uproot", cost: 6, parts: [
|
||||||
{ subtitle: "Total Damage", type: "damage", multiplier: 50, conversion: [70, 30, 0, 0, 0, 0], summary: true },
|
{ subtitle: "Total Damage", type: "damage", multiplier: 100, conversion: [70, 30, 0, 0, 0, 0], summary: true },
|
||||||
] },
|
] },
|
||||||
],
|
],
|
||||||
"powder": [ //This is how instant-damage powder specials are implemented. To view time-boosted damage powder specials (curse, 2nd courage, air prison, view @TODO)
|
"powder": [ //This is how instant-damage powder specials are implemented. To view time-boosted damage powder specials (curse, 2nd courage, air prison, view @TODO)
|
||||||
|
|
|
@ -831,7 +831,6 @@ function displayRecipeStats(craft, parent_id) {
|
||||||
tooltip.classList.add("tooltiptext");
|
tooltip.classList.add("tooltiptext");
|
||||||
tooltip.classList.add("center");
|
tooltip.classList.add("center");
|
||||||
tooltip.id = "tooltip-" + (2*i + j);
|
tooltip.id = "tooltip-" + (2*i + j);
|
||||||
console.log(tooltip.id);
|
|
||||||
cell.appendChild(tooltip);
|
cell.appendChild(tooltip);
|
||||||
}
|
}
|
||||||
ingredTable.appendChild(row);
|
ingredTable.appendChild(row);
|
||||||
|
@ -848,7 +847,6 @@ function displayCraftStats(craft, parent_id) {
|
||||||
|
|
||||||
//Displays an ingredient in item format. However, an ingredient is too far from a normal item to display as one.
|
//Displays an ingredient in item format. However, an ingredient is too far from a normal item to display as one.
|
||||||
function displayExpandedIngredient(ingred, parent_id) {
|
function displayExpandedIngredient(ingred, parent_id) {
|
||||||
console.log(ingred);
|
|
||||||
let parent_elem = document.getElementById(parent_id);
|
let parent_elem = document.getElementById(parent_id);
|
||||||
parent_elem.textContent = "";
|
parent_elem.textContent = "";
|
||||||
let display_order = [
|
let display_order = [
|
||||||
|
|
|
@ -400,7 +400,7 @@ button.toggleOn:hover {
|
||||||
visibility: hidden;
|
visibility: hidden;
|
||||||
width: 120px;
|
width: 120px;
|
||||||
color: #aaa;
|
color: #aaa;
|
||||||
background: #1e2224;
|
background: #110110;
|
||||||
width: min(200%, 75vw);
|
width: min(200%, 75vw);
|
||||||
text-align: center;
|
text-align: center;
|
||||||
border: 5px solid #BCBCBC;
|
border: 5px solid #BCBCBC;
|
||||||
|
|
Loading…
Reference in a new issue