HTML5刮獎特效代碼,是前端開發中比較流行的一種效果。HTML5刮獎可用于各種營銷推廣活動,比如抽獎、優惠券等等。下面我們來看一下HTML5刮獎特效的代碼。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>HTML5刮獎</title>
<style>
#wrapper {
position: relative;
width: 400px;
height: 200px;
}
#canvas, #image {
position: absolute;
top: 0;
left: 0;
}
#image {
z-index: 10;
}
</style>
</head>
<body>
<div id="wrapper">
<canvas id="canvas" width="400" height="200"></canvas>
<img id="image" src="https://example.com/image.jpg" />
</div>
<script>
var canvas = document.getElementById("canvas");
var context = canvas.getContext("2d");
context.fillStyle = "#666";
context.fillRect(0, 0, canvas.width, canvas.height);
context.globalCompositeOperation = "destination-out";
canvas.addEventListener("mousemove", function(event) {
var x = event.offsetX;
var y = event.offsetY;
context.beginPath();
context.arc(x, y, 20, 0, Math.PI * 2, true);
context.fill();
});
</script>
</body>
</html>
上述代碼中,首先定義一個寬400px,高200px的div標簽,其中包含一個canvas標簽和一個img標簽。其中,canvas用于繪制刮開后的圖片,img用于顯示要刮的圖片。canvas和img都被設置為absolute定位,并使用z-index保證img在canvas之上。
在script標簽中,獲取到canvas的2d繪圖上下文,將其填充為灰色,然后設置全局合成模式為"destination-out",這樣在鼠標移動的時候,會在canvas畫布上繪制一個圓形,使得canvas畫布上原有的部分被擦除。鼠標移動的坐標獲取方式是通過addEventListener添加mousemove事件的offsetX和offsetY屬性獲取的。
這樣,一個簡單的HTML5刮獎效果就完成了。當然,實際的頁面中,還需要自己根據需求來設置樣式和圖片路徑,達到更好的效果。