results.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830
  1. "use strict";
  2. var urlToCopy = document.getElementById("urlToCopy");
  3. if (urlToCopy) {
  4. urlToCopy.innerHTML = location.href;
  5. }
  6. function shareLink() {
  7. var urlToCopy = document.getElementById("urlToCopy");
  8. var urlToCopyContainer = document.getElementById("urlToCopyContainer");
  9. try {
  10. if (document.body.createTextRange) {
  11. // for Internet Explorer
  12. var range = document.body.createTextRange();
  13. range.moveToElementText(urlToCopy);
  14. range.select();
  15. document.execCommand("Copy");
  16. } else if (window.getSelection) {
  17. // other browsers
  18. var selection = window.getSelection();
  19. var range = document.createRange();
  20. range.selectNodeContents(urlToCopy);
  21. selection.removeAllRanges();
  22. selection.addRange(range);
  23. document.execCommand("Copy");
  24. }
  25. var button = document.getElementById("buttonLink");
  26. if (button) {
  27. button.className = "button buttonLinkGood";
  28. setTimeout(function() {
  29. var buttonTimeout = document.getElementById("buttonLink");
  30. if (buttonTimeout) button.className = "button buttonLink";
  31. }, 2000);
  32. }
  33. } catch (err) {}
  34. }
  35. function getQueryVariable(variable) {
  36. var query = window.atob(window.location.search.substring(1));
  37. var vars = query.split("&");
  38. for (var i = 0; i < vars.length; i++) {
  39. var pair = vars[i].split("=");
  40. if (pair[0] == variable) {
  41. if (pair[1] == "NaN") {
  42. return 0;
  43. } else {
  44. return pair[1] / 100;
  45. }
  46. }
  47. }
  48. return 0;
  49. }
  50. function setAxisValue(name, value) {
  51. var axis = document.getElementById(name);
  52. if (!axis) return;
  53. var text = document.getElementById(name + "Text");
  54. if (!text) return;
  55. axis.style.width = (100 * value).toFixed(1) + "%";
  56. text.innerHTML = (100 * value).toFixed(0) + "%";
  57. if (text.offsetWidth > axis.offsetWidth - 5) text.style.display = "none";
  58. else text.style.display = "";
  59. }
  60. function setBonus(name, value, limit) {
  61. var axis = document.getElementById(name);
  62. if (!axis) return;
  63. if (value > limit) {
  64. axis.style.display = "flex";
  65. axis.style.opacity = value * value;
  66. } else {
  67. axis.style.display = "none";
  68. }
  69. }
  70. var axes = ["c", "b", "p", "m", "s", "j", "e", "t"];
  71. var bonus = {
  72. anar: 0.9,
  73. prag: 0.5,
  74. femi: 0.9,
  75. comp: 0.9,
  76. vega: 0.5,
  77. reli: 0.5,
  78. mona: 0.5
  79. };
  80. var characteristics = [];
  81. var axesValues = {
  82. c: 0,
  83. b: 0,
  84. p: 0,
  85. m: 0,
  86. s: 0,
  87. j: 0,
  88. e: 0,
  89. t: 0
  90. };
  91. for (var i = 0; i < axes.length; i++) {
  92. var negativeValue = getQueryVariable(axes[i] + "0");
  93. var positiveValue = getQueryVariable(axes[i] + "1");
  94. setAxisValue(axes[i] + "AxisNeg", negativeValue);
  95. setAxisValue(axes[i] + "AxisPos", positiveValue);
  96. setAxisValue(axes[i] + "AxisMid", 1 - negativeValue - positiveValue);
  97. if (negativeValue > positiveValue) {
  98. characteristics.push({ name: axes[i] + "0", value: negativeValue });
  99. } else {
  100. characteristics.push({ name: axes[i] + "1", value: positiveValue });
  101. }
  102. axesValues[axes[i]] = positiveValue - negativeValue;
  103. }
  104. var bonusEnabled = 0;
  105. for (var b in bonus) {
  106. var value = getQueryVariable(b);
  107. setBonus(b + "Bonus", value, bonus[b]);
  108. if (value > bonus[b]) {
  109. bonusEnabled = 1;
  110. characteristics.push({ name: b, value: value });
  111. }
  112. }
  113. characteristics.sort(function(a, b) {
  114. return a.value < b.value;
  115. });
  116. var charSlogan = {
  117. b0: "Humanity",
  118. b1: "Fatherland",
  119. c0: "Equality",
  120. e0: "Ecology",
  121. j0: "Justice",
  122. j1: "Order",
  123. m1: "Liberty",
  124. p0: "Socialism",
  125. p1: "Work",
  126. s1: "Family",
  127. t0: "Revolution"
  128. };
  129. function findFlagColors() {
  130. var colors = [];
  131. for (var i = 0; i < flagColors.length; i++) {
  132. var accepted = 1;
  133. var mainValue = 0;
  134. var mainValueFound = 0;
  135. for (var j = 0; j < flagColors[i].cond.length; j++) {
  136. var charFound = 0;
  137. for (var k = 0; k < characteristics.length; k++) {
  138. if (characteristics[k].name == flagColors[i].cond[j].name) {
  139. charFound = 1;
  140. if (
  141. characteristics[k].value < flagColors[i].cond[j].vmin ||
  142. characteristics[k].value > flagColors[i].cond[j].vmax
  143. )
  144. accepted = 0;
  145. else if (!mainValueFound) {
  146. mainValueFound = 1;
  147. mainValue = characteristics[k].value;
  148. }
  149. break;
  150. }
  151. }
  152. if (!charFound) accepted = 0;
  153. if (!accepted) break;
  154. }
  155. if (accepted) {
  156. colors.push({
  157. bgColor: flagColors[i].bgColor,
  158. fgColor: flagColors[i].fgColor,
  159. value: mainValue
  160. });
  161. }
  162. }
  163. colors.sort(function(a, b) {
  164. return b.value - a.value;
  165. });
  166. return colors;
  167. }
  168. function findFlagShape(numColors) {
  169. var flagFound = -1;
  170. var flagValue = [0, 0, 0];
  171. var flagColor = 0;
  172. for (var i = 0; i < flagShapes.length; i++) {
  173. if (flagShapes[i].numColors > numColors) continue;
  174. var condValue = [0, 0];
  175. var accepted = 1;
  176. if (flagShapes[i].cond.length > 0) {
  177. for (var j = 0; j < flagShapes[i].cond.length; j++) {
  178. var value = axesValues[flagShapes[i].cond[j].name];
  179. if (
  180. value < flagShapes[i].cond[j].vmin ||
  181. value > flagShapes[i].cond[j].vmax
  182. ) {
  183. accepted = 0;
  184. }
  185. if (j < 3) condValue[j] = Math.abs(value);
  186. if (!accepted) break;
  187. }
  188. } else {
  189. var condValue = [0, 0];
  190. }
  191. if (accepted && flagColor <= flagShapes[i].numColors) {
  192. if (flagShapes[i].numColors > flagColor) {
  193. flagColor = flagShapes[i].numColors;
  194. flagValue[0] = condValue[0];
  195. flagValue[1] = condValue[1];
  196. flagValue[2] = condValue[2];
  197. flagFound = i;
  198. } else if (condValue[0] > flagValue[0]) {
  199. flagColor = flagShapes[i].numColors;
  200. flagValue[0] = condValue[0];
  201. flagValue[1] = condValue[1];
  202. flagValue[2] = condValue[2];
  203. flagFound = i;
  204. } else if (condValue[0] == flagValue[0]) {
  205. if (condValue[1] > flagValue[1]) {
  206. flagColor = flagShapes[i].numColors;
  207. flagValue[0] = condValue[0];
  208. flagValue[1] = condValue[1];
  209. flagValue[2] = condValue[2];
  210. flagFound = i;
  211. } else if (condValue[1] == flagValue[1]) {
  212. if (condValue[2] > flagValue[2]) {
  213. flagColor = flagShapes[i].numColors;
  214. flagValue[0] = condValue[0];
  215. flagValue[1] = condValue[1];
  216. flagValue[2] = condValue[2];
  217. flagFound = i;
  218. }
  219. }
  220. }
  221. }
  222. }
  223. return flagFound;
  224. }
  225. function getCharacteristic(name, vmin, vmax) {
  226. for (var k = 0; k < characteristics.length; k++) {
  227. if (characteristics[k].name != name) continue;
  228. if (characteristics[k].value >= vmin && characteristics[k].value <= vmax)
  229. return characteristics[k].value;
  230. else return -1.0;
  231. }
  232. return -1.0;
  233. }
  234. function findFlagSymbol(numColors) {
  235. var symbol0 = {
  236. parent_type: "none",
  237. transform: {}
  238. };
  239. var symbol1 = {
  240. parent_type: "none",
  241. transform: {}
  242. };
  243. var valueMax = 0;
  244. if (numColors == 0) {
  245. symbol0.parent_type = "dot";
  246. symbol0.transform = {
  247. child_type: "none",
  248. x: 3,
  249. y: 3,
  250. main: true,
  251. parent_tx: 0,
  252. parent_ty: 0,
  253. parent_sx: 1,
  254. parent_sy: 1,
  255. parent_r: 0,
  256. child_tx: 0,
  257. child_ty: 0,
  258. child_sx: 1,
  259. child_sy: 1,
  260. child_r: 0
  261. };
  262. }
  263. for (var s0 = 0; s0 < flagSymbols.length; s0++) {
  264. var charVal0 = getCharacteristic(
  265. flagSymbols[s0].cond.name,
  266. flagSymbols[s0].cond.vmin,
  267. flagSymbols[s0].cond.vmax
  268. );
  269. if (charVal0 > 0) {
  270. var value = charVal0 * 1.5;
  271. var transform0 = -1;
  272. if (value > valueMax) {
  273. for (k0 = 0; k0 < flagSymbols[s0].data.transforms.length; k0++) {
  274. if (flagSymbols[s0].data.transforms[k0].child_type == "none") {
  275. transform0 = k0;
  276. }
  277. }
  278. if (transform0 >= 0) {
  279. symbol0.parent_type = flagSymbols[s0].data.parent_type;
  280. symbol0.transform = flagSymbols[s0].data.transforms[transform0];
  281. symbol1.parent_type = "none";
  282. valueMax = value;
  283. }
  284. }
  285. for (var s1 = s0 + 1; s1 < flagSymbols.length; s1++) {
  286. transform0 = -1;
  287. var transform1 = -1;
  288. var k0 = -1;
  289. for (k0 = 0; k0 < flagSymbols[s0].data.transforms.length; k0++) {
  290. for (var k1 = 0; k1 < flagSymbols[s1].data.transforms.length; k1++) {
  291. if (
  292. flagSymbols[s0].data.parent_type ==
  293. flagSymbols[s1].data.transforms[k1].child_type &&
  294. flagSymbols[s1].data.parent_type ==
  295. flagSymbols[s0].data.transforms[k0].child_type
  296. ) {
  297. transform0 = k0;
  298. transform1 = k1;
  299. }
  300. }
  301. }
  302. if (transform1 < 0 || transform0 < 0) continue;
  303. var charVal1 = getCharacteristic(
  304. flagSymbols[s1].cond.name,
  305. flagSymbols[s1].cond.vmin,
  306. flagSymbols[s1].cond.vmax
  307. );
  308. if (charVal1 > 0) {
  309. value = charVal0 + charVal1;
  310. if (value > valueMax) {
  311. symbol0.parent_type = flagSymbols[s0].data.parent_type;
  312. symbol0.transform = flagSymbols[s0].data.transforms[transform0];
  313. symbol1.parent_type = flagSymbols[s1].data.parent_type;
  314. symbol1.transform = flagSymbols[s1].data.transforms[transform1];
  315. valueMax = value;
  316. }
  317. }
  318. }
  319. }
  320. }
  321. if (
  322. symbol0.parent_type != "none" &&
  323. symbol1.parent_type != "none" &&
  324. symbol1.transform.main &&
  325. !symbol0.transform.main
  326. )
  327. return [symbol1, symbol0];
  328. else return [symbol0, symbol1];
  329. }
  330. var generatedSlogan = "";
  331. var sloganDiv = document.getElementById("slogan");
  332. if (sloganDiv) {
  333. var selectedSlogan = [];
  334. for (var i = 0; i < characteristics.length; i++) {
  335. if (
  336. characteristics[i].value > 0 &&
  337. charSlogan.hasOwnProperty(characteristics[i].name)
  338. ) {
  339. selectedSlogan.push({
  340. text: charSlogan[characteristics[i].name],
  341. value: characteristics[i].value
  342. });
  343. }
  344. }
  345. selectedSlogan.sort(function(a, b) {
  346. return a.value < b.value;
  347. });
  348. var counter = 0;
  349. for (var i = 0; i < selectedSlogan.length; i++) {
  350. if (generatedSlogan != "") generatedSlogan += " · ";
  351. generatedSlogan += selectedSlogan[i].text;
  352. counter++;
  353. if (counter >= 3) break;
  354. }
  355. sloganDiv.innerHTML = generatedSlogan;
  356. }
  357. if (!bonusEnabled) {
  358. var bonusBox = document.getElementById("bonusBox");
  359. bonusBox.style.display = "none";
  360. }
  361. var images = {
  362. sprites: "/images/flag_sprites.png",
  363. c0: "/images/constructivism_small.png",
  364. c1: "/images/essentialism_small.png",
  365. j0: "/images/justice_soft_small.png",
  366. j1: "/images/justice_hard_small.png",
  367. s0: "/images/progressism_small.png",
  368. s1: "/images/conservatism_small.png",
  369. b0: "/images/internationalism_small.png",
  370. b1: "/images/nationalism_small.png",
  371. p0: "/images/communism_small.png",
  372. p1: "/images/capitalism_small.png",
  373. m0: "/images/regulation_small.png",
  374. m1: "/images/laissezfaire_small.png",
  375. e0: "/images/ecology_small.png",
  376. e1: "/images/productivism_small.png",
  377. t0: "/images/revolution_small.png",
  378. t1: "/images/reformism_small.png",
  379. anar: "/images/anarchism_small.png",
  380. prag: "/images/pragmatism_small.png",
  381. femi: "/images/feminism_small.png",
  382. comp: "/images/complotism_small.png",
  383. vega: "/images/veganism_small.png",
  384. mona: "/images/monarchism_small.png",
  385. reli: "/images/religion_small.png"
  386. };
  387. var numImageLoaded = 0;
  388. function onImageLoaded() {
  389. numImageLoaded++;
  390. if (numImageLoaded < images.length) {
  391. return;
  392. }
  393. var flag = document.getElementById("generatedFlag");
  394. if (flag) {
  395. var ctx = flag.getContext("2d");
  396. var spriteX = 256;
  397. var spriteY = 128;
  398. var spriteS = 1.0;
  399. var colors = findFlagColors();
  400. var symbolData = findFlagSymbol(colors.length);
  401. var flagId = findFlagShape(colors.length);
  402. if (colors.length <= 0)
  403. colors.push({ bgColor: "#ffffff", fgColor: "#000000" });
  404. if (flagId < 0) {
  405. ctx.beginPath();
  406. ctx.rect(0, 0, 512, 256);
  407. ctx.fillStyle = "#ffffff";
  408. ctx.fill();
  409. } else {
  410. for (var i = 0; i < flagShapes[flagId].shapes.length; i++) {
  411. var path = flagShapes[flagId].shapes[i];
  412. var numPoints = path.length / 2;
  413. ctx.beginPath();
  414. ctx.moveTo(path[1] * 512, path[2] * 256);
  415. if (path[1] == "circle") {
  416. ctx.arc(
  417. path[2] * 512,
  418. path[3] * 256,
  419. path[4] * 256,
  420. 0,
  421. 2 * Math.PI,
  422. false
  423. );
  424. } else if (
  425. path[1] == "circleSymbol" &&
  426. symbolData[0].parent_type != "none"
  427. ) {
  428. ctx.arc(
  429. path[2] * 512,
  430. path[3] * 256,
  431. path[4] * 256,
  432. 0,
  433. 2 * Math.PI,
  434. false
  435. );
  436. } else {
  437. for (var j = 1; j < numPoints; j++) {
  438. ctx.lineTo(path[1 + j * 2 + 0] * 512, path[1 + j * 2 + 1] * 256);
  439. }
  440. }
  441. ctx.fillStyle = colors[path[0]].bgColor;
  442. ctx.fill();
  443. }
  444. spriteX = flagShapes[flagId].symbol[0] * 512;
  445. spriteY = flagShapes[flagId].symbol[1] * 256;
  446. spriteS = flagShapes[flagId].symbol[2];
  447. }
  448. if (symbolData[0].parent_type != "none") {
  449. var tmpC = document.createElement("canvas");
  450. tmpC.width = images["sprites"].width;
  451. tmpC.height = images["sprites"].height;
  452. var tmpCtx = tmpC.getContext("2d");
  453. var coloredSprites = tmpCtx.getImageData(0, 0, tmpC.width, tmpC.height);
  454. tmpCtx.beginPath();
  455. tmpCtx.rect(0, 0, tmpC.width, tmpC.height);
  456. tmpCtx.fillStyle = colors[0].fgColor;
  457. tmpCtx.fill();
  458. tmpCtx.globalCompositeOperation = "destination-in";
  459. tmpCtx.drawImage(images["sprites"], 0, 0);
  460. ctx.save();
  461. ctx.translate(spriteX, spriteY);
  462. ctx.scale(spriteS, spriteS);
  463. var sx = symbolData[0].transform.x;
  464. var sy = symbolData[0].transform.y;
  465. ctx.save();
  466. ctx.translate(
  467. symbolData[0].transform.parent_tx,
  468. -symbolData[0].transform.parent_ty
  469. );
  470. ctx.rotate((symbolData[0].transform.parent_r * Math.PI) / 180);
  471. ctx.scale(
  472. symbolData[0].transform.parent_sx,
  473. symbolData[0].transform.parent_sy
  474. );
  475. ctx.drawImage(tmpC, sx * 128, sy * 128, 128, 128, -64, -64, 128, 128);
  476. ctx.restore();
  477. if (symbolData[1].parent_type != "none") {
  478. var sx = symbolData[1].transform.x;
  479. var sy = symbolData[1].transform.y;
  480. ctx.translate(
  481. symbolData[0].transform.child_tx,
  482. -symbolData[0].transform.child_ty
  483. );
  484. ctx.rotate((symbolData[0].transform.child_r * Math.PI) / 180);
  485. ctx.scale(
  486. symbolData[0].transform.child_sx,
  487. symbolData[0].transform.child_sy
  488. );
  489. ctx.translate(
  490. symbolData[1].transform.parent_tx,
  491. -symbolData[1].transform.parent_ty
  492. );
  493. ctx.rotate((symbolData[1].transform.parent_r * Math.PI) / 180);
  494. ctx.scale(
  495. symbolData[1].transform.parent_sx,
  496. symbolData[1].transform.parent_sy
  497. );
  498. ctx.drawImage(tmpC, sx * 128, sy * 128, 128, 128, -64, -64, 128, 128);
  499. ctx.restore();
  500. }
  501. ctx.restore();
  502. }
  503. }
  504. var rPreview = document.getElementById("generatedResults");
  505. if (rPreview) {
  506. var ctx = rPreview.getContext("2d");
  507. ctx.beginPath();
  508. ctx.rect(0, 0, rPreview.width, rPreview.height);
  509. ctx.fillStyle = "#ebebeb";
  510. ctx.fill();
  511. var yPos = 20;
  512. if (flag) {
  513. var flagCtx = flag.getContext("2d");
  514. var flagSize = 160;
  515. //Logo
  516. ctx.beginPath();
  517. ctx.rect(0, 0, rPreview.width, 42);
  518. ctx.fillStyle = "#500076";
  519. ctx.fill();
  520. ctx.fillStyle = "#ffffff";
  521. ctx.font = "bold 25px sans-serif";
  522. ctx.textAlign = "left";
  523. ctx.fillText("P️olitiScales, DBHQ Edition", 10, 30);
  524. ctx.fillStyle = "#ffffff";
  525. ctx.font = "bold 15px sans-serif";
  526. ctx.textAlign = "right";
  527. ctx.fillText("DBHQ.github.io", rPreview.width - 10, 27);
  528. yPos += 48;
  529. //Flag
  530. ctx.drawImage(
  531. flag,
  532. 0,
  533. 0,
  534. flag.width,
  535. flag.height,
  536. rPreview.width / 2.0 - flagSize,
  537. yPos,
  538. flagSize * 2,
  539. flagSize
  540. );
  541. yPos += flagSize + 10;
  542. //Slogan
  543. ctx.fillStyle = "#000000";
  544. ctx.font = "25px sans-serif";
  545. ctx.textAlign = "center";
  546. ctx.fillText(generatedSlogan, rPreview.width / 2.0, yPos + 30);
  547. yPos += 70;
  548. //Axes
  549. var axesDrawInfo = [
  550. {
  551. key: "c",
  552. color0: "#a425b6",
  553. color1: "#34b634",
  554. name0: "Constructivism",
  555. name1: "Essentialism"
  556. },
  557. {
  558. key: "j",
  559. color0: "#14bee1",
  560. color1: "#e6cc27",
  561. name0: "Rehabilitative justice",
  562. name1: "Punitive justice"
  563. },
  564. {
  565. key: "s",
  566. color0: "#850083",
  567. color1: "#970000",
  568. name0: "Progressive",
  569. name1: "Conservative"
  570. },
  571. {
  572. key: "b",
  573. color0: "#3e6ffd",
  574. color1: "#ff8500",
  575. name0: "Internationalism",
  576. name1: "Nationalism"
  577. },
  578. {
  579. key: "p",
  580. color0: "#cc0000",
  581. color1: "#ffb800",
  582. name0: "Communism",
  583. name1: "Capitalism"
  584. },
  585. {
  586. key: "m",
  587. color0: "#269B32",
  588. color1: "#6608C0",
  589. name0: "Regulation",
  590. name1: "Laissez-faire"
  591. },
  592. {
  593. key: "e",
  594. color0: "#a0e90d",
  595. color1: "#4deae9",
  596. name0: "Ecology",
  597. name1: "Production"
  598. },
  599. {
  600. key: "t",
  601. color0: "#eb1a66",
  602. color1: "#0ee4c8",
  603. name0: "Revolution",
  604. name1: "Reform"
  605. }
  606. ];
  607. var axeMargin = 100;
  608. var axeWidth = rPreview.width - axeMargin * 2;
  609. ctx.strokeStyle = "#888888";
  610. for (var i = 0; i < axesDrawInfo.length; i++) {
  611. var negativeValue = getQueryVariable(axesDrawInfo[i]["key"] + "0");
  612. var positiveValue = getQueryVariable(axesDrawInfo[i]["key"] + "1");
  613. var neutralValue = 1 - negativeValue - positiveValue;
  614. var negSize = axeWidth * negativeValue;
  615. var posSize = axeWidth * positiveValue;
  616. var ntrSize = axeWidth * neutralValue;
  617. ctx.beginPath();
  618. ctx.rect(0.5 + axeMargin + negSize, 0.5 + yPos, ntrSize, 30);
  619. ctx.stroke();
  620. ctx.beginPath();
  621. ctx.rect(0.5 + axeMargin, 0.5 + yPos, negSize, 30);
  622. ctx.fillStyle = axesDrawInfo[i]["color0"];
  623. ctx.fill();
  624. ctx.stroke();
  625. ctx.beginPath();
  626. ctx.rect(
  627. 0.5 + rPreview.width - axeMargin - posSize,
  628. 0.5 + yPos,
  629. posSize,
  630. 30
  631. );
  632. ctx.fillStyle = axesDrawInfo[i]["color1"];
  633. ctx.fill();
  634. ctx.stroke();
  635. if (negSize > 40) {
  636. ctx.fillStyle = "#ffffff";
  637. ctx.font = "20px sans-serif";
  638. ctx.textAlign = "right";
  639. ctx.fillText(
  640. Math.round(negativeValue * 100) + "%",
  641. axeMargin + negSize - 5,
  642. yPos + 23
  643. );
  644. }
  645. if (posSize > 40) {
  646. ctx.fillStyle = "#ffffff";
  647. ctx.font = "20px sans-serif";
  648. ctx.textAlign = "left";
  649. ctx.fillText(
  650. Math.round(positiveValue * 100) + "%",
  651. axeMargin + negSize + ntrSize + 5,
  652. yPos + 23
  653. );
  654. }
  655. if (ntrSize > 40) {
  656. ctx.fillStyle = "#888888";
  657. ctx.font = "20px sans-serif";
  658. ctx.textAlign = "center";
  659. ctx.fillText(
  660. Math.round(neutralValue * 100) + "%",
  661. axeMargin + negSize + ntrSize / 2,
  662. yPos + 23
  663. );
  664. }
  665. ctx.drawImage(
  666. images[axesDrawInfo[i]["key"] + "0"],
  667. axeMargin - 73,
  668. yPos - 27
  669. );
  670. ctx.drawImage(
  671. images[axesDrawInfo[i]["key"] + "1"],
  672. rPreview.width - axeMargin + 73 - 86,
  673. yPos - 27
  674. );
  675. ctx.fillStyle = "#000000";
  676. ctx.font = "16px sans-serif";
  677. ctx.textAlign = "left";
  678. ctx.fillText(axesDrawInfo[i]["name0"], axeMargin + 8, yPos - 6);
  679. ctx.textAlign = "right";
  680. ctx.fillText(
  681. axesDrawInfo[i]["name1"],
  682. rPreview.width - axeMargin - 8,
  683. yPos - 6
  684. );
  685. yPos += 100;
  686. }
  687. var xShift = 0;
  688. var numBonus = 0;
  689. for (var b in bonus) {
  690. value = getQueryVariable(b);
  691. if (value > bonus[b]) {
  692. numBonus++;
  693. }
  694. }
  695. for (var b in bonus) {
  696. value = getQueryVariable(b);
  697. if (value > bonus[b]) {
  698. ctx.drawImage(
  699. images[b],
  700. rPreview.width / 2 - ((numBonus - 1) * 100) / 2 + xShift - 43,
  701. yPos - 27
  702. );
  703. xShift += 100;
  704. }
  705. }
  706. }
  707. }
  708. }
  709. for (var b in images) {
  710. var src = images[b];
  711. images[b] = new Image();
  712. images[b].src = src;
  713. images[b].onload = onImageLoaded;
  714. }
  715. function download_image() {
  716. var canvas = document.getElementById("generatedResults");
  717. var link = document.createElement("a");
  718. link.href = canvas.toDataURL();
  719. link.download = `PolitiScales_Results_${+new Date()}.png`;
  720. document.body.appendChild(link);
  721. link.click();
  722. document.body.removeChild(link);
  723. }