HTML_5 Canvas(1)

简介:

HTML5 简介

 

HTML5相对于html4的优点是:

1 多了许多标签,提供了更为合理的Tag

2 提供了极为强大的API接口,使得以前需要使用复杂的javascrpt实现的功能直接使用标签就可以使用了

3 Html仍然在不断完善过程中,现在大部分浏览器已经具备了某些html5的支持,浏览器支持的比例按照google chrome,opera,firefox,safari,ie逐渐减少

 

Canvas 接口

HTML5提供<canvas>标签

比如<canvas id="myCanvas"></canvas>

 

基本的模板:

<!DOCTYPE HTML>

<html>

<head>

<script>

window.onload = function(){

//获取canvas元素

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

//初始化canvas元素是2D的(可能有读者就想这里可能会有3d的)

var context = canvas.getContext("2d");

// 把操作写在这里TODO

};

</script>

</head>

<body>

<canvas id="myCanvas" width="578" height="200">

</canvas>

</body>

</html>

 

Canvas的接口:

context.moveTo(x,y); //将画笔移动到(x,y)

context.lineTo(x,y); //从当前画笔画一条线到(x,y)

context.stroke();//画线并显示 
context.lineWidth=[value]; //笔触长度

context.strokeStyle=[value]; //画线颜色

context.lineCap=[value]; //比划类型,value可以是butt,round,square

 

context.arc(centerX, centerY, radius, startingAngle,

endingAngle, antiClockwise);//画一个圆弧,以centerX,centerY为圆心,radius为半径,开始角度为staringAngle,结束角度为endingAngle,antiClockwise是代表顺时针

 

window.onload = function(){
    var canvas = document.getElementById("myCanvas");
    var context = canvas.getContext("2d");
 
    var centerX = 288;
    var centerY = 160;
    var radius = 75;
    var startingAngle = 1.1 * Math.PI;
    var endingAngle = 1.9 * Math.PI;
    var counterclockwise = false;
 
    context.arc(centerX, centerY, radius, startingAngle,
        endingAngle, counterclockwise);
 
    context.lineWidth = 15;
    context.strokeStyle = "black"; // line color
    context.stroke();
};

产生的图就是

clip_image002

 

context.quadraticCurveTo(controlX, controlY, endX, endY);

//画一条二次曲线(数学上的二次曲线是三点确定一个曲线,因此就有startpoint,controlpoint,endpoint三个点来确定)

window.onload = function(){
    var canvas = document.getElementById("myCanvas");
    var context = canvas.getContext("2d");
 
    context.moveTo(188, 150);
 
    var controlX = 288;
    var controlY = 0;
    var endX = 388;
    var endY = 150;
 
    context.quadraticCurveTo(controlX, controlY, endX, endY);
    context.lineWidth = 10;
    context.strokeStyle = "black"; // line color
    context.stroke();
};

产生的效果

clip_image004

 

 

context.bezierCurveTo(controlX1, controlY1, controlX2, controlY2, endX, endY);

//贝塞尔曲线,贝塞尔曲线由4个点组成,具体说明可以参考度娘http://baike.baidu.com/view/60154.htm

window.onload = function(){
    var canvas = document.getElementById("myCanvas");
    var context = canvas.getContext("2d");
 
    context.moveTo(188, 130);
 
    var controlX1 = 140;
    var controlY1 = 10;
    var controlX2 = 388;
    var controlY2 = 10;
    var endX = 388;
    var endY = 170;
 
    context.bezierCurveTo(controlX1, controlY1, controlX2,
        controlY2, endX, endY);
 
    context.lineWidth = 10;
    context.strokeStyle = "black"; // line color
    context.stroke();
};

生成的效果:

clip_image006

起始点加上参数的三个点组成四个点就划成了贝塞尔曲线

 

 

context.beginPath();

//将多种曲线和在一起的方法

window.onload = function(){
    var canvas = document.getElementById("myCanvas");
    var context = canvas.getContext("2d");
 
    context.beginPath();
    context.moveTo(100, 20);
    context.lineTo(200, 160); // line 1 画直线
    context.quadraticCurveTo(230, 200, 250, 120); // quadratic curve 二次曲线
    context.bezierCurveTo(290, -40, 300, 200, 400, 150); // bezier curve
    context.lineTo(500, 90); // line 2
    context.lineWidth = 5;
    context.strokeStyle = "#0000ff";
    context.stroke();
};

效果图:

clip_image008

 

 

context.lineJoin=[value];

//将两条直线连接起来的方式,比如可以是miter(直连), round(圆连), bevel(平连)

window.onload = function(){
    var canvas = document.getElementById("myCanvas");
    var context = canvas.getContext("2d");
 
    // miter line joine (left)
    context.beginPath();
    context.moveTo(canvas.width / 2 - 50 - 140, canvas.height - 50); // line 1
    context.lineTo(canvas.width / 2 - 140, 50); // line 1
    context.lineTo(canvas.width / 2 + 50 - 140, canvas.height - 50); // line 1
    context.lineWidth = 25;
    context.lineJoin = "miter";
    context.stroke();
 
    // round line join (middle)
    context.beginPath();
    context.moveTo(canvas.width / 2 - 50, canvas.height - 50); // line 1
    context.lineTo(canvas.width / 2, 50); // line 1
    context.lineTo(canvas.width / 2 + 50, canvas.height - 50); // line 1
    context.lineWidth = 25;
    context.lineJoin = "round";
    context.stroke();
 
    // bevel line join (right)
    context.beginPath();
    context.moveTo(canvas.width / 2 - 50 + 140, canvas.height - 50); // line 1
    context.lineTo(canvas.width / 2 + 140, 50); // line 1
    context.lineTo(canvas.width / 2 + 50 + 140, canvas.height - 50); // line 1
    context.lineWidth = 25;
    context.lineJoin = "bevel";
    context.stroke();
};

效果图:

clip_image010

 

context.arcTo(controlX,controlY,endX,endY,radius);

//制作圆弧拐角

window.onload = function(){
    var canvas = document.getElementById("myCanvas");
    var context = canvas.getContext("2d");
 
    var rectWidth = 200;
    var rectHeight = 100;
    var rectX = canvas.width / 2 - rectWidth / 2;
    var rectY = canvas.height / 2 - rectHeight / 2;
 
    var cornerRadius = 50;
 
    context.beginPath();
    context.moveTo(rectX, rectY);
    context.lineTo(rectX + rectWidth - cornerRadius, rectY);
    context.arcTo(rectX + rectWidth, rectY, rectX + rectWidth,
        rectY + cornerRadius, cornerRadius);
    context.lineTo(rectX + rectWidth, rectY + rectHeight);
 
    context.lineWidth = 5;
    context.stroke();
};

效果图:

clip_image012

 

 

context.closePath();

//完成一条封闭的图案

window.onload = function(){

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

var context = canvas.getContext("2d");

context.beginPath(); // begin custom shape

context.moveTo(170, 80);

context.bezierCurveTo(130, 100, 130, 150, 230, 150);

context.bezierCurveTo(250, 180, 320, 180, 340, 150);

context.bezierCurveTo(420, 150, 420, 120, 390, 100);

context.bezierCurveTo(430, 40, 370, 30, 340, 50);

context.bezierCurveTo(320, 5, 250, 20, 250, 50);

context.bezierCurveTo(200, 5, 150, 20, 170, 80); //注意这里的170,80必须和起点一样

context.closePath(); // complete custom shape

context.lineWidth = 5;

context.strokeStyle = "#0000ff";

context.stroke();

};

效果图:

clip_image014

 

 

context.fillStyle=[value];

context.fill();

//这两个要连在一起用,为封闭的曲线上色

比如

context.fillStyle = "#8ED6FF";

context.fill();

 

context.rect(topLeftCornerX,topLeftCornerY,width,height);

//画矩形,需要给出左上角坐标和高宽

 

context.arc(centerX,centerY,radius,0,2*Math.PI,false);

//画圆,圆心(centerX, centerY),半径为radius,从0角度开始,2pi角度,顺时针画

 

该代码都是从http://www.html5canvastutorials.com/ copy过来的,仅仅做了一些翻译和注释

强烈推荐这个网站作为学习html5 canvas的站点。

笔者也刚开始学习html5,这篇是学习笔记

 

参考文档:

http://baike.baidu.com/view/951383.htm#2_3

http://www.html5canvastutorials.com/tutorials/html5-canvas-element/

http://www.w3school.com.cn/html5/html5_canvas.asp

 

 

作者:yjf512(叶剑峰)

出处:http://www.cnblogs.com/yjf512/

本文版权归yjf512和cnBlog共有,欢迎转载,但未经作者同意必须保留此段声明

目录
相关文章
|
2月前
|
移动开发 前端开发 JavaScript
HTML5 Canvas6
使用 `drawImage(image, x, y)` 方法可将图像放置在画布上。示例:将名为 &quot;The Scream&quot; 的图像放置到画布指定位置。代码如下: ```javascript var c=document.getElementById(&quot;myCanvas&quot;); var ctx=c.getContext(&quot;2d&quot;); var img=document.getElementById(&quot;scream&quot;); ctx.drawImage(img,10,10); ```
|
2月前
|
移动开发 前端开发 JavaScript
HTML5 Canvas4
Canvas 文本绘制简介:通过设置 `font` 属性定义字体样式,使用 `fillText(text,x,y)` 方法绘制实心文本,或使用 `strokeText(text,x,y)` 方法绘制空心文本。示例代码展示了如何使用 &quot;Arial&quot; 字体在画布上绘制 30px 高的文字。
|
2月前
|
移动开发 前端开发 JavaScript
HTML5 Canvas5
Canvas 的渐变功能允许在各种形状上(如矩形、圆形、线条和文本)应用自定义颜色渐变。通过 `createLinearGradient` 和 `createRadialGradient` 方法可分别创建线性和径向渐变。渐变需定义两个或更多颜色停止点,使用 `addColorStop` 方法设定。最后,将渐变对象赋值给 `fillStyle` 或 `strokeStyle` 并绘制形状即可实现渐变效果。
|
2月前
|
移动开发 前端开发 JavaScript
HTML5 Canvas3
Canvas是一个基于二维网格的绘图工具,其左上角坐标为(0,0)。通过`fillRect(0,0,150,75)`可在画布上从(0,0)开始绘制一个150x75的矩形。使用`moveTo(x,y)`和`lineTo(x,y)`可以定义线条的起始与结束位置,结合`stroke()`方法绘制线条。绘制圆形则需调用`arc(x,y,r,start,stop)`方法,并使用`stroke()`或`fill()`完成绘制。
|
2月前
|
移动开发 前端开发 JavaScript
HTML5 Canvas1
HTML5 `&lt;canvas&gt;` 元素用于通过脚本(如JavaScript)绘制图形,包括图表、图像等。它本身仅是图形容器,需结合脚本实现具体绘图功能,支持绘制矩形、圆形、文字及添加图片。各主流浏览器均支持此元素。示例代码展示了如何创建并设置画布的基本属性。
|
4月前
|
移动开发 前端开发 JavaScript
HTML5 Canvas详解及应用
HTML5 Canvas 允许通过 JavaScript 在网页上动态绘制图形、动画等视觉内容。首先在 HTML 中定义 `&lt;canvas&gt;` 元素,并通过 JavaScript 获取画布上下文进行绘制。常见方法包括绘制矩形、路径、圆形和文本,以及处理图像和创建动画效果。适用于游戏开发、数据可视化、图像编辑和动态图形展示等多种应用场景。需要注意性能优化、无状态绘制及自行处理事件等问题。
|
前端开发
HTML学习笔记(四) Canvas 下
HTML学习笔记(四) Canvas
87 0
|
前端开发 JavaScript 容器
HTML学习笔记(四) Canvas 上
HTML学习笔记(四) Canvas
110 0
|
Web App开发 移动开发 前端开发
|
JavaScript 前端开发
05.HTML5(canvas)
Title function drawRect() { var a = document.
852 0

相关实验场景

更多