HTML5的出現為網頁的開發帶來了更加豐富的功能和效果,其中3D效果成為了網頁開發者熱衷的話題之一。今天我們來分享一下HTML5中一個小而精致的3D效果——隧道效果。
下面是一段簡單的HTML5隧道代碼:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>3D Tunnel</title>
<style>
body {
background: #000;
margin: 0;
overflow: hidden;
}
canvas {
display: block;
}
</style>
</head>
<body>
<canvas id="canvas"></canvas>
<script>
window.onload = function () {
var canvas = document.getElementById("canvas");
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
var ctx = canvas.getContext("2d");
var rectWidth = 100;
var rectHeight = 100;
var rectVelocity = 1;
var rectPosX = -rectWidth;
var rectPosY = canvas.height / 2 - rectHeight / 2;
function drawRect() {
ctx.save();
ctx.fillStyle = "red";
ctx.fillRect(rectPosX, rectPosY, rectWidth, rectHeight);
ctx.restore();
}
function update() {
rectPosX += rectVelocity;
if (rectPosX >canvas.width) {
rectPosX = -rectWidth;
}
}
function render() {
ctx.clearRect(0, 0, canvas.width, canvas.height);
drawRect();
for (var i = 0; i < 20; i++) {
ctx.save();
var distance = i * 100;
var scale = 1 / (1 + distance * 0.01);
var alpha = 1 - distance / 2000;
ctx.translate(canvas.width / 2, canvas.height / 2);
ctx.scale(scale, scale);
ctx.translate(-canvas.width / 2, -canvas.height / 2);
ctx.beginPath();
ctx.globalAlpha = alpha;
ctx.rect(0, 0, canvas.width, canvas.height);
ctx.clip();
drawRect();
ctx.restore();
update();
}
requestAnimationFrame(render);
}
render();
}
</script>
</body>
</html>
這段代碼主要實現從遠到近的3D隧道效果。代碼中將一個方塊的紅色矩形視為穿越的物體。將屏幕分為20段,每次都將這些物體展現在不同的距離上,并設置透明度,從而呈現出隧道的效果。通過這個簡單的隧道3D效果,我們可以了解到HTML5的3D效果還有許多未被發掘的奧秘,可以為網站增加更多的創意元素。
以上就是HTML5隧道代碼的簡介,希望這篇文章能夠幫助到大家。下一篇html53d迷宮代碼