results.js 21 KB

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