欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

HTML5利用canvas API展示阴影效果

程序员文章站 2022-03-09 22:29:27
html5的canvas自带api可以显示阴影效果,主要还是在画布(canvas)的上下文对象(context)上做文章 1.  2. ...

html5的canvas自带api可以显示阴影效果,主要还是在画布(canvas)的上下文对象(context)上做文章
1. <!doctype html>
2. <head>
3. <meta charset="utf-8">
4. <title>html5 combine shape demo</title>
5. <script type="text/javascript" src="js/drawshadow.js"></script>
6. </head>
7. 
8. <body onload="draw('canvas')"></body>
9. <h2>canvas:显示阴影效果</h2>
10. 
11. 
12. <!-- 指定一个canvas元素用于显示结果 -->
13. <canvas id="canvas" width="400” height="400"/>
14. <br><br>
画带阴影效果的图形见如下的js代码:
1. /**
2.  *  this file is confidential by charles.wang
3.  *  copyright belongs to charles.wang
4.  *  you can make contact with charles.wang ()
5.  */
6.  
7.  function draw (id){
8.     
9.     //取得画布对象
10.     var canvas = document.getelementbyid(id);
11.     if(canvas ==null)
12.     return false;
13.     //取得上下文
14.     var context = canvas.getcontext('2d');
15.     //绘制底图
16.     context.fillstyle='#ffeeff';
17.     context.fillrect(0,0,400,400);
18.     
19.     //以下4个属性是阴影的设置属性,用他们可以用来画阴影效果
20.     
21.     //shadowoffsetx是横向位移量,所以这里设置为10表明阴影会出现在原图形右边,最多10像素
22.     context.shadowoffsetx=10;
23.     //shadowoffsetx是纵向位移量,所以这里设置为10表明阴影会出现在原图形下边,最多10像素
24.     context.shadowoffsety=10;
25.     //阴影的颜色
26.     context.shadowcolor="rgba(50,50,100,0.5)";
27.     //阴影的模糊范围
28.     context.shadowblur=7.5;
29.     
30.     //所以到这里为止,我们吧上下文关联上了阴影效果,所有用这个context绘制的图形都会有(+10,+10)的阴影效果
31.     
32.     //绘制五角星
33.     context.translate(50,50);
34.     create5star(context);
35.     context.fill();
36.  }
37.  
38.  function create5star(context){
39.     
40.      var n = 0;
41.      var dx=100;
42.      var dy=0;
43.      var s = 50;
44.      //创建路径
45.      context.beginpath();
46.      context.fillstyle='rgba(255,0,0,0.5)';
47.      var x = math.sin(0);
48.      var y=math.cos(0);
49.      var dig = math.pi/5*4;
50.      //画5条边
51.      for(var i =0;i<5;i++){
52.         var x = math.sin(i * dig);
53.         var y = math.cos(i* dig);
54.         context.lineto(dx+x*s,dy+y*s);
55.      }
56.      context.closepath();
57.  }
 
最终展示效果如图:
  

 HTML5利用canvas API展示阴影效果




摘自 平行线的凝聚