HTML5 Холст
Элемент HTML <canvas>
используется для рисования графики на веб-странице.
Рисунок слева создан с <canvas>
. Он показывает четыре элемента: красный прямоугольник, градиентный прямоугольник,
Многоцветный прямоугольник и многоцветный текст.
Что такое HTML холст?
Элемент HTML <canvas>
используется для рисования графики, на лету, через JavaScript.
Элемент <canvas>
является только контейнером для графики. Для рисования графики необходимо использовать JavaScript.
Canvas имеет несколько методов для рисования контуров, прямоугольников, кругов, текста и добавления изображений.
Поддержка браузера
Номера в таблице указывают первую версию обозревателя, полностью поддерживающую элемент <canvas>
.
Element | |||||
---|---|---|---|---|---|
<canvas> | 4.0 | 9.0 | 2.0 | 3.1 | 9.0 |
Примеры холста
Холст — это прямоугольная область на HTML-странице. По умолчанию холст не имеет границ и не содержит содержимого.
Разметка выглядит следующим:
<canvas id="myCanvas" width="200" height="100"></canvas>
Note: Always specify an id
attribute (to be referred to in a script),
and a width
and height
attribute to define the size of the canvas. To add a border, use the style
attribute.
Here is an example of a basic, empty canvas:
Example
<canvas id="myCanvas" width="200" height="100"
style="border:1px solid
#000000;">
</canvas>
Рисование линии
Example
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.moveTo(0, 0);
ctx.lineTo(200, 100);
ctx.stroke();
Рисование окружности
Пример
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.beginPath();
ctx.arc(95, 50, 40, 0, 2 * Math.PI);
ctx.stroke();
Рисование текста
Example
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.font = "30px Arial";
ctx.fillText("Hello World", 10, 50);
Текст обводки
Example
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.font = "30px Arial";
ctx.strokeText("Hello World", 10, 50);
Рисование линейного градиента
Пример
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
// Create gradient
var grd = ctx.createLinearGradient(0, 0, 200, 0);
grd.addColorStop(0, "red");
grd.addColorStop(1, "white");
// Fill with gradient
ctx.fillStyle = grd;
ctx.fillRect(10, 10, 150, 80);
Рисование кругового градиента
Example
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
// Create gradient
var grd = ctx.createRadialGradient(75, 50, 5, 90, 60, 100);
grd.addColorStop(0, "red");
grd.addColorStop(1, "white");
// Fill with gradient
ctx.fillStyle = grd;
ctx.fillRect(10, 10, 150, 80);
Рисование изображения
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
var img = document.getElementById("scream");
ctx.drawImage(img, 10, 10);
Справочник по холсту HTML
Чтобы узнать все о HTML <canvas>
, посетите наш полный справочник HTML холст.