mana symbol mapping + hybrid phyrexian

This commit is contained in:
Kyle
2022-01-29 09:40:54 -08:00
parent 3b73b61e44
commit ca8a7dece7
19 changed files with 38 additions and 21 deletions

View File

@@ -250,9 +250,12 @@ function dragOver(event, drag=true) {
}
}
//Mana Symbols
var manaSymbols = [];
loadManaSymbols(['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14', '15', '16', '17', '18', '19', '20', 'w', 'u', 'b', 'r', 'g', 'c', 'x', 'y', 'z', 't', 'untap', 'e', 's', 'oldtap', 'originaltap', 'purple']);
loadManaSymbols(['wu', 'wb', 'ub', 'ur', 'br', 'bg', 'rg', 'rw', 'gw', 'gu', '2w', '2u', '2b', '2r', '2g', 'wp', 'up', 'bp', 'rp', 'gp', 'p'], [1.2, 1.2]);
const mana = new Map();
// var manaSymbols = [];
loadManaSymbols(['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14', '15', '16', '17', '18', '19', '20',
'w', 'u', 'b', 'r', 'g', 'c', 'x', 'y', 'z', 't', 'untap', 'e', 's', 'oldtap', 'originaltap', 'purple']);
loadManaSymbols(['wu', 'wb', 'ub', 'ur', 'br', 'bg', 'rg', 'rw', 'gw', 'gu', '2w', '2u', '2b', '2r', '2g', 'wp', 'up', 'bp', 'rp', 'gp', 'p',
'wup', 'wbp', 'ubp', 'urp', 'brp', 'bgp', 'rgp', 'rwp', 'gwp', 'gup'], [1.2, 1.2]);
loadManaSymbols(['bar.png', 'whitebar.png']);
loadManaSymbols(['chaos'], [1.2, 1]);
loadManaSymbols(['planeswalker'], [0.6, 1.2]);
@@ -287,11 +290,15 @@ function loadManaSymbols(manaSymbolPaths, size = [1, 1]) {
manaSymbolPath += '.svg';
}
manaSymbol.image.src = fixUri(manaSymbolPath);
manaSymbols.push(manaSymbol);
mana.set(manaSymbol.name, manaSymbol);
// manaSymbols.push(manaSymbol);
});
}
function findManaSymbolIndex(string) {
return manaSymbols.findIndex(element => element.name == string);
return mana.get(key) || -1;
}
function getManaSymbol(key) {
return mana.get(key);
}
//FRAME TAB
function drawFrames() {
@@ -997,7 +1004,7 @@ function writeText(textObject, targetContext) {
newLineSpacing = textSize * -0.23;
textSize -= scaleHeight(0.0086);
}
lineContext.drawImage(manaSymbols[findManaSymbolIndex(barImageName)].image, canvasMargin + (textWidth - barWidth) / 2, canvasMargin + barDistance * textSize, barWidth, barHeight);
lineContext.drawImage(getManaSymbol(barImageName).image, canvasMargin + (textWidth - barWidth) / 2, canvasMargin + barDistance * textSize, barWidth, barHeight);
} else if (possibleCode == 'i') {
if (textFont == 'mplantin') {
textFontExtension = 'i';
@@ -1061,7 +1068,7 @@ function writeText(textObject, targetContext) {
lineContext.lineWidth = textOutlineWidth;
} else if (possibleCode.includes('upinline')) {
lineY -= parseInt(possibleCode.replace('upinline', '')) || 0;
} else if (possibleCode.includes('up') && possibleCode != 'up') {
} else if (possibleCode.substring(0, 2) == 'up' && possibleCode != 'up') {
currentY -= parseInt(possibleCode.replace('up', '')) || 0;
} else if (possibleCode.includes('down')) {
currentY += parseInt(possibleCode.replace('down', '')) || 0;
@@ -1090,7 +1097,7 @@ function writeText(textObject, targetContext) {
}
} else if (possibleCode == 'planechase') {
var planechaseHeight = textSize * 1.8;
lineContext.drawImage(manaSymbols[findManaSymbolIndex('chaos')].image, currentX + canvasMargin, canvasMargin, planechaseHeight * 1.2, planechaseHeight);
lineContext.drawImage(getManaSymbol('chaos').image, currentX + canvasMargin, canvasMargin, planechaseHeight * 1.2, planechaseHeight);
currentX += planechaseHeight * 1.3;
startingCurrentX += planechaseHeight * 1.3;
} else if (possibleCode == 'indent') {
@@ -1139,13 +1146,13 @@ function writeText(textObject, targetContext) {
} else if (possibleCode.includes('kerning')) {
lineCanvas.style.letterSpacing = possibleCode.replace('kerning', '') + 'px';
lineContext.font = lineContext.font; //necessary for the letterspacing update to be recognized
} else if (findManaSymbolIndex(possibleCode.replace('/', '')) > -1 || findManaSymbolIndex(possibleCode.replace('/', '').split('').reverse().join('')) > -1) {
} else if (getManaSymbol(possibleCode.replace('/', '')) != undefined || getManaSymbol(possibleCode.replace('/', '').split('').reverse().join('')) != undefined) {
possibleCode = possibleCode.replace('/', '')
var manaSymbol;
if (textObject.manaPrefix && (findManaSymbolIndex(textObject.manaPrefix + possibleCode) != -1 || findManaSymbolIndex(textObject.manaPrefix + possibleCode.split('').reverse().join('')) != -1)) {
manaSymbol = manaSymbols[findManaSymbolIndex(textObject.manaPrefix + possibleCode)] || manaSymbols[findManaSymbolIndex(textObject.manaPrefix + possibleCode.split('').reverse().join(''))];
if (textObject.manaPrefix && (getManaSymbol(textObject.manaPrefix + possibleCode) != undefined || getManaSymbol(textObject.manaPrefix + possibleCode.split('').reverse().join('')) != undefined)) {
manaSymbol = getManaSymbol(textObject.manaPrefix + possibleCode) || getManaSymbol(textObject.manaPrefix + possibleCode.split('').reverse().join(''));
} else {
manaSymbol = manaSymbols[findManaSymbolIndex(possibleCode)] || manaSymbols[findManaSymbolIndex(possibleCode.split('').reverse().join(''))];
manaSymbol = getManaSymbol(possibleCode) || getManaSymbol(possibleCode.split('').reverse().join(''));
}
var manaSymbolSpacing = textSize * 0.04 + textManaSpacing;
var manaSymbolWidth = manaSymbol.width * textSize * 0.78;
@@ -1189,7 +1196,7 @@ function writeText(textObject, targetContext) {
fakeShadowContext.clearRect(0, 0, fakeShadow.width, fakeShadow.height);
var backImage = null;
if (manaSymbol.backs) {
backImage = manaSymbols[findManaSymbolIndex('back' + Math.floor(Math.random() * manaSymbol.backs) + manaSymbol.back)].image;
backImage = getManaSymbol('back' + Math.floor(Math.random() * manaSymbol.backs) + manaSymbol.back).image;
}
if (textArcRadius > 0) {
if (manaSymbol.backs) {

View File

@@ -2,7 +2,7 @@
if (!card.manaSymbols.includes('/js/frames/manaSymbolsCartoony.js')) {
card.manaSymbols.push('/js/frames/manaSymbolsCartoony.js');
}
if (findManaSymbolIndex('cw') == -1) {
if (!mana.get('cw')) {
loadManaSymbols([
['cartoony/cw.png', 'cw', 4], ['cartoony/cu.png', 'cu', 4], ['cartoony/cb.png', 'cb', 4], ['cartoony/cr.png', 'cr', 4], ['cartoony/cg.png', 'cg', 4],
['cartoony/c0.png', 'cc', 15], ['cartoony/c1.png', 'cc', 15], ['cartoony/c2.png', 'cc', 15], ['cartoony/c3.png', 'cc', 15], ['cartoony/c4.png', 'cc', 15],

View File

@@ -2,6 +2,6 @@
if (!card.manaSymbols.includes('/js/frames/manaSymbolsFAB.js')) {
card.manaSymbols.push('/js/frames/manaSymbolsFAB.js');
}
if (findManaSymbolIndex('fab') == -1) {
if (!mana.get('fab')) {
loadManaSymbols(['fab/fabw', 'fab/fabu', 'fab/fabb', 'fab/fabr', 'fab/fabg']);
}

View File

@@ -2,6 +2,6 @@
if (!card.manaSymbols.includes('/js/frames/manaSymbolsFuture.js')) {
card.manaSymbols.push('/js/frames/manaSymbolsFuture.js');
}
if (findManaSymbolIndex('fw') == -1) {
if (!mana.get('fw')) {
loadManaSymbols(['future/fw.png', 'future/fu.png', 'future/fb.png', 'future/fr.png', 'future/fg.png', 'future/f0.png', 'future/f1.png', 'future/f2.png', 'future/f3.png', 'future/f4.png', 'future/f5.png', 'future/f6.png', 'future/f7.png', 'future/f8.png', 'future/f9.png', 'future/f10.png', 'future/f11.png', 'future/f12.png', 'future/f13.png', 'future/f14.png', 'future/f15.png', 'future/f16.png', 'future/f17.png', 'future/f18.png', 'future/f19.png', 'future/f20.png', 'future/fwu.png', 'future/fwb.png', 'future/fub.png', 'future/fur.png', 'future/fbr.png', 'future/fbg.png', 'future/frg.png', 'future/frw.png', 'future/fgw.png', 'future/fgu.png', 'future/fx.png']);
}

View File

@@ -2,6 +2,6 @@
if (!card.manaSymbols.includes('/js/frames/manaSymbolsM21.js')) {
card.manaSymbols.push('/js/frames/manaSymbolsM21.js');
}
if (findManaSymbolIndex('m21w') == -1) {
if (!mana.get('m21w')) {
loadManaSymbols(['m21/m21w.png', 'm21/m21u.png', 'm21/m21b.png', 'm21/m21r.png', 'm21/m21g.png', 'm21/m210.png', 'm21/m211.png', 'm21/m212.png', 'm21/m213.png', 'm21/m214.png', 'm21/m215.png', 'm21/m216.png', 'm21/m217.png', 'm21/m218.png', 'm21/m219.png', 'm21/m21x.png', 'm21/dark/dm21w.png', 'm21/dark/dm21u.png', 'm21/dark/dm21b.png', 'm21/dark/dm21r.png', 'm21/dark/dm21g.png', 'm21/dark/dm210.png', 'm21/dark/dm211.png', 'm21/dark/dm212.png', 'm21/dark/dm213.png', 'm21/dark/dm214.png', 'm21/dark/dm215.png', 'm21/dark/dm216.png', 'm21/dark/dm217.png', 'm21/dark/dm218.png', 'm21/dark/dm219.png', 'm21/dark/dm21x.png']);
}

View File

@@ -2,7 +2,7 @@
if (!card.manaSymbols.includes('/js/frames/manaSymbolsMysticalArchiveJP.js')) {
card.manaSymbols.push('/js/frames/manaSymbolsMysticalArchiveJP.js');
}
if (findManaSymbolIndex('majpw') == -1) {
if (!mana.get('majpw')) {
loadManaSymbols([
'majp/majpw', 'majp/majpu', 'majp/majpb', 'majp/majpr', 'majp/majpg',
'majp/majpc', 'majp/majpx', 'majp/majp0', 'majp/majp1',

View File

@@ -2,7 +2,7 @@
if (!card.manaSymbols.includes('/js/frames/manaSymbolsNeon.js')) {
card.manaSymbols.push('/js/frames/manaSymbolsNeon.js');
}
if (findManaSymbolIndex('neonw') == -1) {
if (!mana.get('neonw')) {
loadManaSymbols([
'neon/neonw', 'neon/neonu', 'neon/neonb', 'neon/neonr', 'neon/neong',
'neon/neonc', 'neon/neonx', 'neon/neon0', 'neon/neon1',

View File

@@ -2,7 +2,7 @@
if (!card.manaSymbols.includes('/js/frames/manaSymbolsOld.js')) {
card.manaSymbols.push('/js/frames/manaSymbolsOld.js');
}
if (findManaSymbolIndex('old') == -1) {
if (!mana.get('old')) {
loadManaSymbols([
'old/oldw', 'old/oldu', 'old/oldb', 'old/oldr', 'old/oldg',
]);

View File

@@ -2,7 +2,7 @@
if (!card.manaSymbols.includes('/js/frames/manaSymbolsOutline.js')) {
card.manaSymbols.push('/js/frames/manaSymbolsOutline.js');
}
if (findManaSymbolIndex('outlinew') == -1) {
if (!mana.get('outlinew')) {
loadManaSymbols([
'outline/outlinew', 'outline/outlineu', 'outline/outlineb', 'outline/outliner', 'outline/outlineg',
'outline/outlinec', 'outline/outlines', 'outline/outlinex', 'outline/outline0', 'outline/outline1',