Skip to content

Instantly share code, notes, and snippets.

@docwhat
Last active June 26, 2020 20:12
Show Gist options
  • Save docwhat/61dfa1a4c546b51d7ec4a8b38abccb74 to your computer and use it in GitHub Desktop.
Save docwhat/61dfa1a4c546b51d7ec4a8b38abccb74 to your computer and use it in GitHub Desktop.
HTML error single pages
<!DOCTYPE html>
<html>
<head>
<title>Canvas Asteroids</title>
<style>
* {
margin: 0;
}
canvas {
position: absolute;
width: 100%;
height: 100%;
background: #262626;
}
#info {
color: #fff;
font-family: "Lucida Sans Typewriter", "Lucida Console", Monaco,
"Bitstream Vera Sans Mono", monospace;
margin: 10px 10px 0;
padding: 8px;
background: #161616;
position: absolute;
z-index: 1;
}
#info h1 {
font-size: 18px;
}
#info p {
font-size: 11px;
}
#info a {
color: #ddd;
}
</style>
<script>
var Pool = (function () {
var e = {
_type: null,
_size: null,
_pointer: null,
_elements: null,
init: function (e, t) {
;(this._type = e),
(this._size = t),
(this._pointer = t),
(this._elements = [])
var n = 0,
i = this._size
for (n; n < i; ++n) this._elements[n] = this._type.create()
},
getElement: function () {
return this._pointer > 0 ? this._elements[--this._pointer] : null
},
disposeElement: function (e) {
this._elements[this._pointer++] = e
},
}
return {
create: function (t, n) {
var i = Object.create(e)
return i.init(t, n), i
},
}
})()
</script>
<script>
var Vec2D = (function () {
var t = {
_x: 1,
_y: 0,
getX: function () {
return this._x
},
setX: function (t) {
this._x = t
},
getY: function () {
return this._y
},
setY: function (t) {
this._y = t
},
setXY: function (t, n) {
;(this._x = t), (this._y = n)
},
getLength: function () {
return Math.sqrt(this._x * this._x + this._y * this._y)
},
setLength: function (t) {
var n = this.getAngle()
;(this._x = Math.cos(n) * t), (this._y = Math.sin(n) * t)
},
getAngle: function () {
return Math.atan2(this._y, this._x)
},
setAngle: function (t) {
var n = this.getLength()
;(this._x = Math.cos(t) * n), (this._y = Math.sin(t) * n)
},
add: function (t) {
;(this._x += t.getX()), (this._y += t.getY())
},
sub: function (t) {
;(this._x -= t.getX()), (this._y -= t.getY())
},
mul: function (t) {
;(this._x *= t), (this._y *= t)
},
div: function (t) {
;(this._x /= t), (this._y /= t)
},
}
return {
create: function (n, i) {
var s = Object.create(t)
return s.setXY(n, i), s
},
}
})()
</script>
<script>
var Particle = (function () {
var l = {
radius: null,
color: null,
lifeSpan: null,
fric: null,
pos: null,
vel: null,
blacklisted: null,
update: function () {
this.pos.add(this.vel),
this.vel.mul(this.fric),
(this.radius -= 0.1),
this.radius < 0.1 && (this.radius = 0.1),
this.lifeSpan-- < 0 && (this.blacklisted = !0)
},
reset: function () {
this.blacklisted = !1
},
}
return {
create: function () {
var i = Object.create(l)
return (
(i.radius = 2),
(i.color = "#FFF"),
(i.lifeSpan = 0),
(i.fric = 0.98),
(i.pos = Vec2D.create(0, 0)),
(i.vel = Vec2D.create(0, 0)),
(i.blacklisted = !1),
i
)
},
}
})()
</script>
<script>
var Bullet = (function () {
var e = {
radius: null,
color: null,
pos: null,
vel: null,
blacklisted: null,
update: function () {
this.pos.add(this.vel)
},
reset: function () {
this.blacklisted = !1
},
}
return {
create: function () {
var l = Object.create(e)
return (
(l.radius = 4),
(l.color = "#FFF"),
(l.pos = Vec2D.create(0, 0)),
(l.vel = Vec2D.create(0, 0)),
(l.blacklisted = !1),
l
)
},
}
})()
</script>
<script>
var Asteroid = (function () {
var l = {
radius: null,
color: null,
pos: null,
vel: null,
blacklisted: null,
type: null,
sides: null,
angle: null,
angleVel: null,
update: function () {
this.pos.add(this.vel), (this.angle += this.angleVel)
},
reset: function () {
this.blacklisted = !1
},
}
return {
create: function () {
var e = Object.create(l)
return (
(e.radius = 40),
(e.color = "#FF5900"),
(e.pos = Vec2D.create(0, 0)),
(e.vel = Vec2D.create(0, 0)),
(e.blacklisted = !1),
(e.type = "b"),
(e.sides = (2 * Math.random() + 7) >> 0),
(e.angle = 0),
(e.angleVel = 0.01 * (1 - 2 * Math.random())),
e
)
},
}
})()
</script>
<script>
var Ship = (function () {
var e = {
angle: null,
pos: null,
vel: null,
thrust: null,
ref: null,
bulletDelay: null,
idle: null,
radius: null,
update: function () {
this.vel.add(this.thrust),
this.pos.add(this.vel),
this.vel.getLength() > 5 && this.vel.setLength(5),
++this.bulletDelay,
this.idle &&
++this.idleDelay > 120 &&
((this.idleDelay = 0), (this.idle = !1), this.ref.resetGame())
},
shoot: function () {
this.bulletDelay > 8 &&
(this.ref.generateShot(), (this.bulletDelay = 0))
},
}
return {
create: function (l, t, i) {
var s = Object.create(e)
return (
(s.ref = i),
(s.angle = 0),
(s.pos = Vec2D.create(l, t)),
(s.vel = Vec2D.create(0, 0)),
(s.thrust = Vec2D.create(0, 0)),
(s.idle = !1),
(s.radius = 8),
(s.idleDelay = 0),
s
)
},
}
})()
</script>
<script>
function keyboardInit() {
;(window.onkeydown = function (e) {
switch (e.keyCode) {
case 65:
case 37:
keyLeft = !0
break
case 87:
case 38:
keyUp = !0
break
case 68:
case 39:
keyRight = !0
break
case 83:
case 40:
keyDown = !0
break
case 32:
keySpace = !0
}
e.preventDefault()
}),
(window.onkeyup = function (e) {
switch (e.keyCode) {
case 65:
case 37:
keyLeft = !1
break
case 87:
case 38:
keyUp = !1
break
case 68:
case 39:
keyRight = !1
break
case 83:
case 40:
keyDown = !1
break
case 32:
keySpace = !1
}
e.preventDefault()
})
}
function particleInit() {
;(particlePool = Pool.create(Particle, 100)), (particles = [])
}
function bulletInit() {
;(bulletPool = Pool.create(Bullet, 40)), (bullets = [])
}
function asteroidInit() {
;(asteroidPool = Pool.create(Asteroid, 30)), (asteroids = [])
}
function shipInit() {
ship = Ship.create(screenWidth >> 1, screenHeight >> 1, this)
}
function loop() {
updateShip(),
updateParticles(),
updateBullets(),
updateAsteroids(),
checkCollisions(),
render(),
getAnimationFrame(loop)
}
function updateShip() {
ship.update(),
ship.idle ||
(keySpace && ship.shoot(),
keyLeft && (ship.angle -= 0.1),
keyRight && (ship.angle += 0.1),
keyUp
? (ship.thrust.setLength(0.1),
ship.thrust.setAngle(ship.angle),
generateThrustParticle())
: (ship.vel.mul(0.94), ship.thrust.setLength(0)),
ship.pos.getX() > screenWidth
? ship.pos.setX(0)
: ship.pos.getX() < 0 && ship.pos.setX(screenWidth),
ship.pos.getY() > screenHeight
? ship.pos.setY(0)
: ship.pos.getY() < 0 && ship.pos.setY(screenHeight))
}
function generateThrustParticle() {
var e = particlePool.getElement()
e &&
((e.radius = 3 * Math.random() + 2),
(e.color = "#FFF"),
(e.lifeSpan = 80),
e.pos.setXY(
ship.pos.getX() + -14 * Math.cos(ship.angle),
ship.pos.getY() + -14 * Math.sin(ship.angle)
),
e.vel.setLength(8 / e.radius),
e.vel.setAngle(ship.angle + (1 - 2 * Math.random()) * (Math.PI / 18)),
e.vel.mul(-1),
(particles[particles.length] = e))
}
function updateParticles() {
var e = particles.length - 1
for (e; e > -1; --e) {
var t = particles[e]
t.blacklisted
? (t.reset(),
particles.splice(particles.indexOf(t), 1),
particlePool.disposeElement(t))
: t.update()
}
}
function updateBullets() {
var e = bullets.length - 1
for (e; e > -1; --e) {
var t = bullets[e]
t.blacklisted
? (t.reset(),
bullets.splice(bullets.indexOf(t), 1),
bulletPool.disposeElement(t))
: (t.update(),
t.pos.getX() > screenWidth
? (t.blacklisted = !0)
: t.pos.getX() < 0 && (t.blacklisted = !0),
t.pos.getY() > screenHeight
? (t.blacklisted = !0)
: t.pos.getY() < 0 && (t.blacklisted = !0))
}
}
function updateAsteroids() {
var e = asteroids.length - 1
for (e; e > -1; --e) {
var t = asteroids[e]
t.blacklisted
? (t.reset(),
asteroids.splice(asteroids.indexOf(t), 1),
asteroidPool.disposeElement(t))
: (t.update(),
t.pos.getX() > screenWidth + t.radius
? t.pos.setX(-t.radius)
: t.pos.getX() < -t.radius &&
t.pos.setX(screenWidth + t.radius),
t.pos.getY() > screenHeight + t.radius
? t.pos.setY(-t.radius)
: t.pos.getY() < -t.radius &&
t.pos.setY(screenHeight + t.radius))
}
if (asteroids.length < 5) {
var s = (2 * Math.random()) >> 0
generateAsteroid(screenWidth * s, screenHeight * s, 60, "b")
}
}
function generateAsteroid(e, t, s, o) {
var i = asteroidPool.getElement()
i &&
((i.radius = s),
(i.type = o),
i.pos.setXY(e, t),
i.vel.setLength(1 + asteroidVelFactor),
i.vel.setAngle(Math.random() * (2 * Math.PI)),
(asteroids[asteroids.length] = i),
(asteroidVelFactor += 0.025))
}
function checkCollisions() {
checkBulletAsteroidCollisions(), checkShipAsteroidCollisions()
}
function checkBulletAsteroidCollisions() {
var e,
t = bullets.length - 1
for (t; t > -1; --t)
for (e = asteroids.length - 1; e > -1; --e) {
var s = bullets[t],
o = asteroids[e]
checkDistanceCollision(s, o) &&
((s.blacklisted = !0), destroyAsteroid(o))
}
}
function checkShipAsteroidCollisions() {
var e = asteroids.length - 1
for (e; e > -1; --e) {
var t = asteroids[e],
s = ship
if (checkDistanceCollision(t, s)) {
if (s.idle) return
;(s.idle = !0), generateShipExplosion(), destroyAsteroid(t)
}
}
}
function generateShipExplosion() {
var e = 18
for (e; e > -1; --e) {
var t = particlePool.getElement()
if (!t) return
;(t.radius = 6 * Math.random() + 2),
(t.lifeSpan = 80),
(t.color = "#FFF"),
t.vel.setLength(20 / t.radius),
t.vel.setAngle(ship.angle + (1 - 2 * Math.random()) * doublePI),
t.pos.setXY(
ship.pos.getX() +
Math.cos(t.vel.getAngle()) * (0.8 * ship.radius),
ship.pos.getY() + Math.sin(t.vel.getAngle()) * (0.8 * ship.radius)
),
(particles[particles.length] = t)
}
}
function checkDistanceCollision(e, t) {
var s = e.pos.getX() - t.pos.getX(),
o = e.pos.getY() - t.pos.getY()
return Vec2D.create(s, o).getLength() < e.radius + t.radius
}
function destroyAsteroid(e) {
;(e.blacklisted = !0),
generateAsteroidExplosion(e),
resolveAsteroidType(e)
}
function generateAsteroidExplosion(e) {
var t = 18
for (t; t > -1; --t) {
var s = particlePool.getElement()
if (!s) return
;(s.radius = Math.random() * (e.radius >> 2) + 2),
(s.lifeSpan = 80),
(s.color = "#FF5900"),
s.vel.setLength(20 / s.radius),
s.vel.setAngle(ship.angle + (1 - 2 * Math.random()) * doublePI),
s.pos.setXY(
e.pos.getX() + Math.cos(s.vel.getAngle()) * (0.8 * e.radius),
e.pos.getY() + Math.sin(s.vel.getAngle()) * (0.8 * e.radius)
),
(particles[particles.length] = s)
}
}
function resolveAsteroidType(e) {
switch (e.type) {
case "b":
generateAsteroid(e.pos.getX(), e.pos.getY(), 40, "m"),
generateAsteroid(e.pos.getX(), e.pos.getY(), 40, "m")
break
case "m":
generateAsteroid(e.pos.getX(), e.pos.getY(), 20, "s"),
generateAsteroid(e.pos.getX(), e.pos.getY(), 20, "s")
}
}
function render() {
;(context.fillStyle = "#262626"),
(context.globalAlpha = 0.4),
context.fillRect(0, 0, screenWidth, screenHeight),
(context.globalAlpha = 1),
renderShip(),
renderParticles(),
renderBullets(),
renderAsteroids(),
renderScanlines()
}
function renderShip() {
ship.idle ||
(context.save(),
context.translate(ship.pos.getX() >> 0, ship.pos.getY() >> 0),
context.rotate(ship.angle),
(context.strokeStyle = "#FFF"),
(context.lineWidth = Math.random() > 0.9 ? 2 : 1),
context.beginPath(),
context.moveTo(10, 0),
context.lineTo(-10, -10),
context.lineTo(-10, 10),
context.lineTo(10, 0),
context.stroke(),
context.closePath(),
context.restore())
}
function renderParticles() {
var e = particles.length - 1
for (e; e > -1; --e) {
var t = particles[e]
context.beginPath(),
(context.strokeStyle = t.color),
context.arc(
t.pos.getX() >> 0,
t.pos.getY() >> 0,
t.radius,
0,
doublePI
),
Math.random() > 0.4 && context.stroke(),
context.closePath()
}
}
function renderBullets() {
var e = bullets.length - 1
for (e; e > -1; --e) {
var t = bullets[e]
context.beginPath(),
(context.strokeStyle = t.color),
context.arc(
t.pos.getX() >> 0,
t.pos.getY() >> 0,
t.radius,
0,
doublePI
),
Math.random() > 0.2 && context.stroke(),
context.closePath()
}
}
function renderAsteroids() {
var e = asteroids.length - 1
for (e; e > -1; --e) {
var t = asteroids[e]
context.beginPath(),
(context.lineWidth = Math.random() > 0.2 ? 4 : 3),
(context.strokeStyle = t.color)
var s = t.sides
for (
context.moveTo(
(t.pos.getX() +
Math.cos(doublePI * (s / t.sides) + t.angle) * t.radius) >>
0,
(t.pos.getY() +
Math.sin(doublePI * (s / t.sides) + t.angle) * t.radius) >>
0
),
s;
s > -1;
--s
)
context.lineTo(
(t.pos.getX() +
Math.cos(doublePI * (s / t.sides) + t.angle) * t.radius) >>
0,
(t.pos.getY() +
Math.sin(doublePI * (s / t.sides) + t.angle) * t.radius) >>
0
)
Math.random() > 0.2 && context.stroke(), context.closePath()
}
}
function renderScanlines() {
var e = hScan
for (context.globalAlpha = 0.05, context.lineWidth = 1, e; e > -1; --e)
context.beginPath(),
context.moveTo(0, 4 * e),
context.lineTo(screenWidth, 4 * e),
(context.strokeStyle = Math.random() > 1e-4 ? "#FFF" : "#222"),
context.stroke()
context.globalAlpha = 1
}
function generateShot() {
var e = bulletPool.getElement()
e &&
((e.radius = 1),
e.pos.setXY(
ship.pos.getX() + 14 * Math.cos(ship.angle),
ship.pos.getY() + 14 * Math.sin(ship.angle)
),
e.vel.setLength(10),
e.vel.setAngle(ship.angle),
(bullets[bullets.length] = e))
}
function resetGame() {
;(asteroidVelFactor = 0),
ship.pos.setXY(screenWidth >> 1, screenHeight >> 1),
ship.vel.setXY(0, 0),
resetAsteroids()
}
function resetAsteroids() {
var e = asteroids.length - 1
for (e; e > -1; --e) {
asteroids[e].blacklisted = !0
}
}
var canvas,
context,
screenWidth,
screenHeight,
doublePI = 2 * Math.PI,
ship,
particlePool,
particles,
bulletPool,
bullets,
asteroidPool,
asteroids,
hScan,
asteroidVelFactor = 0,
keyLeft = !1,
keyUp = !1,
keyRight = !1,
keyDown = !1,
keySpace = !1
;(window.getAnimationFrame =
window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.oRequestAnimationFrame ||
window.msRequestAnimationFrame ||
function (e) {
window.setTimeout(e, 16.6)
}),
(window.onload = function () {
;(canvas = document.getElementById("canvas")),
(context = canvas.getContext("2d")),
window.onresize(),
keyboardInit(),
particleInit(),
bulletInit(),
asteroidInit(),
shipInit(),
loop()
}),
(window.onresize = function () {
canvas &&
((screenWidth = canvas.clientWidth),
(screenHeight = canvas.clientHeight),
(canvas.width = screenWidth),
(canvas.height = screenHeight),
(hScan = (screenHeight / 4) >> 0))
})
</script>
</head>
<body>
<div id="info">
<h1>404 Not Found</h1>
<p>Use [A][S][W][D] or [&larr;][&uarr;][&darr;][&rarr;] to MOVE</p>
<p>Use [K] or [SPACE] to SHOOT</p>
<p>
<small>
©2014 Jeff Ibacache
<a
href="https://github.com/everblind/js-playground/tree/baf69566e83b1dc3317a06c6c8ef9ee786ff0572#readme"
>
(source)
</a>
</small>
</p>
</div>
<canvas id="canvas" tabindex="0"></canvas>
</body>
</html>
<!DOCTYPE html>
<meta http-equiv="refresh" content="30" />
<title>We'll be right back...</title>
<style>
body {
background: #fff;
color: #444;
text-align: center;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji",
"Segoe UI Symbol";
font-size: 32px;
}
img {
width: 50%;
max-width: 600px;
}
</style>
<h1>
&#x1F3B6;
After these messages&hellip;
<br />
We'll be right back
&#x1F3B6;
</h1>
<img
src=""
alt="Old ABC Saturday morning cartoons commercial bumper."
/>
<p>
We're restarting something and will be back shortly.
</p>
<!-- Reload the page periodically incase the system came back. -->
<script>
setTimeout("location.reload(true);", 1000 * 10)
</script>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment