Rework initBuildStats
This commit is contained in:
parent
322a2c0d0c
commit
6bfea92e01
5 changed files with 63 additions and 95 deletions
127
build.js
127
build.js
|
@ -40,6 +40,17 @@ function levelToHPBase(level){
|
|||
}
|
||||
|
||||
|
||||
const baseDamageMultiplier = {
|
||||
SUPER_SLOW: 0.51,
|
||||
VERY_SLOW: 0.83,
|
||||
SLOW: 1.5,
|
||||
NORMAL: 2.05,
|
||||
FAST: 2.5,
|
||||
VERY_FAST: 3.1,
|
||||
SUPER_FAST: 4.3
|
||||
};
|
||||
const attackSpeeds = ["SUPER_SLOW", "VERY_SLOW", "SLOW", "NORMAL", "FAST", "VERY_FAST", "SUPER_FAST"];
|
||||
|
||||
/*Class that represents a wynn player's build.
|
||||
*/
|
||||
class Build{
|
||||
|
@ -101,13 +112,15 @@ class Build{
|
|||
}
|
||||
this.availableSkillpoints = levelToSkillPoints(this.level);
|
||||
this.equipment = [ helmet, chestplate, leggings, boots, ring1, ring2, bracelet, necklace ];
|
||||
this.items = [helmet, chestplate, leggings, boots, ring1, ring2, bracelet, necklace, weapon];
|
||||
this.items = this.equipment.concat([weapon]);
|
||||
// return [equip_order, best_skillpoints, final_skillpoints, best_total];
|
||||
let result = calculate_skillpoints(this.equipment, weapon);
|
||||
this.equip_order = result[0];
|
||||
this.base_skillpoints = result[1];
|
||||
this.total_skillpoints = result[2];
|
||||
this.assigned_skillpoints = result[3];
|
||||
|
||||
this.initBuildStats();
|
||||
}
|
||||
|
||||
/*Returns build in string format
|
||||
|
@ -130,37 +143,12 @@ class Build{
|
|||
}
|
||||
/* Get melee stats for build.
|
||||
Returns an array in the order:
|
||||
|
||||
*/
|
||||
getMeleeStats(){
|
||||
//Establish vars
|
||||
let meleeMult = new Map();
|
||||
meleeMult.set("SUPER_SLOW",0.51);
|
||||
meleeMult.set("VERY_SLOW",0.83);
|
||||
meleeMult.set("SLOW",1.5);
|
||||
meleeMult.set("NORMAL",2.05);
|
||||
meleeMult.set("FAST",2.5);
|
||||
meleeMult.set("VERY_FAST",3.1);
|
||||
meleeMult.set("SUPER_FAST",4.3);
|
||||
let atkSpdToNum = new Map();
|
||||
atkSpdToNum.set("SUPER_SLOW",-3);
|
||||
atkSpdToNum.set("VERY_SLOW",-2);
|
||||
atkSpdToNum.set("SLOW",-1);
|
||||
atkSpdToNum.set("NORMAL",0);
|
||||
atkSpdToNum.set("FAST",1);
|
||||
atkSpdToNum.set("VERY_FAST",2);
|
||||
atkSpdToNum.set("SUPER_FAST",3);
|
||||
let numToAtkSpd = new Map();
|
||||
numToAtkSpd.set(-3,"SUPER_SLOW");
|
||||
numToAtkSpd.set(-2,"VERY_SLOW");
|
||||
numToAtkSpd.set(-1,"SLOW");
|
||||
numToAtkSpd.set(0,"NORMAL");
|
||||
numToAtkSpd.set(1,"FAST");
|
||||
numToAtkSpd.set(2,"VERY_FAST");
|
||||
numToAtkSpd.set(3,"SUPER_FAST");
|
||||
|
||||
let stats = this.getBuildStats();
|
||||
let nDam = stats.get("nDam").split("-").map(Number);
|
||||
let damages = []
|
||||
let eDam = stats.get("eDam").split("-").map(Number);
|
||||
let tDam = stats.get("tDam").split("-").map(Number);
|
||||
let wDam = stats.get("wDam").split("-").map(Number);
|
||||
|
@ -201,6 +189,9 @@ class Build{
|
|||
agi = agi + agiReq;
|
||||
let poison = stats.get("maxStats").get("poison");
|
||||
|
||||
console.log(str);
|
||||
console.log(dex);
|
||||
|
||||
//Now do math
|
||||
let nDamAdj = [Math.round(nDam[0] * ((100 + mdPct + skillPointsToPercentage(str) * 100) / 100.) + mdRaw), Math.round(nDam[1] * ((100 + mdPct + skillPointsToPercentage(str) * 100) / 100.) + mdRaw), Math.round(nDam[0] * ((200 + mdPct + skillPointsToPercentage(str) * 100) / 100.) + mdRaw), Math.round(nDam[1] * ((200 + mdPct + skillPointsToPercentage(str) * 100) / 100.) + mdRaw)];
|
||||
let eDamAdj = [Math.round(eDam[0] * ((100 + mdPct + eDamPct + skillPointsToPercentage(str) * 100 + skillPointsToPercentage(str) * 100) / 100.)), Math.round(eDam[1] * ((100 + mdPct + eDamPct + skillPointsToPercentage(str) * 100 + skillPointsToPercentage(str) * 100) / 100.)), Math.round(eDam[0] * ((200 + mdPct + eDamPct + skillPointsToPercentage(str) * 100 + skillPointsToPercentage(str) * 100) / 100.)), Math.round(eDam[1] * ((200 + mdPct + eDamPct + skillPointsToPercentage(str) * 100 + skillPointsToPercentage(str) * 100) / 100.))];
|
||||
|
@ -225,69 +216,39 @@ class Build{
|
|||
@pre The build itself should be valid. No checking of validity of pieces is done here.
|
||||
@post The map returned will contain non-stacking IDs w/ a value null.
|
||||
*/
|
||||
getBuildStats(){
|
||||
initBuildStats(){
|
||||
|
||||
let staticIDs = ["hp", "eDef", "tDef", "wDef", "fDef", "aDef"];
|
||||
|
||||
//Create a map of this build's stats
|
||||
//This is universal for every possible build, so it's possible to move this elsewhere.
|
||||
let statMap = new Map();
|
||||
let minStats = new Map(); //for rolled mins
|
||||
let maxStats = new Map(); //for rolled maxs
|
||||
for (const i in item_fields){
|
||||
let id = item_fields[i];
|
||||
if(rolledIDs.includes(id)){ //ID is rolled - put the min and max rolls in min and max stats
|
||||
if(stackingIDs.includes(id)){ //IDs stack - make it number
|
||||
minStats.set(id,0);
|
||||
maxStats.set(id,0);
|
||||
}//if standaloneIDs includes id, something's wrong.
|
||||
}else{ //ID is not rolled - just set w/ default
|
||||
if(stackingIDs.includes(id)){//stacking but not rolled: ex skill points
|
||||
statMap.set(id,0);
|
||||
}else if(standaloneIDs.includes(id)){
|
||||
statMap.set(id,"");
|
||||
}else if(skpReqs.includes(id)){
|
||||
statMap.set(id,0);
|
||||
}
|
||||
}
|
||||
}
|
||||
statMap.set("minStats",minStats);
|
||||
statMap.set("maxStats",maxStats);
|
||||
|
||||
for (const i in this.items){
|
||||
let item = expandItem(this.items[i]);
|
||||
for(const [key,value] of item){ //for each key:value pair in item
|
||||
if(key === "minRolls"){
|
||||
for (const [id,roll] of value){ //for each id:roll pair in minRolls
|
||||
statMap.get("minStats").set(id,statMap.get("minStats").get(id) + roll); //we know they must stack
|
||||
}
|
||||
}else if(key==="maxRolls"){
|
||||
for (const [id,roll] of value){ //for each id:roll pair in maxRolls
|
||||
statMap.get("maxStats").set(id,statMap.get("maxStats").get(id) + roll); //we know they must stack
|
||||
}
|
||||
}else if(typeof value === "undefined"){ //does not stack - convert to string
|
||||
statMap.set(key,statMap.get(key).concat("undefined,"));
|
||||
}else if(typeof value === "null"){ //does not stack - convert to string
|
||||
statMap.set(key,statMap.get(key).concat("null,"));
|
||||
}else if(typeof value === "number"){ //although the value is not rolled, it stacks b/c it's a number.
|
||||
if(key === "strReq" || key === "dexReq" || key === "intReq" || key === "defReq" || key === "agiReq" ){
|
||||
if(value > statMap.get(key)){
|
||||
statMap.set(key,value);
|
||||
}
|
||||
}else{
|
||||
statMap.set(key,statMap.get(key)+value);
|
||||
}
|
||||
}else if(typeof value === "string"){ //does not stack
|
||||
if(key === "nDam" || key === "eDam" || key === "tDam" || key === "wDam" || key === "fDam" || key === "aDam" || key === "atkSpd"){
|
||||
statMap.set(key,statMap.get(key).concat(value));
|
||||
}else{
|
||||
statMap.set(key,statMap.get(key).concat(value.concat(",")));
|
||||
}
|
||||
}
|
||||
for (const staticID of staticIDs) {
|
||||
statMap.set(staticID, 0);
|
||||
}
|
||||
statMap.set("hp", 505); //TODO: Add player base health
|
||||
|
||||
for (const _item of this.items){
|
||||
let item = expandItem(_item);
|
||||
for (let [id, value] of item.get("maxRolls")) {
|
||||
statMap.set(id,(statMap.get(id) || 0)+value);
|
||||
}
|
||||
for (const staticID of staticIDs) {
|
||||
if (item[staticID]) { statMap.set(statMap.get(staticID) + item[staticID]); }
|
||||
}
|
||||
}
|
||||
|
||||
// The stuff relevant for damage calculation!!! @ferricles
|
||||
statMap.set("atkSpd", this.weapon["atkSpd"]);
|
||||
statMap.set("damageRaw", [this.weapon["nDam"], this.weapon["fDam"], this.weapon["wDam"], this.weapon["aDam"], this.weapon["tDam"], this.weapon["eDam"]]);
|
||||
statMap.set("damageBonus", [statMap.get("fDamPct"), statMap.get("wDamPct"), statMap.get("aDamPct"), statMap.get("tDamPct"), statMap.get("eDamPct")]);
|
||||
statMap.set("defRaw", [statMap.get("fDef"), statMap.get("wDef"), statMap.get("aDef"), statMap.get("tDef"), statMap.get("eDef")]);
|
||||
statMap.set("defBonus", [statMap.get("fDefPct"), statMap.get("wDefPct"), statMap.get("aDefPct"), statMap.get("tDefPct"), statMap.get("eDefPct")]);
|
||||
|
||||
console.log(statMap);
|
||||
return statMap;
|
||||
|
||||
this.statMap = statMap;
|
||||
}
|
||||
|
||||
/* Setters */
|
||||
|
||||
|
||||
}
|
||||
|
|
5
credits.txt
Normal file
5
credits.txt
Normal file
|
@ -0,0 +1,5 @@
|
|||
Damage calculator checking: https://its0x7.cf/build/
|
||||
|
||||
Theme and overall inspiration: Wynndata (Dukio)
|
||||
- https://wynndata.tk
|
||||
|
|
@ -1,7 +1,5 @@
|
|||
let nonRolledIDs = ["name", "displayName", "tier", "set", "slots", "type", "material", "drop", "quest", "restrict", "nDam", "fDam", "wDam", "aDam", "tDam", "eDam", "atkSpd", "hp", "fDef", "wDef", "aDef", "tDef", "eDef", "lvl", "classReq", "strReq", "dexReq", "intReq", "defReq", "agiReq","str", "dex", "int", "agi", "def", "fixID", "category", "id"];
|
||||
let rolledIDs = ["hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "thorns", "exploding", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd"];
|
||||
let stackingIDs = ["hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "thorns", "exploding", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd", "fDef", "wDef", "aDef", "tDef", "eDef", "str", "dex", "int", "agi", "def"];
|
||||
let standaloneIDs = ["name", "displayName", "tier", "set", "slots", "type", "material", "drop", "quest", "restrict", "nDam", "fDam", "wDam", "aDam", "tDam", "eDam", "atkSpd", "hp", "lvl", "classReq", "fixID", "category", "id"];
|
||||
|
||||
function expandItem(item){
|
||||
let minRolls = new Map();
|
||||
|
|
|
@ -14,6 +14,9 @@
|
|||
<div class="header" id="header">
|
||||
Wynn build calculator
|
||||
</div>
|
||||
<div class="center" id="header">
|
||||
<a href="credits.txt">Credits</a>
|
||||
</div>
|
||||
<div class="equipment">
|
||||
<div class="center" style="grid-column:1;grid-row:1">
|
||||
<div>
|
||||
|
|
23
test.js
23
test.js
|
@ -48,23 +48,24 @@ function populateItemList(type) {
|
|||
*/
|
||||
function init() {
|
||||
let noneItems = [
|
||||
["helmet", "No Helmet"],
|
||||
["chestplate", "No Chestplate"],
|
||||
["leggings", "No Leggings"],
|
||||
["boots", "No Boots"],
|
||||
["ring", "No Ring 1"],
|
||||
["ring", "No Ring 2"],
|
||||
["bracelet", "No Bracelet"],
|
||||
["necklace", "No Necklace"],
|
||||
["wand", "No Weapon"],
|
||||
["armor", "helmet", "No Helmet"],
|
||||
["armor", "chestplate", "No Chestplate"],
|
||||
["armor", "leggings", "No Leggings"],
|
||||
["armor", "boots", "No Boots"],
|
||||
["accessory", "ring", "No Ring 1"],
|
||||
["accessory", "ring", "No Ring 2"],
|
||||
["accessory", "bracelet", "No Bracelet"],
|
||||
["accessory", "necklace", "No Necklace"],
|
||||
["weapon", "wand", "No Weapon"],
|
||||
];
|
||||
for (let i = 0; i < 9; i++) {
|
||||
let item = Object();
|
||||
for (const field of item_fields) {
|
||||
item[field] = 0;
|
||||
}
|
||||
item.type = noneItems[i][0];
|
||||
item.name = noneItems[i][1];
|
||||
item.category = noneItems[i][0];
|
||||
item.type = noneItems[i][1];
|
||||
item.name = noneItems[i][2];
|
||||
item.displayName = item.name;
|
||||
item.set = null;
|
||||
item.quest = null;
|
||||
|
|
Loading…
Add table
Reference in a new issue