Save powders
This commit is contained in:
parent
370e18fef2
commit
9d9554209b
4 changed files with 155 additions and 30 deletions
34
build.js
34
build.js
|
@ -49,26 +49,32 @@ class Build{
|
||||||
|
|
||||||
/*Construct a build.
|
/*Construct a build.
|
||||||
*/
|
*/
|
||||||
constructor(level,helmet,chestplate,leggings,boots,ring1,ring2,bracelet,necklace,weapon){
|
constructor(level,helmet,chestplate,leggings,boots,ring1,ring2,bracelet,necklace,weapon,powders){
|
||||||
|
// NOTE: powders is just an array of arrays of powder IDs. Not powder objects.
|
||||||
|
this.powders = powders
|
||||||
if(helmet.type.valueOf() != "helmet".valueOf()){
|
if(helmet.type.valueOf() != "helmet".valueOf()){
|
||||||
throw new TypeError("No such helmet named ", helmet.name);
|
throw new TypeError("No such helmet named ", helmet.name);
|
||||||
}else{
|
}else{
|
||||||
this.helmet = helmet;
|
this.helmet = helmet;
|
||||||
|
this.powders[0] = this.powders[0].slice(0,helmet.slots);
|
||||||
}
|
}
|
||||||
if(chestplate.type.valueOf() != "chestplate"){
|
if(chestplate.type.valueOf() != "chestplate"){
|
||||||
throw new TypeError("No such chestplate named ", chestplate.name);
|
throw new TypeError("No such chestplate named ", chestplate.name);
|
||||||
}else{
|
}else{
|
||||||
this.chestplate = chestplate;
|
this.chestplate = chestplate;
|
||||||
|
this.powders[1] = this.powders[1].slice(0,chestplate.slots);
|
||||||
}
|
}
|
||||||
if(leggings.type.valueOf() != "leggings"){
|
if(leggings.type.valueOf() != "leggings"){
|
||||||
throw new TypeError("No such leggings named ", leggings.name);
|
throw new TypeError("No such leggings named ", leggings.name);
|
||||||
}else{
|
}else{
|
||||||
this.leggings = leggings;
|
this.leggings = leggings;
|
||||||
|
this.powders[2] = this.powders[2].slice(0,leggings.slots);
|
||||||
}
|
}
|
||||||
if(boots.type.valueOf() != "boots"){
|
if(boots.type.valueOf() != "boots"){
|
||||||
throw new TypeError("No such boots named ", boots.name);
|
throw new TypeError("No such boots named ", boots.name);
|
||||||
}else{
|
}else{
|
||||||
this.boots = boots;
|
this.boots = boots;
|
||||||
|
this.powders[3] = this.powders[3].slice(0,boots.slots);
|
||||||
}
|
}
|
||||||
if(ring1.type.valueOf() != "ring"){
|
if(ring1.type.valueOf() != "ring"){
|
||||||
throw new TypeError("No such ring named ", ring1.name);
|
throw new TypeError("No such ring named ", ring1.name);
|
||||||
|
@ -92,6 +98,7 @@ class Build{
|
||||||
}
|
}
|
||||||
if(weapon.type.valueOf() == "wand" || weapon.type.valueOf() == "bow" || weapon.type.valueOf() == "dagger" || weapon.type.valueOf() == "spear" || weapon.type.valueOf() == "relik"){
|
if(weapon.type.valueOf() == "wand" || weapon.type.valueOf() == "bow" || weapon.type.valueOf() == "dagger" || weapon.type.valueOf() == "spear" || weapon.type.valueOf() == "relik"){
|
||||||
this.weapon = weapon;
|
this.weapon = weapon;
|
||||||
|
this.powders[4] = this.powders[4].slice(0,weapon.slots);
|
||||||
}else{
|
}else{
|
||||||
throw new TypeError("No such weapon named ", weapon.name);
|
throw new TypeError("No such weapon named ", weapon.name);
|
||||||
}
|
}
|
||||||
|
@ -112,6 +119,9 @@ class Build{
|
||||||
this.total_skillpoints = result[2];
|
this.total_skillpoints = result[2];
|
||||||
this.assigned_skillpoints = result[3];
|
this.assigned_skillpoints = result[3];
|
||||||
|
|
||||||
|
// For strength boosts like warscream, vanish, etc.
|
||||||
|
this.damage_multiplier = 1.0;
|
||||||
|
|
||||||
this.initBuildStats();
|
this.initBuildStats();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -126,7 +136,11 @@ class Build{
|
||||||
/* Get total health for build.
|
/* Get total health for build.
|
||||||
*/
|
*/
|
||||||
getHealth(){
|
getHealth(){
|
||||||
health = parseInt(this.helmet.hp,10) + parseInt(this.helmet.hpBonus,10) + parseInt(this.chestplate.hp,10) + parseInt(this.chestplate.hpBonus,10) + parseInt(this.leggings.hp,10) + parseInt(this.leggings.hpBonus,10) + parseInt(this.boots.hp,10) + parseInt(this.boots.hpBonus,10) + parseInt(this.ring1.hp,10) + parseInt(this.ring1.hpBonus,10) + parseInt(this.ring2.hp,10) + parseInt(this.ring2.hpBonus,10) + parseInt(this.bracelet.hp,10) + parseInt(this.bracelet.hpBonus,10) + parseInt(this.necklace.hp,10) + parseInt(this.necklace.hpBonus,10) + parseInt(this.weapon.hp,10) + parseInt(this.weapon.hpBonus,10) + levelToHPBase(this.level);
|
let health = levelToHPBase(this.level);
|
||||||
|
for (const item in this.items) {
|
||||||
|
if (item.hp) health += item.hp;
|
||||||
|
if (item.hpBonus) health += item.hpBonus;
|
||||||
|
}
|
||||||
if(health<5){
|
if(health<5){
|
||||||
return 5;
|
return 5;
|
||||||
}else{
|
}else{
|
||||||
|
@ -168,15 +182,13 @@ class Build{
|
||||||
for (let i in this.total_skillpoints) {
|
for (let i in this.total_skillpoints) {
|
||||||
skillBoost.push(skillPointsToPercentage(this.total_skillpoints[i]) + stats.get("damageBonus")[i] / 100.);
|
skillBoost.push(skillPointsToPercentage(this.total_skillpoints[i]) + stats.get("damageBonus")[i] / 100.);
|
||||||
}
|
}
|
||||||
console.log(skillBoost);
|
|
||||||
for (let i in damages) {
|
for (let i in damages) {
|
||||||
let damageBoost = 1 + skillBoost[i] + staticBoost;
|
let damageBoost = 1 + skillBoost[i] + staticBoost;
|
||||||
console.log(damageBoost);
|
|
||||||
damages_results.push([
|
damages_results.push([
|
||||||
Math.round(damages[i][0] * damageBoost), // Normal min
|
Math.max(damages[i][0] * damageBoost * this.damage_multiplier, 0), // Normal min
|
||||||
Math.round(damages[i][1] * damageBoost), // Normal max
|
Math.max(damages[i][1] * damageBoost * this.damage_multiplier, 0), // Normal max
|
||||||
Math.round(damages[i][0] * (1 + damageBoost)), // Crit min
|
Math.max(damages[i][0] * (1 + damageBoost) * this.damage_multiplier, 0), // Crit min
|
||||||
Math.round(damages[i][1] * (1 + damageBoost)), // Crit max
|
Math.max(damages[i][1] * (1 + damageBoost) * this.damage_multiplier, 0), // Crit max
|
||||||
]);
|
]);
|
||||||
totalDamNorm[0] += damages_results[i][0];
|
totalDamNorm[0] += damages_results[i][0];
|
||||||
totalDamNorm[1] += damages_results[i][1];
|
totalDamNorm[1] += damages_results[i][1];
|
||||||
|
@ -184,7 +196,7 @@ class Build{
|
||||||
totalDamCrit[1] += damages_results[i][3];
|
totalDamCrit[1] += damages_results[i][3];
|
||||||
}
|
}
|
||||||
for (let i in damages_results[0]) {
|
for (let i in damages_results[0]) {
|
||||||
damages_results[0][i] += mdRaw;
|
damages_results[0][i] += mdRaw * this.damage_multiplier;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Now do math
|
//Now do math
|
||||||
|
@ -210,7 +222,7 @@ class Build{
|
||||||
for (const staticID of staticIDs) {
|
for (const staticID of staticIDs) {
|
||||||
statMap.set(staticID, 0);
|
statMap.set(staticID, 0);
|
||||||
}
|
}
|
||||||
statMap.set("hp", 505); //TODO: Add player base health
|
statMap.set("hp", this.getHealth());
|
||||||
|
|
||||||
for (const _item of this.items){
|
for (const _item of this.items){
|
||||||
let item = expandItem(_item);
|
let item = expandItem(_item);
|
||||||
|
@ -229,8 +241,6 @@ class Build{
|
||||||
statMap.set("defRaw", [statMap.get("eDam"), statMap.get("tDef"), statMap.get("wDef"), statMap.get("fDef"), statMap.get("aDef")]);
|
statMap.set("defRaw", [statMap.get("eDam"), statMap.get("tDef"), statMap.get("wDef"), statMap.get("fDef"), statMap.get("aDef")]);
|
||||||
statMap.set("defBonus", [statMap.get("eDamPct"), statMap.get("tDefPct"), statMap.get("wDefPct"), statMap.get("fDefPct"), statMap.get("aDefPct")]);
|
statMap.set("defBonus", [statMap.get("eDamPct"), statMap.get("tDefPct"), statMap.get("wDefPct"), statMap.get("fDefPct"), statMap.get("aDefPct")]);
|
||||||
|
|
||||||
console.log(statMap);
|
|
||||||
|
|
||||||
this.statMap = statMap;
|
this.statMap = statMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
padding: 4%;
|
padding: 4%;
|
||||||
display: grid;
|
display: grid;
|
||||||
grid-template-columns: repeat(4, 1fr);
|
grid-template-columns: repeat(4, 1fr);
|
||||||
gap: 25px;
|
gap: 15px;
|
||||||
grid-auto-rows: minmax(60px, auto);
|
grid-auto-rows: minmax(60px, auto);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
145
test.js
145
test.js
|
@ -22,6 +22,35 @@ let accessoryTypes = [ "ring", "bracelet", "necklace" ];
|
||||||
let weaponTypes = [ "wand", "spear", "bow", "dagger", "relik" ];
|
let weaponTypes = [ "wand", "spear", "bow", "dagger", "relik" ];
|
||||||
let item_fields = [ "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", "hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "str", "dex", "int", "agi", "def", "thorns", "exploding", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "fixID", "category", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd", "id" ];
|
let item_fields = [ "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", "hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "str", "dex", "int", "agi", "def", "thorns", "exploding", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "fixID", "category", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd", "id" ];
|
||||||
let skpReqs = ["strReq", "dexReq", "intReq", "defReq", "agiReq"];
|
let skpReqs = ["strReq", "dexReq", "intReq", "defReq", "agiReq"];
|
||||||
|
|
||||||
|
let powderIDs = new Map();
|
||||||
|
let powderNames = new Map();
|
||||||
|
let _powderID = 0;
|
||||||
|
for (const x of ['e', 't', 'w', 'f', 'a']) {
|
||||||
|
for (let i = 1; i <= 6; ++i) {
|
||||||
|
// Support both upper and lowercase, I guess.
|
||||||
|
powderIDs.set(x.toUpperCase()+i, _powderID);
|
||||||
|
powderIDs.set(x+i, _powderID);
|
||||||
|
powderNames.set(_powderID, x+i);
|
||||||
|
_powderID++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
let powderInputs = [
|
||||||
|
"helmet-powder",
|
||||||
|
"chestplate-powder",
|
||||||
|
"leggings-powder",
|
||||||
|
"boots-powder",
|
||||||
|
"weapon-powder",
|
||||||
|
];
|
||||||
|
// Ordering: [dmgMin, dmgMax, convert, defPlus, defMinus (+6 mod 5)]
|
||||||
|
let powderStats = [
|
||||||
|
[3,6,17,2,1], [6,9,21,4,2], [8,14,25,8,3], [11,16,31,14,5], [15,18,38,22,9], [18,22,46,30,13],
|
||||||
|
[1,8,9,3,1], [1,13,11,5,1], [2,18,14,9,2], [3,24,17,14,4], [3,32,22,20,7], [5,40,28,28,10],
|
||||||
|
[3,4,13,3,1], [4,7,15,6,1], [6,10,17,11,2], [8,12,21,18,4], [11,14,26,28,7], [13,17,32,40,10],
|
||||||
|
[2,5,14,3,1], [4,8,16,5,2], [6,10,19,9,3], [9,13,24,16,5], [12,16,30,25,9], [15,19,37,36,13],
|
||||||
|
[2,6,11,3,1], [4,9,14,6,2], [7,10,17,10,3], [9,13,22,16,5], [13,18,28,24,9], [16,18,35,34,13]
|
||||||
|
];
|
||||||
|
|
||||||
let itemTypes = armorTypes.concat(accessoryTypes).concat(weaponTypes);
|
let itemTypes = armorTypes.concat(accessoryTypes).concat(weaponTypes);
|
||||||
let itemLists = new Map();
|
let itemLists = new Map();
|
||||||
for (const it of itemTypes) {
|
for (const it of itemTypes) {
|
||||||
|
@ -75,6 +104,12 @@ function init() {
|
||||||
item.fixID = true;
|
item.fixID = true;
|
||||||
item.tier = " ";//do not get rid of this @hpp
|
item.tier = " ";//do not get rid of this @hpp
|
||||||
item.id = 10000 + i;
|
item.id = 10000 + i;
|
||||||
|
item.nDam = "0-0";
|
||||||
|
item.eDam = "0-0";
|
||||||
|
item.tDam = "0-0";
|
||||||
|
item.wDam = "0-0";
|
||||||
|
item.fDam = "0-0";
|
||||||
|
item.aDam = "0-0";
|
||||||
|
|
||||||
noneItems[i] = item;
|
noneItems[i] = item;
|
||||||
}
|
}
|
||||||
|
@ -155,9 +190,10 @@ function populateFromURL() {
|
||||||
let bracelet;
|
let bracelet;
|
||||||
let necklace;
|
let necklace;
|
||||||
let weapon;
|
let weapon;
|
||||||
|
let powdering = ["", "", "", "", ""];
|
||||||
let info = url_tag.split("_");
|
let info = url_tag.split("_");
|
||||||
let version = info[0];
|
let version = info[0];
|
||||||
if (version === "0") {
|
if (version === "0" || version === "1") {
|
||||||
let equipments = info[1];
|
let equipments = info[1];
|
||||||
helmet = idMap.get(Base64.toInt(equipments.slice(0,3)));
|
helmet = idMap.get(Base64.toInt(equipments.slice(0,3)));
|
||||||
chestplate = idMap.get(Base64.toInt(equipments.slice(3,6)));
|
chestplate = idMap.get(Base64.toInt(equipments.slice(3,6)));
|
||||||
|
@ -169,21 +205,43 @@ function populateFromURL() {
|
||||||
necklace = idMap.get(Base64.toInt(equipments.slice(21,24)));
|
necklace = idMap.get(Base64.toInt(equipments.slice(21,24)));
|
||||||
weapon = idMap.get(Base64.toInt(equipments.slice(24,27)));
|
weapon = idMap.get(Base64.toInt(equipments.slice(24,27)));
|
||||||
}
|
}
|
||||||
|
if (version === "1") {
|
||||||
|
let powder_info = info[1].slice(27);
|
||||||
|
console.log(powder_info);
|
||||||
|
// TODO: Make this run in linear instead of quadratic time...
|
||||||
|
for (let i = 0; i < 5; ++i) {
|
||||||
|
let powders = "";
|
||||||
|
let n_blocks = Base64.toInt(powder_info.charAt(0));
|
||||||
|
console.log(n_blocks + " blocks");
|
||||||
|
powder_info = powder_info.slice(1);
|
||||||
|
for (let j = 0; j < n_blocks; ++j) {
|
||||||
|
let block = powder_info.slice(0,5);
|
||||||
|
console.log(block);
|
||||||
|
let six_powders = Base64.toInt(block);
|
||||||
|
for (let k = 0; k < 6 && six_powders != 0; ++k) {
|
||||||
|
powders += powderNames.get((six_powders & 0x1f) - 1);
|
||||||
|
six_powders >>>= 5;
|
||||||
|
}
|
||||||
|
powder_info = powder_info.slice(5);
|
||||||
|
}
|
||||||
|
powdering[i] = powders;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
setValue("helmet-choice", helmet);
|
setValue("helmet-choice", helmet);
|
||||||
setValue("helmet-powder", "");
|
setValue("helmet-powder", powdering[0]);
|
||||||
setValue("chestplate-choice", chestplate);
|
setValue("chestplate-choice", chestplate);
|
||||||
setValue("chestplate-powder", "");
|
setValue("chestplate-powder", powdering[1]);
|
||||||
setValue("leggings-choice", leggings);
|
setValue("leggings-choice", leggings);
|
||||||
setValue("leggings-powder", "");
|
setValue("leggings-powder", powdering[2]);
|
||||||
setValue("boots-choice", boots);
|
setValue("boots-choice", boots);
|
||||||
setValue("boots-powder", "");
|
setValue("boots-powder", powdering[3]);
|
||||||
setValue("ring1-choice", ring1);
|
setValue("ring1-choice", ring1);
|
||||||
setValue("ring2-choice", ring2);
|
setValue("ring2-choice", ring2);
|
||||||
setValue("bracelet-choice", bracelet);
|
setValue("bracelet-choice", bracelet);
|
||||||
setValue("necklace-choice", necklace);
|
setValue("necklace-choice", necklace);
|
||||||
setValue("weapon-choice", weapon);
|
setValue("weapon-choice", weapon);
|
||||||
setValue("weapon-powder", "");
|
setValue("weapon-powder", powdering[4]);
|
||||||
setValue("str-skp", "0");
|
setValue("str-skp", "0");
|
||||||
setValue("dex-skp", "0");
|
setValue("dex-skp", "0");
|
||||||
setValue("int-skp", "0");
|
setValue("int-skp", "0");
|
||||||
|
@ -195,7 +253,16 @@ function populateFromURL() {
|
||||||
|
|
||||||
function encodeBuild() {
|
function encodeBuild() {
|
||||||
if (player_build) {
|
if (player_build) {
|
||||||
let build_string = "0_" + Base64.fromIntN(player_build.helmet.id, 3) +
|
// let build_string = "0_" + Base64.fromIntN(player_build.helmet.id, 3) +
|
||||||
|
// Base64.fromIntN(player_build.chestplate.id, 3) +
|
||||||
|
// Base64.fromIntN(player_build.leggings.id, 3) +
|
||||||
|
// Base64.fromIntN(player_build.boots.id, 3) +
|
||||||
|
// Base64.fromIntN(player_build.ring1.id, 3) +
|
||||||
|
// Base64.fromIntN(player_build.ring2.id, 3) +
|
||||||
|
// Base64.fromIntN(player_build.bracelet.id, 3) +
|
||||||
|
// Base64.fromIntN(player_build.necklace.id, 3) +
|
||||||
|
// Base64.fromIntN(player_build.weapon.id, 3);
|
||||||
|
let build_string = "1_" + Base64.fromIntN(player_build.helmet.id, 3) +
|
||||||
Base64.fromIntN(player_build.chestplate.id, 3) +
|
Base64.fromIntN(player_build.chestplate.id, 3) +
|
||||||
Base64.fromIntN(player_build.leggings.id, 3) +
|
Base64.fromIntN(player_build.leggings.id, 3) +
|
||||||
Base64.fromIntN(player_build.boots.id, 3) +
|
Base64.fromIntN(player_build.boots.id, 3) +
|
||||||
|
@ -205,6 +272,22 @@ function encodeBuild() {
|
||||||
Base64.fromIntN(player_build.necklace.id, 3) +
|
Base64.fromIntN(player_build.necklace.id, 3) +
|
||||||
Base64.fromIntN(player_build.weapon.id, 3);
|
Base64.fromIntN(player_build.weapon.id, 3);
|
||||||
|
|
||||||
|
for (const _powderset of player_build.powders) {
|
||||||
|
let n_bits = Math.ceil(_powderset.length / 6);
|
||||||
|
build_string += Base64.fromIntN(n_bits, 1); // Hard cap of 378 powders.
|
||||||
|
// Slice copy.
|
||||||
|
let powderset = _powderset.slice();
|
||||||
|
while (powderset.length != 0) {
|
||||||
|
let firstSix = powderset.slice(0,6).reverse();
|
||||||
|
let powder_hash = 0;
|
||||||
|
for (const powder of firstSix) {
|
||||||
|
powder_hash = (powder_hash << 5) + 1 + powder; // LSB will be extracted first.
|
||||||
|
}
|
||||||
|
build_string += Base64.fromIntN(powder_hash, 5);
|
||||||
|
powderset = powderset.slice(6);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return build_string;
|
return build_string;
|
||||||
}
|
}
|
||||||
return "";
|
return "";
|
||||||
|
@ -214,15 +297,15 @@ function calculateBuild(){
|
||||||
/* TODO: implement level changing
|
/* TODO: implement level changing
|
||||||
Make this entire function prettier
|
Make this entire function prettier
|
||||||
*/
|
*/
|
||||||
let helmet = document.getElementById("helmet-choice").value;
|
let helmet = getValue("helmet-choice");
|
||||||
let chestplate = document.getElementById("chestplate-choice").value;
|
let chestplate = getValue("chestplate-choice");
|
||||||
let leggings = document.getElementById("leggings-choice").value;
|
let leggings = getValue("leggings-choice");
|
||||||
let boots = document.getElementById("boots-choice").value;
|
let boots = getValue("boots-choice");
|
||||||
let ring1 = document.getElementById("ring1-choice").value;
|
let ring1 = getValue("ring1-choice");
|
||||||
let ring2 = document.getElementById("ring2-choice").value;
|
let ring2 = getValue("ring2-choice");
|
||||||
let bracelet = document.getElementById("bracelet-choice").value;
|
let bracelet = getValue("bracelet-choice");
|
||||||
let necklace = document.getElementById("necklace-choice").value;
|
let necklace = getValue("necklace-choice");
|
||||||
let weapon = document.getElementById("weapon-choice").value;
|
let weapon = getValue("weapon-choice");
|
||||||
if(helmet===""){
|
if(helmet===""){
|
||||||
helmet = "No Helmet";
|
helmet = "No Helmet";
|
||||||
}
|
}
|
||||||
|
@ -250,6 +333,19 @@ function calculateBuild(){
|
||||||
if(weapon===""){
|
if(weapon===""){
|
||||||
weapon = "No Weapon";
|
weapon = "No Weapon";
|
||||||
}
|
}
|
||||||
|
let powderings = [];
|
||||||
|
for (const i in powderInputs) {
|
||||||
|
// read in two characters at a time.
|
||||||
|
// TODO: make this more robust.
|
||||||
|
let input = getValue(powderInputs[i]);
|
||||||
|
let powdering = [];
|
||||||
|
while (input) {
|
||||||
|
let first = input.slice(0, 2);
|
||||||
|
powdering.push(powderIDs.get(first));
|
||||||
|
input = input.slice(2);
|
||||||
|
}
|
||||||
|
powderings.push(powdering);
|
||||||
|
}
|
||||||
player_build = new Build(
|
player_build = new Build(
|
||||||
106,
|
106,
|
||||||
itemMap.get(helmet),
|
itemMap.get(helmet),
|
||||||
|
@ -261,6 +357,7 @@ function calculateBuild(){
|
||||||
itemMap.get(bracelet),
|
itemMap.get(bracelet),
|
||||||
itemMap.get(necklace),
|
itemMap.get(necklace),
|
||||||
itemMap.get(weapon),
|
itemMap.get(weapon),
|
||||||
|
powderings
|
||||||
);
|
);
|
||||||
console.log(player_build.toString());
|
console.log(player_build.toString());
|
||||||
|
|
||||||
|
@ -288,7 +385,6 @@ function calculateBuild(){
|
||||||
setText("int-skp-base", "Original Value: " + skillpoints[2]);
|
setText("int-skp-base", "Original Value: " + skillpoints[2]);
|
||||||
setText("def-skp-base", "Original Value: " + skillpoints[3]);
|
setText("def-skp-base", "Original Value: " + skillpoints[3]);
|
||||||
setText("agi-skp-base", "Original Value: " + skillpoints[4]);
|
setText("agi-skp-base", "Original Value: " + skillpoints[4]);
|
||||||
console.log(skillpoints);
|
|
||||||
|
|
||||||
setHTML("str-skp-pct", skillPointsToPercentage(skillpoints[0])*100 );
|
setHTML("str-skp-pct", skillPointsToPercentage(skillpoints[0])*100 );
|
||||||
setHTML("dex-skp-pct", skillPointsToPercentage(skillpoints[1])*100 );
|
setHTML("dex-skp-pct", skillPointsToPercentage(skillpoints[1])*100 );
|
||||||
|
@ -307,8 +403,23 @@ function calculateBuild(){
|
||||||
displayExpandedItem(expandItem(player_build.bracelet), "build-bracelet");
|
displayExpandedItem(expandItem(player_build.bracelet), "build-bracelet");
|
||||||
displayExpandedItem(expandItem(player_build.necklace), "build-necklace");
|
displayExpandedItem(expandItem(player_build.necklace), "build-necklace");
|
||||||
displayExpandedItem(expandItem(player_build.weapon), "build-weapon");
|
displayExpandedItem(expandItem(player_build.weapon), "build-weapon");
|
||||||
|
|
||||||
|
calculateBuildStats();
|
||||||
|
}
|
||||||
|
|
||||||
|
function calculateBuildStats() {
|
||||||
let meleeStats = player_build.getMeleeStats();
|
let meleeStats = player_build.getMeleeStats();
|
||||||
//nDamAdj,eDamAdj,tDamAdj,wDamAdj,fDamAdj,aDamAdj,totalDamNorm,totalDamCrit,normDPS,critDPS,avgDPS
|
//nDamAdj,eDamAdj,tDamAdj,wDamAdj,fDamAdj,aDamAdj,totalDamNorm,totalDamCrit,normDPS,critDPS,avgDPS
|
||||||
|
for (let i = 0; i < 6; ++i) {
|
||||||
|
for (let j in meleeStats[i]) {
|
||||||
|
meleeStats[i][j] = Math.round(meleeStats[i][j]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (let i = 6; i < 8; ++i) {
|
||||||
|
for (let j in meleeStats[i]) {
|
||||||
|
meleeStats[i][j] = Math.round(meleeStats[i][j]);
|
||||||
|
}
|
||||||
|
}
|
||||||
let meleeSummary = "";
|
let meleeSummary = "";
|
||||||
meleeSummary = meleeSummary.concat("<h1><u>Melee Stats</u></h1>");
|
meleeSummary = meleeSummary.concat("<h1><u>Melee Stats</u></h1>");
|
||||||
meleeSummary = meleeSummary.concat("<h2>Average DPS: ",Math.round(meleeStats[10]),"</h2> <br><br>");
|
meleeSummary = meleeSummary.concat("<h2>Average DPS: ",Math.round(meleeStats[10]),"</h2> <br><br>");
|
||||||
|
|
4
utils.js
4
utils.js
|
@ -36,6 +36,10 @@ function setValue(id, value) {
|
||||||
el.dispatchEvent(new Event("change"));
|
el.dispatchEvent(new Event("change"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getValue(id) {
|
||||||
|
return document.getElementById(id).value;
|
||||||
|
}
|
||||||
|
|
||||||
// Base 64 encoding tools
|
// Base 64 encoding tools
|
||||||
// https://stackoverflow.com/a/27696695
|
// https://stackoverflow.com/a/27696695
|
||||||
// Modified for fixed precision
|
// Modified for fixed precision
|
||||||
|
|
Loading…
Add table
Reference in a new issue