summaryrefslogtreecommitdiffhomepage
path: root/js/main.js
blob: 3fa2566769aed3c0b08a91c2ac24ac668e6594e9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
Reveal.initialize({
  controls: false,
  math: {
    mathjax: 'node_modules/mathjax/MathJax.js',
    config: 'TeX-AMS_HTML-full',
    // pass other options into `MathJax.Hub.Config()`
    TeX: {Macros: {RR: "{\\bf R}"}}
  },

  hash: true,
  dependencies: [
    {src: 'plugin/markdown/marked.js'},
    {src: 'plugin/markdown/markdown.js'},
    {src: 'plugin/highlight/highlight.js'},
    {src: 'plugin/math/math.js', async: true},
    {src: 'plugin/notes/notes.js', async: true}
  ]
});


/******************
 * KOCH ANIMATION *
 ******************/
const canvas = document.getElementById("koch");
const ctr = document.getElementById("iterationCtr");
const ctx = canvas.getContext("2d");

canvas.width = window.innerWidth * 0.9;
canvas.height = window.innerHeight * 0.9;
const cx = canvas.width / 2;
const cy = canvas.height / 2;
ctx.translate(cx, cy);
ctx.fillStyle = "#191919";
ctx.lineWidth = 4;
ctx.fillRect(-cx, -cy, 2 * cx, 2 * cy);
ctx.strokeStyle = "white";
koch([-cx, 100], [cx, 100], 0);

window.onkeyup = event => {
  switch (event.key) {
    case "1":
    case "2":
    case "3":
    case "4":
    case "5":
    case "6":
    case "7":
      ctr.innerText = event.key;
      ctx.fillRect(-cx, -cy, 2 * cx, 2 * cy);
      koch([-cx, 100], [cx, 100], Number(event.key) - 1);
  }
};

// Recursion!
function koch(start, end, iteration) {
  const x1 = (end[0] - start[0]) / 3 + start[0];
  const y1 = (end[1] - start[1]) / 3 + start[1];
  const x2 = (end[0] - start[0]) * 2 / 3 + start[0];
  const y2 = (end[1] - start[1]) * 2 / 3 + start[1];
  const x3 = ((x1 + x2) + Math.sqrt(3) * (-y1 + y2)) / 2;
  const y3 = ((y1 + y2) + Math.sqrt(3) * (x1 - x2)) / 2;

  ctx.beginPath();

  ctx.moveTo(start[0], start[1]);
  ctx.lineTo(x1, y1);
  ctx.moveTo(x2, y2);
  ctx.lineTo(end[0], end[1]);

  ctx.moveTo(x1, y1);
  ctx.lineTo(x3, y3);
  ctx.moveTo(x2, y2);
  ctx.lineTo(x3, y3);
  ctx.closePath();
  ctx.stroke();

  ctx.strokeStyle = "#191919";
  ctx.beginPath();
  ctx.moveTo(x1, y1);
  ctx.lineTo(x2, y2);
  ctx.closePath();
  ctx.stroke();
  ctx.strokeStyle = "white";

  if (iteration > 0) {
    koch([start[0], start[1]], [x1, y1], iteration - 1);
    koch([x1, y1], [x3, y3], iteration - 1);
    koch([x3, y3], [x2, y2], iteration - 1);
    koch([x2, y2], [end[0], end[1]], iteration - 1);
  }
}