tetrissimo/index.html
2021-06-07 10:42:00 -07:00

226 lines
8.0 KiB
HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Tetrissimo</title>
<style>
body {
background-color: lightgray;
}
</style>
<link rel="shortcut icon" type="image/gif" href=""/>
</head>
<body>
<div style="display: flex">
<canvas id="canvas" width="480" height="600"></canvas>
<div style="margin-left: 20px">
<table>
<tr>
<th style="text-align: right"><label for="pixelSize">Pixel size:</label></th>
<td><input type="range" step="1" id="pixelSize" value="4" min="1" max="16"/></td>
<td><code id="pixelSizeValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="borderWidth">Border width:</label></th>
<td><input type="range" step="1" id="borderWidth" value="2" min="0" max="8"/></td>
<td><code id="borderWidthValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="padding">Padding:</label></th>
<td><input type="range" step="1" id="padding" value="4" min="0" max="16"/></td>
<td><code id="paddingValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="gridLines">Grid lines:</label></th>
<td><input type="checkbox" id="gridLines" checked/></td>
<td><code id="gridLinesValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="gridLineSize">Grid line size:</label></th>
<td><input type="range" id="gridLineSize" value="4" step="1" min="1" max="16"/></td>
<td><code id="gridLineSizeValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="hudWidth">HUD width:</label></th>
<td><input type="range" id="hudWidth" value="32" step="4" min="4" max="64"/></td>
<td><code id="hudWidthValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="hudHeight">HUD height:</label></th>
<td><input type="range" id="hudHeight" value="12" step="4" min="4" max="64"/></td>
<td><code id="hudHeightValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="playAreaWidth">Play Area width:</label></th>
<td><input type="range" id="playAreaWidth" value="64" step="4" min="16" max="80"/></td>
<td><code id="playAreaWidthValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="playAreaHeight">Play Area height:</label></th>
<td><input type="range" id="playAreaHeight" value="128" step="4" min="16" max="256"/></td>
<td><code id="playAreaHeightValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="fps">FPS:</label></th>
<td><input type="range" id="fps" value="60" step="1" min="1" max="120"/></td>
<td><code id="fpsValue"></code></td>
</tr>
<tr>
<th style="text-align: right"><label for="level">Level:</label></th>
<td><input type="range" id="level" value="1" step="1" min="1" max="10"/></td>
<td><code id="levelValue"></code></td>
</tr>
</table>
<br />
<button id="playButton">Play</button>
</div>
</div>
<script src="requirejs-polyfill.js"></script>
<script src="tetrissimo.js"></script>
<script>
(function() {
const playBtn = document.getElementById('playButton');
const pixelSizeRange = document.getElementById('pixelSize');
const pixelSizeValue = document.getElementById('pixelSizeValue');
const paddingRange = document.getElementById('padding');
const paddingValue = document.getElementById('paddingValue');
const gridLinesCheckbox = document.getElementById('gridLines');
const gridLinesValue = document.getElementById('gridLinesValue');
const gridLineSizeRange = document.getElementById('gridLineSize');
const gridLineSizeValue = document.getElementById('gridLineSizeValue');
const borderWidthRange = document.getElementById('borderWidth');
const borderWidthValue = document.getElementById('borderWidthValue');
const hudWidthRange = document.getElementById('hudWidth');
const hudWidthValue = document.getElementById('hudWidthValue');
const hudHeightRange = document.getElementById('hudHeight');
const hudHeightValue = document.getElementById('hudHeightValue');
const playAreaWidthRange = document.getElementById('playAreaWidth');
const playAreaWidthValue = document.getElementById('playAreaWidthValue');
const playAreaHeightRange = document.getElementById('playAreaHeight');
const playAreaHeightValue = document.getElementById('playAreaHeightValue');
const fpsRange = document.getElementById('fps');
const fpsValue = document.getElementById('fpsValue');
const levelRange = document.getElementById('level');
const levelValue = document.getElementById('levelValue');
const updateCanvas = () => {
const pixelSize = Number(pixelSizeRange.value);
const padding = Number(paddingRange.value);
const gridLineSize = Number(gridLineSizeRange.value);
const gridLines = gridLinesCheckbox.checked;
const borderWidth = Number(borderWidthRange.value);
const hudWidth = Number(hudWidthRange.value);
const hudHeight = Number(hudHeightRange.value);
const playAreaWidth = Number(playAreaWidthRange.value);
const playAreaHeight = Number(playAreaHeightRange.value);
pixelSizeValue.innerHTML = pixelSize.toString();
paddingValue.innerHTML = padding.toString();
gridLinesValue.innerHTML = gridLines ? 'on' : 'off';
gridLineSizeValue.innerHTML = gridLineSize.toString()
borderWidthValue.innerHTML = borderWidth.toString();
hudWidthValue.innerHTML = hudWidth.toString();
hudHeightValue.innerHTML = hudHeight.toString();
playAreaWidthValue.innerHTML = playAreaWidth.toString();
playAreaHeightValue.innerHTML = playAreaHeight.toString();
ui.setOptions({
pixelSize,
x: 0,
y: 0,
padding,
gridLines: gridLines ? gridLineSize : false,
borderWidth,
hud: {
width: hudWidth,
height: hudHeight,
},
playArea: {
width: playAreaWidth,
height: playAreaHeight,
}
});
ui.update();
};
pixelSizeRange.addEventListener('change', updateCanvas);
paddingRange.addEventListener('change', updateCanvas);
gridLineSizeRange.addEventListener('change', updateCanvas);
borderWidthRange.addEventListener('change', updateCanvas);
gridLinesCheckbox.addEventListener('input', updateCanvas);
hudWidthRange.addEventListener('change', updateCanvas);
hudHeightRange.addEventListener('change', updateCanvas);
playAreaWidthRange.addEventListener('change', updateCanvas);
playAreaHeightRange.addEventListener('change', updateCanvas);
playBtn.addEventListener('click', () => {
if (game.getState() === 'running') {
game.pause();
} else {
game.start();
}
});
const updateFps = () => {
const fps = Number(fpsRange.value);
fpsValue.innerHTML = fps.toString();
game.setTargetFps(fps);
};
fpsRange.addEventListener('change', updateFps);
const updateLevel = () => {
const level = Number(levelRange.value);
levelValue.innerHTML = level.toString();
const tetrissimoLevel = TetrissimoLevel['level' + level];
if (!tetrissimoLevel) {
throw new Error(`invalid level number "${level}"`);
}
game.setLevel(tetrissimoLevel);
};
levelRange.addEventListener('change', updateLevel);
document.addEventListener('keydown', (e) => {
const performAction = (type) => {
e.preventDefault();
game.performPieceAction({ type });
};
switch (e.code) {
case 'KeyA':
performAction('moveLeft');
break;
case 'KeyS':
performAction('moveDown');
break;
case 'KeyD':
performAction('moveRight');
break;
case 'Space':
performAction('rotateRight');
break;
case 'ShiftLeft':
performAction('rotateLeft');
break;
}
})
updateCanvas();
updateFps();
updateLevel();
}());
</script>
</body>
</html>