Maison > interface Web > Tutoriel H5 > Explication détaillée du canevas HTML5 (5)

Explication détaillée du canevas HTML5 (5)

黄舟
Libérer: 2017-03-17 15:50:31
original
1509 Les gens l'ont consulté

drawImage propose trois méthodes :

1. Positionnez l'image sur la toile.

context.drawImage(img,x,y);
Copier après la connexion

2. Positionnez l'image sur la toile et précisez la largeur et la hauteur de l'image.

context.drawImage(img,x,y,width,height);
Copier après la connexion

3. Recadrez l'image et positionnez la partie recadrée sur la toile.

context.drawImage(img,sx,sy,swidth,sheight,x,y,width,height);
Copier après la connexion

    参数描述
    img规定要使用的图像、画布或视频。
    sx开始剪切图像的 x 坐标位置。
    sy开始剪切图像的 y 坐标位置。
    swidth被剪切图像的宽度。
    sheight被剪切图像的高度。
    x在画布上放置图像的 x 坐标位置。
    y在画布上放置图像的 y 坐标位置。
    width要绘制的图像的宽度。(伸展或缩小图像)
    height要绘制的图像的高度。(伸展或缩小图像)

Le code suivant contient les trois méthodes ci-dessus pour dessiner des images sur une toile :

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>canvas绘图</title>
    <script>
    window.onload = function()
    {
        drawCanvas1();
        drawCanvas2();
        drawCanvas3();
    }
    //context.drawImage(img,x,y);
    function drawCanvas1()
    {
        var canvas = document.getElementById("myCanvas1");
        var context = canvas.getContext("2d");
        //将图片绘制到canvas上
        var img = new Image();
        img.src = "1.jpg";
        img.onload = function()
        {
            context.drawImage(img, 0, 0);
        };

        context.textAlign = "center";
        context.fillText("context.drawImage(img,x,y)画原图", 250, 350);
    }

    //context.drawImage(img,x,y,width,height);
    function drawCanvas2()
    {
        var canvas = document.getElementById("myCanvas2");
        var context = canvas.getContext("2d");
        //将图片绘制到canvas上
        var img = new Image();
        img.src = "1.jpg";
        img.onload = function()
        {
            context.drawImage(img, 0, 0, 500, 300);
        };

        context.textAlign = "center";
        context.fillText("context.drawImage(img,x,y,width,height)指定宽和高进行拉伸和缩放", 250, 350);
    }

    //context.drawImage(img,sx,sy,swidth,sheight,x,y,width,height);
    function drawCanvas3()
    {
        var canvas = document.getElementById("myCanvas3");
        var context = canvas.getContext("2d");
        //将图片绘制到canvas上
        var img = new Image();
        img.src = "1.jpg";
        img.onload = function()
        { 
            context.drawImage(img, 200,100, 200, 200, 0, 0, 200, 200);
        };

        context.textAlign = "center";
        context.fillText("context.drawImage(img,sx,sy,swidth,sheight,x,y,width,height)", 250, 350);
        context.fillText("裁切图片的一部分绘制在画布上,并可进行缩放", 250, 370);
    }

    </script>
</head>
<body>
    <canvas id="myCanvas1" width="500" height="400" style="border:#F00 solid 1px">
        您的浏览器不支持canvas
    </canvas>
    <canvas id="myCanvas2" width="500" height="400" style="border:#F00 solid 1px">
        您的浏览器不支持canvas
    </canvas>
    <canvas id="myCanvas3" width="500" height="400" style="border:#F00 solid 1px">
        您的浏览器不支持canvas
    </canvas>
    <br />
</body>
</html>
Copier après la connexion

Effet comme suit :
Explication détaillée du canevas HTML5 (5)
La première image : context.drawImage(img, 0, 0) commence à dessiner à partir du canevas (0,0) et dessine la taille originale de l'image.
La deuxième image : context.drawImage(img, 0, 0, 500, 300) signifie qu'il commence à dessiner à partir du canevas (0,0), et précise que la largeur et la hauteur de l'image dessinée sont 500 et 300 respectivement, l'image originale sera étirée ou réduite.
La troisième image : context.drawImage(img, 200,100, 200, 200, 0, 0, 200, 200); signifie recadrer la partie d'une largeur et d'une hauteur de 200 et 200 respectivement à partir de la position (200,100) du image. Et placez-le à la position (0,0) du canevas et spécifiez la largeur et la hauteur de l'image dessinée comme 200 et 200 respectivement.

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