通过Canvas实现的可刮涂层效果.

修改img.src时涂层也会自动适应新图片的尺寸.

修改layer函数可更改涂层样式.

涂层:

可刮效果:

 

以下是HTML源代码(已增加移动设备支持):

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
<!DOCTYPE html>
<html>
<body>
<canvas/>
<script>
     ( function (bodyStyle) {
         bodyStyle.mozUserSelect = 'none' ;
         bodyStyle.webkitUserSelect = 'none' ;
 
         var img = new Image();
         var canvas = document.querySelector( 'canvas' );
         canvas.style.backgroundColor= 'transparent' ;
         canvas.style.position = 'absolute' ;
 
         img.addEventListener( 'load' , function (e) {
             var ctx;
             var w = img.width,
                 h = img.height;
             var offsetX = canvas.offsetLeft,
                 offsetY = canvas.offsetTop;
             var mousedown = false ;
 
             function layer(ctx) {
                 ctx.fillStyle = 'gray' ;
                 ctx.fillRect(0, 0, w, h);
             }
 
             function eventDown(e){
                 e.preventDefault();
                 mousedown= true ;
             }
 
             function eventUp(e){
                 e.preventDefault();
                 mousedown= false ;
             }
 
             function eventMove(e){
                 e.preventDefault();
                 if (mousedown) {
                     if (e.changedTouches){
                         e=e.changedTouches[e.changedTouches.length-1];
                     }
                     var x = (e.clientX + document.body.scrollLeft || e.pageX) - offsetX || 0,
                         y = (e.clientY + document.body.scrollTop || e.pageY) - offsetY || 0;
                     with (ctx) {
                         beginPath()
                         arc(x, y, 5, 0, Math.PI * 2);
                         fill();
                     }
                 }
             }
 
             canvas.width=w;
             canvas.height=h;
             canvas.style.backgroundImage= 'url(' +img.src+ ')' ;
             ctx=canvas.getContext( '2d' );
             ctx.fillStyle= 'transparent' ;
             ctx.fillRect(0, 0, w, h);
             layer(ctx);
 
             ctx.globalCompositeOperation = 'destination-out' ;
 
             canvas.addEventListener( 'touchstart' , eventDown);
             canvas.addEventListener( 'touchend' , eventUp);
             canvas.addEventListener( 'touchmove' , eventMove);
             canvas.addEventListener( 'mousedown' , eventDown);
             canvas.addEventListener( 'mouseup' , eventUp);
             canvas.addEventListener( 'mousemove' , eventMove);
         });
         img.src = '' ;
     })(document.body.style);
</script>
</body>
</html>

需要判断是否刮完时用这段代码替换原代码的eventUp事件处理函数:

1
2
3
4
5
6
7
8
9
10
11
e.preventDefault();
mousedown = false ;
var data=ctx.getImageData(0,0,w,h).data;
for ( var i=0,j=0;i<data.length;i+=4){
     if (data[i] && data[i+1] && data[i+2] && data[i+3]){
         j++;
     }
}
if (j<=w*h*0.1){
     alert( 'ok' );
}

这段代码中的0.1是10%的意思,在涂层的面积小于等于10%时,就弹出窗口,表示刮完了,可以根据需求自行调整.

转载于:https://www.cnblogs.com/xuhongfei/p/3462786.html

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐