使用Html5中的cavas画一面国旗

2022-10-09,,

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

《使用Html5中的cavas画一面国旗.doc》

下载本文的Word格式文档,以方便收藏与打印。