HTML5 Canvas 绘制星条旗

简介:

代码:

复制代码
<!DOCTYPE html>
<html lang="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<head>
     <title>美国国旗</title>
    </head>

     <body onload="draw()">
        <canvas id="myCanvus" width="380px" height="200px" style="border:1px dashed black;">
            出现文字表示你的浏览器不支持HTML5
        </canvas>
     </body>
</html>
<script type="text/javascript">
<!--
    function draw(){
        var canvas=document.getElementById("myCanvus");
        var canvasWidth=380;
        var canvasHeight=200;

        var context=canvas.getContext("2d");
        
        context.fillStyle = "white";
        context.fillRect(0, 0, canvasWidth, canvasHeight);
        
        var i;
        // 13个横条
        for(i=0;i<13;i++){
            if(i % 2==0){
                context.fillStyle = "red";
                context.fillRect(0, canvasHeight/13*i, canvasWidth, canvasHeight/13);
            }else{
                context.fillStyle = "white";
                context.fillRect(0, canvasHeight/13*i, canvasWidth, canvasHeight/13);
            }            
        }

        // 左上角蓝底
        var D=canvasWidth/5*2;
        var C=canvasHeight/13*7;
        context.fillStyle = "blue";
        context.fillRect(0, 0, D, C);

        // 画星星
        var x;
        var y;
        var j=0;

        context.strokeStyle = "white";
        context.fillStyle = "white"

        for(i=0;i<6;i++){
            for(j=0;j<5;j++){
                x=D/12+2*i*D/12;
                y=C/10+2*j*C/10;

                context.save();

                var r=5;
                context.translate(x-r,y-r);

                
                context.beginPath();
                context.moveTo(r, 0);
                context.lineTo(r+Math.cos(Math.PI*3/10)*r, r+Math.sin(Math.PI*3/10)*r);
                context.lineTo(r-Math.cos(Math.PI*1/10)*r, r-Math.sin(Math.PI*1/10)*r);
                context.lineTo(r+Math.cos(Math.PI*1/10)*r, r-Math.sin(Math.PI*1/10)*r);
                context.lineTo(r-Math.cos(Math.PI*3/10)*r, r+Math.sin(Math.PI*3/10)*r);
                context.lineTo(r, 0);
                context.fill();
                context.stroke();
                context.closePath();

                context.restore();
            }
        }

        for(i=0;i<5;i++){
            for(j=0;j<4;j++){
                x=D/6+2*i*D/12;
                y=C/5+2*j*C/10;

                context.save();

                var r=5;
                context.translate(x-r,y-r);

                
                context.beginPath();
                context.moveTo(r, 0);
                context.lineTo(r+Math.cos(Math.PI*3/10)*r, r+Math.sin(Math.PI*3/10)*r);
                context.lineTo(r-Math.cos(Math.PI*1/10)*r, r-Math.sin(Math.PI*1/10)*r);
                context.lineTo(r+Math.cos(Math.PI*1/10)*r, r-Math.sin(Math.PI*1/10)*r);
                context.lineTo(r-Math.cos(Math.PI*3/10)*r, r+Math.sin(Math.PI*3/10)*r);
                context.lineTo(r, 0);
                context.fill();
                context.stroke();
                context.closePath();

                context.restore();
            }
        }
    }

    function getRad(degree){
        return degree/180*Math.PI;
    }
//-->
</script>
复制代码

 关于美国国旗如何画请参考:https://wenku.baidu.com/view/d6eb1d40b4daa58da1114a32.html



















本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/xiandedanteng/p/7470362.html,如需转载请自行联系原作者


相关文章
|
3月前
|
前端开发 JavaScript API
2024 新年HTML5+Canvas制作3D烟花特效(附源码)
2024 新年HTML5+Canvas制作3D烟花特效(附源码)
54 0
|
8月前
|
移动开发 前端开发 Shell
《HTML5 Canvas核心技术 图形、动画与游戏开发》 读书笔记
《HTML5 Canvas核心技术 图形、动画与游戏开发》 读书笔记
|
3月前
|
存储 移动开发 前端开发
HTML新特性【HTML5内联SVG、SVG_矩形、SVG 与 Canvas两者间的区别 、HTML5_MathML 】(三)-全面详解(学习总结---从入门到深化)
HTML新特性【HTML5内联SVG、SVG_矩形、SVG 与 Canvas两者间的区别 、HTML5_MathML 】(三)-全面详解(学习总结---从入门到深化)
48 0
|
2月前
|
前端开发 JavaScript 容器
编程笔记 html5&css&js 032 HTML Canvas
编程笔记 html5&css&js 032 HTML Canvas
|
4月前
|
移动开发 前端开发 JavaScript
html5 Canvas 绘制基本图形 从直线图形到使用路径 - 直线、矩形、路径、多边形、复杂组合图形
html5 Canvas 绘制基本图形 从直线图形到使用路径 - 直线、矩形、路径、多边形、复杂组合图形
127 0
html5 Canvas 绘制基本图形 从直线图形到使用路径 - 直线、矩形、路径、多边形、复杂组合图形
|
4月前
|
存储 移动开发 前端开发
HTML新特性【HTML5内联SVG、SVG_矩形、SVG 与 Canvas两者间的区别 、HTML5_MathML 】(三)-全面详解(学习总结---从入门到深化)(下)
HTML新特性【HTML5内联SVG、SVG_矩形、SVG 与 Canvas两者间的区别 、HTML5_MathML 】(三)-全面详解(学习总结---从入门到深化)
30 0
|
4月前
|
XML 移动开发 前端开发
HTML新特性【HTML5内联SVG、SVG_矩形、SVG 与 Canvas两者间的区别 、HTML5_MathML 】(三)-全面详解(学习总结---从入门到深化)(上)
HTML新特性【HTML5内联SVG、SVG_矩形、SVG 与 Canvas两者间的区别 、HTML5_MathML 】(三)-全面详解(学习总结---从入门到深化)
29 0
|
5月前
|
移动开发 前端开发 JavaScript
HTML5新增元素之Canvas-实现太极八卦图和扇子
HTML5新增元素之Canvas-实现太极八卦图和扇子
|
8月前
|
前端开发 开发者
|
9月前
|
移动开发 JavaScript 前端开发
封装HTML5中canvas画布操作的第三方库
封装HTML5中canvas画布操作的第三方库
462 0