-
Notifications
You must be signed in to change notification settings - Fork 10
/
script.js
144 lines (109 loc) · 3.74 KB
/
script.js
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
// helper functions
function randint(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}
function move(image, x, y) {
image.style.left = x;
image.style.top = y;
}
function getDimensions(image) {
// get the dimensions from the width and height attributes
let width = image.getAttribute("width");
let height = image.getAttribute("height");
if (width != null && height != null) {
return [parseInt(width), parseInt(height)];
}
// get the dimensions from the viewbox if the width and height are not set
let viewbox = image.getAttribute("viewBox");
if (viewbox == null) {
return [300, 150]; // default dimensions for SVG
}
viewbox = viewbox.split(" ");
width = parseInt(viewbox[2]);
height = parseInt(viewbox[3]);
return [width, height];
}
function changeDirection(index, value) {
direction[index] = value;
// check if color randomization is enabled and if the direction changed
if (randomizeColor) {
logo.style.fill = `rgb(${randint(0, 255)}, ${randint(0, 255)}, ${randint(0, 255)})`;
}
}
function getLogoURL() {
// return the default logo if the parameter is not set
if (!params.has("logo")) {
return "/logos/default.svg"
}
return params.get("logo");
}
function getLogo(url) {
// get the SVG logo from the URL
const request = new XMLHttpRequest();
const parser = new DOMParser();
request.open("GET", url, false);
request.send(null);
// if the request failed, return the default logo
if (request.status != 200) {
return getLogo("/logos/default.svg");
}
let image = parser.parseFromString(request.responseText, "text/html");
// if the image is not an SVG, return the default logo
if (image.querySelector("parsererror")) {
return getLogo("/logos/default.svg");
}
image = image.querySelector("svg");
// if the image is null, return the default logo
if (image == null) {
return getLogo("/logos/default.svg");
}
// filter any color attributes from the SVG
for (const attribute of ["fill", "style"]) {
for (const element of image.querySelectorAll(`[${attribute}]`)) {
element.removeAttribute(attribute);
}
}
return image;
}
// constants
const params = new URLSearchParams(window.location.search);
const logo = getLogo(getLogoURL());
const dimensions = getDimensions(logo);
const initialColor = params.get("initialColor") || "white";
let randomizeColor = true;
// don't randomize the color if the parameter is set to false
if (params.has("randomizeColor") && params.get("randomizeColor") in ["false", "0"]) {
randomizeColor = false;
}
const speed = params.get("speed") || 1.0;
// variables
let x = randint(1, window.innerWidth - dimensions[0] - 1);
let y = randint(1, window.innerHeight - dimensions[1] - 1);
let direction = [1, 1];
// set the ID and the fill color to the logo
logo.id = "logo";
logo.style.fill = initialColor;
// add the logo to the page
document.body.append(logo);
// move the logo to the randomized initial position
move(logo, x, y);
// main loop
setInterval(() => {
// change the coords based on the direction & speed
x += speed * direction[0];
y += speed * direction[1];
// check if logo is bouncing on the left/right side
if (x <= 1) {
changeDirection(0, 1);
} else if (x + dimensions[0] + 1 >= window.innerWidth) {
changeDirection(0, -1);
}
// check if logo is bouncing on the top/bottom side
if (y <= 1) {
changeDirection(1, 1);
} else if (y + dimensions[1] + 1 >= window.innerHeight) {
changeDirection(1, -1);
}
// move the logo to the current X and Y coords
move(logo, x, y);
});