results.js 21 KB

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