使用Html5中的cavas画一面国旗
程序员文章站
2022-06-21 21:47:46
这篇文章主要介绍了使用Html5中的cavas画一面国旗的相关资料,需要的朋友可以参考下... 19-09-25...
使用html5中的cavas画一面国旗,具体代码如下所示:
var canvas = document.getelementbyid("canvas");//创建一个cavas画板 var context = canvas.getcontext('2d');//设置画板属性 var width=canvas.width; var height=width*2/3; context.fillstyle="red"; context.fillrect(0,0,width,height); var maxr = 0.15, minr = 0.05; var maxx = 0.55, maxy = 0.35;//大五星的位置 var minx = [0.80, 0.90, 0.90, 0.80,0.65,0.50,0.40];//各个小五角星的x坐标 var miny = [0.20, 0.30, 0.45, 0.55,0.60,0.60,0.50];//各个小五角星的y坐标 var ox = height * maxx, oy = height * maxy;
html代码
<canvas id="canvas" width="600" height="400"></canvas>
js代码
create5star(context,ox,oy,height * maxr,"#ff0",0);//绘制大五角星 for (var idx = 0; idx < 7; idx++) { var sx = minx[idx] * height, sy = miny[idx] * height; var theta = math.atan((oy - sy)/(ox - sx)); create5star(context,sx, sy, height * minr, "#ff0",-math.pi/2+theta); // 画小五角星 } //绘制五角星 function create5star(context,sx,sy,radius,color,rotato){ context.save(); context.fillstyle=color; context.translate(sx,sy);//移动坐标原点 context.rotate(math.pi+rotato);//旋转 context.beginpath();//创建路径 var x = math.sin(0); var y= math.cos(0); var dig = math.pi/5 *4; for(var i = 0;i< 5;i++){//画五角星的五条边 var x = math.sin(i*dig); var y = math.cos(i*dig); context.lineto(x*radius,y*radius); } context.closepath(); context.stroke(); context.fill(); context.restore(); }
总结
以上所述是小编给大家介绍的使用html5中的cavas画一面国旗,希望对大家有所帮助