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

使用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画一面国旗,希望对大家有所帮助