JavaScript. Подробное руководство, 6-е издание, стр. 365

<b>peekhole.addColorStop(0.0, &quot;transparent&quot;); // Прозрачный</b>

<b>peekhole.addColorStop(0.7, &quot;rgba(100,100,100,.9)&quot;); // Полупрозрачный серый </b>

<b>peekhole.addColorStop(1.0, &quot;rgba(0,0,0,0)&quot;); // Опять прозрачный</b>

Важно понимать, что градиенты тесно связаны с местоположением в холсте. При создании градиента вы указываете его границы. Если после этого попытаться выполнить заливку области за этими границами, будет использован сплошной цвет, соответствующий одному или другому концу градиента. Если, к примеру, вы определите градиент вдоль линии, соединяющей точки (0,0) и (100, 100), этот градиент можно будет использовать только для заливки объектов, находящихся внутри прямоугольной области (0,0,100,100).

Рисунок, изображенный на рис. 21.10, был создан с использованием шаблона pattern и градиентов bgfade и peekhole с помощью следующего программного кода:

<b>c.fillStyle = bgfade; // Сначала использовать линейный градиент</b>

<b>с.fillRect(0,0,600,600); // Залить весь холст</b>

<b>с.strokeStyle = pattern; // Использовать шаблон для рисования линий</b>

<b>c.lineWidth = 100; // Очень толстые линии</b>

<b>с.strokeRect(100,100,400,400); // Нарисовать большой квадрат</b>

<b>c.fillStyle = peekhole; // Использовать радиальный градиент</b>

<b>с.fillRect(0,0,600,600); // Покрыть холст этой полупрозрачной заливкой</b>

21.4.8. Атрибуты рисования линий

Вы уже знакомы со свойством

<b>lineWidth</b>
, которое определяет толщину линий, рисуемых методами
<b>stroke()</b>
и strokeRect
<b>()</b>
. Кроме свойства
<b>lineWidth</b>
(и конечно же,
<b>strokeStyle</b>
) существует еще три графических атрибута, влияющих на рисование линий.

По умолчанию свойство

<b>lineWidth</b>
имеет значение 1, и ему можно присвоить любое положительное целое число, и даже дробное число меньше 1. (Линии толщиной менее одного пиксела рисуются полупрозрачными цветами, поэтому они выглядят менее темными по сравнению с линиями толщиной в 1 пиксел). Чтобы полностью понять действие свойства
<b>lineWidth</b>
, представьте контур как комбинацию бесконечно тонких одномерных линий. Прямые линии и кривые, рисуемые методом
<b>stroke(),</b>
центрируются по этому контуру, выступая на половину
<b>lineWidth</b>
в обе стороны. Если при рисовании замкнутого контура необходимо, чтобы видимы были только части линий за пределами контура, нарисуйте сначала контур, а затем залейте его непрозрачным цветом, чтобы скрыть части линий, которые вторгаются внутрь контура. Или, если необходимо, чтобы видимы были только части линий внутри замкнутого контура, вызовите сначала методы
<b>save()</b>
и
<b>clip()</b>
(раздел 21.4.10), а затем методы
<b>stroke()</b>
и
restore().

Из-за имеющейся возможности изменять масштаб по осям координат, как показано на рис. 21.7, толщина линий зависит от текущего преобразования. Если выполнить вызов

<b>scale(2,1),</b>
чтобы изменить масштаб по оси X и оставить нетронутым масштаб по оси Y, вертикальные линии будут получаться в два раза толще горизонтальных, нарисованных с одним и тем же значением свойства
<b>lineWidth</b>
. Важно понимать, что толщина линий определяется значением свойства
<b>lineWidth</b>
и текущим преобразованием, имевшимися на момент вызова метода
<b>stroke(),</b>
а не на момент вызова метода
<b>lineТо()</b>
или другого метода конструирования контура.

Три других атрибута рисования линий определяют внешний вид несоединенных концов контура и вершин, где соединяются два фрагмента контура. Они оказывают весьма несущественное влияние на внешний вид тонких линий, но обеспечивают существенные отличия при рисовании толстых линий. Действие двух этих свойств иллюстрируется изображением на рис. 21.11. Здесь контур показан как тонкая черная линия, а результат рисования линий - как окружающая ее серая область.

JavaScript. Подробное руководство, 6-е издание - i_063.jpg

Свойство

<b>lineCap</b>
определяет, как будут выглядеть концы незамкнутых фрагментов контуров. Значение «butt» (по умолчанию) соответствует завершению линий непосредственно в конечной точке. При значении «square» линия будет продолжена за конечную точку на половину толщины и будет иметь квадратный конец. А при значении «round» линия будет продолжена за конечную точку на половину толщины и будет иметь закругленный конец (с радиусом закругления в половину толщины линии).

Свойство

<b>lineJoin</b>
определяет внешний вид вершин, соединяющих фрагменты контура. По умолчанию это свойство имеет значение «miter», при котором внешние края линий двух фрагментов контура будут продолжены, пока они не встретятся. При значении «round» вершины получают закругленную форму, а при значении «bevel» вершины обрезаются прямыми линиями.

Последнее свойство, связанное с рисованием линий, - это свойство

<b>miterLimit</b>
, которое используется, только когда свойство
<b>lineJoin</b>
имеет значение «miter». Когда две линии соединяются под острым углом, сопряжение между ними может оказаться довольно протяженным, и эти протяженные сопряжения могут нарушать визуальную гармонию. Свойство
<b>miterLimit</b>
определяет верхнюю границу протяженности сопряжений. Если сопряжение в некоторой вершине оказывается длиннее половины длины линии, умноженной на значение
<b>miterLimit</b>
, эта вершина будет нарисована с обрезанным сопряжением.

21.4.9. Текст

Для рисования текста в холсте обычно используется метод

<b>fillText()</b>
, который рисует текст, используя цвет (градиент или шаблон), определяемый свойством
<b>fillStyle</b>
. Если необходимо использовать специальные эффекты при выводе текста крупными символами, для рисования контуров отдельных символов можно применить метод
<b>strokeText()</b>
(пример вывода контуров символов приводится на рис. 21.13). Оба метода принимают в первом аргументе текст, который требуется нарисовать, и координаты X и Y вывода текста во втором и третьем аргументах. Ни один из этих методов не вносит изменений в текущий контур и не смещает текущую точку. Как видно на рис. 21.7, при выводе текста учитывается текущее преобразование системы координат.