• 技术文章 >web前端 >H5教程

    HTML5 Canvas组件绘制太极图案的图文代码详情

    黄舟黄舟2017-03-03 16:28:05原创1452

    一实现思路:

    实现原理主要是利用HTML5的Canvas组件提供的path函数功能来绘制圆,首先绘

    制两个半圆,分别为黑色和白色,组成一个圆,绘制完成以后再分别绘制一个黑色

    和白色的圆在绘制好的黑白圆之内,半径恰好是黑白大圆一半。 最后在绘制好的两

    个黑白小圆内分别填充白色和黑色的点,半径大小为10pixel左右。

    二程序效果如下:


    三关键程序解析:


    绘制半圆的程序,其中200,200表示开始绘制圆心点坐标,第三个参数150表示绘制圆的半径

    第四个参数表示开始角度,第五个参数表示结束角度,最后一个参数表示是否为顺时针或者逆时针

    绘制白色半圆的代码如下:


    		ctx.fillStyle="#fff";
    		ctx.beginPath(); 
    		ctx.arc(200, 200, 150, 1.5*Math.PI, Math.PI/2, false);
    		ctx.closePath();
    		ctx.fill();

    绘制黑色半圆的代码如下:

    		ctx.fillStyle="#000";
    		ctx.beginPath(); 
    		ctx.arc(200, 200, 150, Math.PI/2, 1.5*Math.PI, false);
    		ctx.closePath();
    		ctx.fill();


    在太极图案中添加文字的代码使用了透明处理,Canvas全局透明度设置函数

    如下:

    		// set transparency value  
    		ctx.globalAlpha = 0.2;

    绘制文字的代码如下:

    		// Draw semi transparent text
    		ctx.fillStyle = "#f00";
    		ctx.font = "32pt Arial";
    		ctx.fillText("Hello", 220, 200);
    		ctx.fillText("Canvas", 100, 250);


    程序完全JavaScript代码如下:

    	window.onload = function() {
    		var cvs = document.getElementById("canvas-path");
    		ctx = cvs.getContext("2d");
    
    		// Create circle, radius = 150
    		// start point(x, y), radius, start angle, end angle, boolean antiClockWise
    		ctx.fillStyle="#fff";
    		ctx.beginPath(); 
    		ctx.arc(200, 200, 150, 1.5*Math.PI, Math.PI/2, false);
    		ctx.closePath();
    		ctx.fill();
    		ctx.fillStyle="#000";
    		ctx.beginPath(); 
    		ctx.arc(200, 200, 150, Math.PI/2, 1.5*Math.PI, false);
    		ctx.closePath();
    		ctx.fill();
    		
    		// draw sub circle
    		// start point(x, y), radius, start angle, end angle, boolean antiClockWise
    		ctx.fillStyle="#000";
    		ctx.beginPath(); 
    		ctx.arc(200, 275, 75, 0, Math.PI*2, false); 
    		ctx.closePath();
    		ctx.fill();
    		ctx.fillStyle="#fff";
    		ctx.beginPath(); 
    		ctx.arc(200, 125, 75, 0, Math.PI*2, false);
    		ctx.closePath();
    		ctx.fill();
    		
    		// fill black and white point
    		ctx.fillStyle="#fff";
    		ctx.beginPath(); 
    		ctx.arc(200, 275, 10, 0, Math.PI*2, false);
    		ctx.closePath();
    		ctx.fill();
    		ctx.fillStyle="#000";
    		ctx.beginPath(); 
    		ctx.arc(200, 125, 10, 0, Math.PI*2, false);
    		ctx.closePath();
    		ctx.fill();
    		
    		// set transparency value  
    		ctx.globalAlpha = 0.2;  
    		  
    		// Draw semi transparent text
    		ctx.fillStyle = "#f00";
    		ctx.font = "32pt Arial";
    		ctx.fillText("Hello", 220, 200);
    		ctx.fillText("Canvas", 100, 250);
    		ctx.globalAlpha = 1.0; 
    		ctx.shadowOffsetX = 2;  
    		ctx.shadowOffsetY = 2;  
    		ctx.shadowBlur = 2;  
    		ctx.shadowColor = "rgba(0, 0, 0, 0.5)";  
    		ctx.fillStyle = "#000";
    		ctx.font = "20px Times New Roman";
    		ctx.fillText("-created by gloomyfish", 100, 30);
    	};


    我为什么要在插图上加上我的名字,因为发现文章被转载的时候居然没有被标出来!

    以上就是HTML5 Canvas组件绘制太极图案的图文代码详情的内容,更多相关内容请关注PHP中文网(m.sbmmt.com)!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:HTML5 组件Canvas实现电子钟的图文代码详情介绍 下一篇:HTML5 组件Canvas实现图像灰度化的实例代码
    PHP编程就业班

    相关文章推荐

    • 深入解析asp.net中mvc4自定义404页面(分享)• html5离线存储有哪些• 在今天,利用 HTML5 开发和发布大型跨平台网游,可行性如何?要解决哪些问题?• 避免常见的六种HTML5错误用法 (5-6)• phonegap使用方法介绍(八)操作数据库

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网