HTML5新增元素之Canvas-实现太极八卦图和扇子

简介: HTML5新增元素之Canvas-实现太极八卦图和扇子

HTML5新增元素之Canvas-实现太极八卦图和扇子

绘制流程:

1、在HTML5中添加canvas元素,并且设置宽度和ID

2、在canvas元素中添加提示语句,让不支持的canvas的浏览器能够显示友好的提示语句

3、添加script元素

4、获取画布/设置绘图环境

(1)制定线宽:lineWidth(驼峰命名法)=数值

(2)制定颜色:strokeStyle=颜色值(只适用于轮廓、线段、填充颜色用:fillStyle=颜色)

(3)设置起点:moveTo(x坐标,y坐标)

(4)设置终点:lineTo(x 坐标,y坐标)

(5)开始绘制:stroke()

文末有Canvas实现太极八卦图和扇子的案例可以看一下

一、什么是 Canvas?

HTML5 的 canvas 元素使用 JavaScript 在网页上绘制图像。

画布是一个矩形区域,您可以控制其每一像素。canvas 拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。

二、创建 Canvas 元素

向 HTML5 页面添加 canvas 元素,规定元素的 id、宽度和高度:

<canvas id="myCanvas" width="200" height="100"></canvas>

通过 JavaScript 来绘制

  • canvas 元素本身是没有绘图能力的。所有的绘制工作必须在 JavaScript 内部完成:
<script type="text/javascript">
var c=document.getElementById("myCanvas");
var cxt=c.getContext("2d");
cxt.fillStyle="#FF0000";
cxt.fillRect(0,0,150,75);
</script>

JavaScript 使用 id 来寻找 canvas 元素:

var c=document.getElementById("myCanvas");

然后,创建 context 对象:

var cxt=c.getContext("2d"); 

getContext(“2d”) 对象是内建的 HTML5 对象,拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。

下面的两行代码绘制一个红色的矩形:

cxt.fillStyle="#FF0000";
cxt.fillRect(0,0,150,75); 

fillStyle 方法将其染成红色,fillRect 方法规定了形状、位置和尺寸。

理解坐标

上面的 fillRect 方法拥有参数 (0,0,150,75)。

意思是:在画布上绘制 150x75 的矩形,从左上角开始 (0,0)。

如下图所示,画布的 X 和 Y 坐标用于在画布上对绘画进行定位。

案例:

HTML代码如下:

<canvas id="canvas" width="500" height="500">
        您的浏览器暂不支持HTML的元素
        c.lineTo(200,200);
    </canvas>

CSS代码如下:

<style>
       canvas {
           background: #a9a9a0 ;
       }
    </style>

JS代码如下:

<script>
        var canvas=document.getElementById('canvas');
        var c=canvas.getContext('2d');
        c.lineWidth=50;
        c.strokeStyle="aaaaaa";
        c.moveTo(50,50);
        c.lineTo(200,200);
        c.lineTo(300,300);
        c.lineTo(50,50);
        c.stroke();
    </script>

效果图如下(有点丑,别喷我):

代码如下:

<canvas id="canvas" width="800" height="700">
        您的浏览器暂不支持HTML的元素
        c.lineTo(200,200);
   </canvas>
<style>
       canvas {
           background: #a9a9a0 ;
       }
    </style>
<script>
       var canvas=document.getElementById('canvas');
        var c=canvas.getContext('2d');
        c.lineWidth=10;
        c.strokeStyle="a52a2a";
        c.lineWidth=6;
c.strokeStyle="#ffa500";
c.fillStyle="#ffa500";
c.moveTo(400,500);
c.arc(400,500,300,Math.Pi*7/6,Math.PI*1.5,false);
c.beginPath();
c.moveTo(400,500);
c.arc(400,500,300,Math.PI*11/6,Math.PI*7/6,true);
c.fill();
c.beginPath();
c.fillStyle="#a9a9a0";
c.arc(400,500,150,Math.PI*7/6,Math.PI*1.5,false);
c.beginPath();
c.moveTo(400,500);
c.arc(400,500,150,Math.PI*11/6,Math.PI*7/6,true);
c.fill();
c.beginPath();
c.fillStyle="#000000";
c.font="55px 楷体";
c.fillText("纵",375,275);
c.fillText("横",375,340);

太极八卦效果图如下:


相关文章
WK
|
2月前
|
存储 移动开发 前端开发
HTML5新增了哪些其他元素和属性
这段文字介绍了HTML5中新增的多种元素和属性,包括页面布局元素如header、nav等,表单元素如email、tel输入框等,以及其他元素如canvas、svg等。此外,还介绍了全局及表单属性,例如contenteditable、placeholder等,这些新功能显著增强了HTML5在现代网页设计与开发中的实用性与灵活性。
WK
65 1
|
12天前
|
Web App开发 移动开发 前端开发
html5 canvas五彩碎纸屑飘落动画特效
h5 canvas飘落纸片动画是一款实现五彩纸屑飘落的背景动画特效,基于canvas绘制的空中飘落的纸屑片动画特效,适用于网页动态背景效果代码。简单使用,欢迎下载!代码适用浏览器:搜狗、360、FireFox(建议)、Chrome、Safari、Opera、傲游、世界之窗,是一款不错的的特效插件,希望大家喜欢!
32 5
|
21天前
|
存储 移动开发 数据处理
HTML5 元素2
HTML5引入了多个新元素以增强表单功能和用户体验。`&lt;keygen&gt;`元素用于生成密钥对,提交表单时生成私钥和公钥,私钥保存在客户端,公钥发送至服务器,用于后续的身份验证。`&lt;output&gt;`元素则用于展示计算结果或其他脚本输出,如表单数据处理的结果。此外,`&lt;datalist&gt;`元素可与`&lt;input&gt;`元素结合使用,提供预定义的选项列表,增强输入的便捷性和准确性。这些元素共同提升了网页的交互性和安全性。
|
18天前
|
移动开发 前端开发 JavaScript
HTML5 <nav> 元素2
HTML5中的`&lt;nav&gt;`标签用于定义页面的导航链接部分,但并非所有链接都需置于其中。`&lt;aside&gt;`标签定义页面主内容外的相关信息,如侧边栏。`&lt;header&gt;`标签描述文档或节的头部区域,可用于定义内容的介绍展示区。示例包括导航、家庭旅行记录和IE9发布信息等。
|
21天前
|
移动开发 UED HTML5
HTML5 表单元素1
HTML5引入了新的表单元素,如`&lt;datalist&gt;`、`&lt;keygen&gt;`和`&lt;output&gt;`,以增强表单的功能性和用户体验。
|
23天前
|
前端开发
基于canvas实现的彩色纸屑组成文字3d动画HTML源码
基于canvas实现的彩色纸屑组成文字3d动画HTML源码
19 0
基于canvas实现的彩色纸屑组成文字3d动画HTML源码
|
23天前
|
移动开发 前端开发 HTML5
HTML5 Canvas制作的粒子十秒倒计时源码
一段基于HTML5 Canvas制作的粒子爆炸,十秒数字倒计时,全屏倒计时动画效果,给人一种非常大气的视觉感
22 0
HTML5 Canvas制作的粒子十秒倒计时源码
|
18天前
|
Web App开发 移动开发 iOS开发
HTML5 语义元素1
HTML5引入了语义元素,如`&lt;nav&gt;`、`&lt;header&gt;`、`&lt;footer&gt;`等,这些元素能清晰地向浏览器和开发者传达其内容的意义,如导航链接、头部和尾部。与非语义元素(如`&lt;div&gt;`)不同,语义元素使网页结构更加明确,有助于提升可读性和可访问性。例如,`&lt;section&gt;`标签用于定义文档中的节,而`&lt;article&gt;`标签则用于定义独立的内容,如论坛帖子、博客文章等。这些新元素在IE9及更高版本、Firefox、Chrome、Safari和Opera中得到支持。
|
1月前
|
前端开发 JavaScript
Canvas三维变化背景动画HTML源码
Canvas三维变化背景动画HTML源码
31 5
HTML 元素
HTML文档由HTML元素定义,元素包括开始标签、内容和结束标签。某些元素内容为空,可在开始标签中关闭。大多数元素可拥有属性,且元素间可相互嵌套,形成复杂结构。