Maison > interface Web > Tutoriel H5 > Tutoriel d'exemple de dessin sur toile HTML5

Tutoriel d'exemple de dessin sur toile HTML5

PHPz
Libérer: 2017-04-23 10:20:39
original
1707 Les gens l'ont consulté

Cet article explique en détail comment utiliser le dessin HTML5 Canvas à des fins de référence et d'apprentissage par les internautes chinois PHP

Tout d'abord, veuillez noter : l'élément <canvas> est non utilisé par certains anciens navigateurs pris en charge, mais est pris en charge par Firefox 1.5+, Opera 9+, les versions plus récentes de Safari, Chrome et Internet Explorer 9.

Besoin d'obtenir un 2D contexte de rendu avant de dessiner< ;canvas>Element

var canvas = document.getElementById('canvas');var ctx = canvas.getContext('2d');
Copier après la connexion

<span style="font-family: verdana, Arial, Helvetica, sans-serif;">Canvas dessine des images en fonction de l'état . <code><span style="font-family: verdana, Arial, Helvetica, sans-serif;">Canvas是基于状态绘制图像的。</span>

Utilisation de base :
1. Utilisez les deux méthodes suivantes pour définir un chemin

context.moveTo(x,y); //起点context.lineTo(x,y); //连线到终点
Copier après la connexion

2 . Pour plusieurs chemins, si vous souhaitez les traiter séparément, vous devez ajouter les deux méthodes suivantes au début et à la fin de la définition du chemin pour les séparer

context.beginPath();
context.closePath();
Copier après la connexion

3. style

context.lineWidth    //定义线条宽度context.strokeStyle    //定义线条颜色context.fillStyle    //填充颜色context.stroke();    //绘制线条context.fill();        //绘制填充的颜色块
Copier après la connexion

4. Dessiner l'arc


context.arc(
    centerx, centery, radius,    //圆心坐标(x,y)以及半径r
    startingAngle, endingAngle,    //开始的弧度值,和结束的弧度值
    anticlockwise = false        //可选参数,(false顺时针绘制)还是(true逆时针绘制))
Copier après la connexion

5. Dessinez un rectangle


context.rect(x, y, width, height); //设置矩形状态context.fill();
context.stroke();//或者context.fillRect(x, y, width, height); //绘制填充的矩形context.strokeRect(x, y, width, height); //绘制边框的矩形
Copier après la connexion

6. fillStyle et StrokeStyle


#FFF
#333rgb(255,128,0)
rgba(100,100,100,0.8)
hsl(20,62%,28%)
hsla(40,83%,33%,0.6)
red
Copier après la connexion

7. Line Cap : lineCap
est utilisé pour définir le forme des deux extrémités de la ligne, Il y a les trois valeurs suivantes :


butt(default)    //默认缺省round    //圆头square    //方头context.lineCap = "round";
Copier après la connexion

8. La forme de l'intersection de lignes et lignes : lineJoin
Trois valeurs d'attribut :


miter(default)    //尖角bevel    //斜接round    //圆角context.lineJoin = "round";//当尖角很尖锐时,会出现lineJoin为bevel//此时跟另外一个属性有关:miterLimit,默认值是10//当在lineJoin为miter情况下,miterLimit大于10时,lineJoin会自动变成bevel
Copier après la connexion

9. Transformation d'image et sauvegarde d'état
Transformation d'image :


位移:translate(x,y);
旋转:rotate(deg);
缩放:scale(sx,sy);//保存当前图形状态:context.save();//恢复图形的所有状态:context.restore();//使用:context.save();
context.translate(x,y);
context.restore();
Copier après la connexion

10. Matrice de transformation


a    c    e
b    d    f0    0    1a水平缩放(1)
b水平倾斜(0)
c垂直倾斜(0)
d垂直缩放(1)
e水平位移(0)
f垂直位移(0)
即:默认时,该变换矩阵为单位阵//设置变换矩阵transform(a,b,c,d,e,f);//重置变换矩阵setTransform(a,b,c,d,e,f);
Copier après la connexion

11. Dégradé linéaire


var grd = context.createLinearGradient(xstart,ystart,xend,yend);//开始坐标到结束坐标grd.addColorStop(stop,color);//stop为浮点数,开始坐标点到结束坐标点直线上,某个位置(0.0~1.0之间)//例:var skyStyle = context.createLinearGradient(0,0,800,800);
skyStyle.addColorStop(0.0, 'black');
skyStyle.addColorStop(1.0, 'blue');

context.fillStyle = skyStyle;
Copier après la connexion

12. Dégradé radial


var grd = context.createRadialGradient(x0,y0,r0,x1,y1,r1);//开始圆心坐标到结束圆心坐标,以及半径grd.addColorStop(stop,color);//stop为浮点数,开始坐标点到结束坐标点直线上,某个位置(0.0~1.0之间)
Copier après la connexion

13. Remplissage de l'image


createPattern(img,repeat-style) //img为图片对象,repeat-style填充格式//其中repeat-style: no-repeat/repeat-x/repeat-y/repeat//例:var backgroundImage = new Image();
backgroundImage.src = "bg.jpg";
backgroundImage.onload = function(){var pattern = context.createPattern(backgroundImage,"repeat");
context.fillStyle = pattern;
context.fillRect(0,0,800,800);
}
Copier après la connexion

14.remplissage en toile


createPattern(canvas,repeat-style) //canvas对象,repeat-style填充格式
Copier après la connexion

Exemple :


    window.onload=function(){        var canvas=document.getElementById("canvas");
        canvas.width=800;
        canvas.height=800;        var context=canvas.getContext("2d");        var backCanvas=createBackgroundCanvas();        var pattern=context.createPattern(backCanvas,"repeat");
        context.fillStyle=pattern;
        context.fillRect(0,0,800,800);
   }    function createBackgroundCanvas(){        var backCanvas=document.createElement("canvas");
        backCanvas.width=100;
        backCanvas.height=100;        var backContext=backCanvas.getContext("2d");
        backContext.beginPath();
        backContext.moveTo(15,15);
        backContext.lineTo(50,50);
        backContext.lineWidth=10;
        backContext.strokeStyle="green";
        backContext.stroke();        return backCanvas;
    }
Copier après la connexion

15. Remplissage vidéo


createPattern(video,repeat-style) //video视频对象
Copier après la connexion

16. Une autre méthode de dessin d'arc


context.arcTo(
    x1,y1,x2,y2,    //x1,y1,x2,y2两个坐标与起始点x0,y0组成一个角
    radius    //半径)
Copier après la connexion

Exemple :


context.moveTo(x0,y0);
context.arcTo(x1,y1,x2,y2,R);//起始点为(x0,y0),该弧线与01线以及12线相切
Copier après la connexion

17. Courbe de Bézier
Courbe quadratique de Bézier

context.moveTo(x0, y0);    //起始点context.quadraticCurveTo(
    x1, y1,    //控制点坐标
    x2, y2    //终点坐标)
Copier après la connexion

Cubique de Bézier

context.moveTo(x0, y0);    //起始点context.bezierCurveTo(
    x1, y1, //控制点坐标
    x2, y2, //控制点坐标
    x3, y3  //终点坐标)
Copier après la connexion

18. Rendu du texte

context.font = "font-style font-variant font-weight font-size font-family";    //css字体样式,默认值:"20px sans-serif"context.fillText(String, x, y, [maxlen]);    //String字符串,和坐标位置,第四个为可选参数,这行文字的最长宽度context.strokeText(String, x, y, [maxlen]);    

font-style: normal    (Default)
            italics   (斜体字)
            oblique   (倾斜字体)

font-variant: normal  (Default)
              small-caps    (小写英文字母变成小的大写字母)

font-weight: normal   (Default)
             lighter
             bold
             bolder             100,200,300,400(normal)             500,600,700(bold)             800,900font-size:  20px (Default)
            2em            150%font-family: 设置多种字体备选,支持@font-face
Copier après la connexion

Alignement horizontal du texte :


context.textAlign = left
                    right
                    center
Copier après la connexion

Alignement vertical du texte :


context.textBaseline =  top
                        middle
                        bottom
                        alphabetic (Default)
                        ideographic
                        hanging
Copier après la connexion

Mesures du texte :


context.measureText(String).width //获取渲染的字符串的宽度
Copier après la connexion

19. Ombre

context.shadowColor    //阴影颜色context.shadowOffsetX    //阴影的位移值context.shadowOffsetY
context.shadowBlur    //阴影模糊度
Copier après la connexion

20. Méthode globale :

context.globalAlpha = 1 (Default)    //全局透明度,默认不透明context.globalCompositeOperation = "source-over" (Default) //绘制的图像在重叠的时候的效果,默认是(source-over)后面绘制的图像覆盖前面绘制的图像"source-atop"    //后面绘制的图像覆盖前面绘制的图像,但后面的图像只显示重叠部分"source-in"    //后面绘制的图像覆盖前面绘制的图像,但只显示重叠部分"source-out"    //只显示后绘制的图像,而且重叠部分被切掉"destination-over"    //前面绘制的图像覆盖后面绘制的图像"destination-atop"    //前面绘制的图像覆盖后面绘制的图像,但前绘制的图像只显示重叠部分"destination-in"    //前面绘制的图像覆盖后面绘制的图像,但只显示重叠部分"destination-out"    //只显示前绘制的图像,而且重叠部分被切掉"lighter"    //重叠部分颜色叠加融合"copy"    //只显示后绘制图像"xor"    //异或,重叠部分被挖空
Copier après la connexion

21. .Clip Area
Méthode pour définir le chemin actuellement créé comme chemin de détourage actuel

void ctx.clip();void ctx.clip(fillRule);void ctx.clip(path, fillRule);
Copier après la connexion

fillRule

Cet algorithme détermine si un point est Dans le chemin ou hors du chemin.

chemin
Le chemin Path2D à couper.

Exemple :

ctx.arc(100, 100, 75, 0, Math.PI*2, false);
ctx.clip();
ctx.fillRect(0, 0, 100,100);
Copier après la connexion

22. Principe d'emballage non nul
Direction du chemin
Application : Effet papier découpé creux
23. Interaction sur le canevas

context.clearRect(x,y,width,height) //清空指定的区域context.isPointInPath(x,y) //点击检测函数,该点是否在当前规划路径内,当检测点包含在当前或指定的路径内,返回 true;否则返回 false//以下两个是获取鼠标点击在canvas坐标var x = event.clientX - canvas.getBoundingClientRect().left;var y = event.clientY - canvas.getBoundingClientRect().top;
Copier après la connexion

24. Étendre le contexte de Canvas
Étendre la méthode drawStar au contexte :

CanvasRenderingContext2D.prototype.drawStar = function(){}
Copier après la connexion

25. Compatibilité Canvas
Détection

<canvas id="canvas">当前浏览器不支持Canvas,请更换浏览器再试</canvas>
Copier après la connexion

Problèmes de compatibilité entre Canvas et les navigateurs IE6, 7 et 8

Présentation de la bibliothèque explorecanvas :

https://code.google.com/p/explorecanvas/<!--[if IE]><script type="text/javascript" src="../excanvas.js"></script><![endif]-->
Copier après la connexion

26. bibliothèque graphique de toile : canvasplus || artisanJS || RGraph

code.google.com/p/canvasplus

artisanjs.com

roopons.com.au/wp-content/plugins/viral-optins/js/rgraph

27. Document d'interface de l'API Canvas :

developer.mozilla.org/zh-CN/docs/Web/API/CanvasRenderingContext2D

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal