Чтение онлайн

на главную - закладки

Жанры

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

//У' = У + ку*х;

function shear(c, кх, ку) { с.transform(1, ку, кх, 1, 0, 0); }

// Вращение на theta радиан по часовой стрелке вокруг точки (х,у). Это преобразование

// можно выполнить с помощью последовательности вызовов методов translate,rotate,translate

function rotateAbout(c,theta,x,у) {

var ct = Math.cos(theta),

st = Math.sin(theta);

c.transform(ct, -st, st, ct, -x*ct-y*st+x, x*st-y*ct+y);

}

Метод

setTransform
принимает те же аргументы, что и метод
transform,
но вместо преобразования текущей системы координат он выполняет преобразование системы координат по умолчанию и делает результат новой текущей системой координат. Метод
setTransform
удобно использовать для временного возврата к системе координат по умолчанию:

c.save; // Сохранить текущую систему координат

с.setTransform(1,0,0,1,0,0): // Вернуться к системе координат по умолчанию

// Выполнить операции с использованием координат по умолчанию CSS-пикселов

c.restore; // Восстановить сохраненную систему координат

21.4.4.2. Примеры преобразований

Пример 21.6 демонстрирует мощь, которую дает возможность преобразования системы координат, где за счет рекурсивного применения методов

translate, rotate
и
scale
реализовано рисование фракталов - снежинок Коха. Результат работы этого примера представлен на рис. 21.8, где показаны снежинки Коха с количеством уровней рекурсии 0, 1, 2, 3 и 4.

Эти фигуры воспроизводятся весьма изящным программным кодом, но в нем используются рекурсивные преобразования системы координат, что делает его сложным для понимания. Даже если вы не собираетесь углубляться в изучение всех тонкостей примера, обратите все же внимание, что в нем имеется всего один вызов метода

lineTo
. Каждый отдельный сегмент на рис. 21.8 рисуется следующим образом:

с.lineТо(len, 0);

Значение переменной

len
не изменяется в ходе выполнения программы, поэтому позиция, ориентация и длина каждой линии определяется операциями смещения, вращения и масштабирования.

Пример 21.6. Рисование снежинок Коха посредством преобразований системы координат

var deg = Math.PI/180; // Для преобразования градусов в радианы

// Рисует n-уровневый фрактал снежинки Коха в контексте холста с, левый нижний угол

// которого имеет координаты (х,у), а длина стороны равна len.

function snowflake(c, п, х, у, len) {

c.saveO; // Сохранить текущее преобразование

с.translated,у); // Сместить начало координат в начальную точку

с.moveTo(0,0); // Новый фрагмент контура в новом начале координат

leg(n); // Нарисовать первую ветвь снежинки

с.rotate(-120*deg); // Поворот на 120 градусов против часовой стрелки

leg(n); // Нарисовать вторую ветвь

с.rotate(-120*deg); //Поворот

leg(n); // Нарисовать последнюю ветвь

с.closePath; // Замкнуть фрагмент контура

c.restoreO; // Восстановить прежнее преобразование

// Рисует одну ветвь n-уровневой снежинки Коха. Эта функция оставляет

// текущую позицию в конце нарисованной ветви и смещает начало координат так,

// что текущая точка оказывается в позиции (0,0).

// Это означает, что после рисования ветви можно вызвать rotate.

function leg(n) {

c.save; // Сохранить текущее преобразование

if (n == 0) { // Нерекурсивный случай:

с.lineTo(len, 0); // Просто нарисовать горизонтальную линию

} //

else { // Рекурсивный случай: 4 подветви вида: \/

с.scale(1/3,1/3); // Подветви в 3 раза меньше этой ветви

leg(n-1); // Рекурсия для первой подветви

с.rotate(60*deg); // Поворот на 60 градусов по часовой стрелке

leg(n-1); // Вторая подветвь

с.rotate(-120*deg); // Поворот на 120 градусов назад

leg(n-1); // Третья подветвь

Поделиться:
Популярные книги

Бандит

Щепетнов Евгений Владимирович
1. Петр Синельников
Фантастика:
фэнтези
7.92
рейтинг книги
Бандит

Бастард Императора. Том 3

Орлов Андрей Юрьевич
3. Бастард Императора
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Бастард Императора. Том 3

Граф

Ланцов Михаил Алексеевич
6. Помещик
Фантастика:
альтернативная история
5.00
рейтинг книги
Граф

Газлайтер. Том 1

Володин Григорий
1. История Телепата
Фантастика:
попаданцы
альтернативная история
аниме
5.00
рейтинг книги
Газлайтер. Том 1

Хозяин Стужи 3

Петров Максим Николаевич
3. Злой Лед
Фантастика:
аниме
фэнтези
попаданцы
7.00
рейтинг книги
Хозяин Стужи 3

Дважды одаренный. Том VII

Тарс Элиан
7. Дважды одаренный
Фантастика:
аниме
фэнтези
попаданцы
5.00
рейтинг книги
Дважды одаренный. Том VII

Развод в 45. От любви до ненависти

Гофман Крис
6. Развод
Любовные романы:
остросюжетные любовные романы
5.40
рейтинг книги
Развод в 45. От любви до ненависти

Имперец. Том 3

Романов Михаил Яковлевич
2. Имперец
Фантастика:
боевая фантастика
попаданцы
альтернативная история
7.43
рейтинг книги
Имперец. Том 3

Паладин из прошлого тысячелетия

Еслер Андрей
1. Соприкосновение миров
Фантастика:
боевая фантастика
попаданцы
6.25
рейтинг книги
Паладин из прошлого тысячелетия

Мечник Вернувшийся 1000 лет спустя

Ткачев Андрей Юрьевич
1. Вернувшийся мечник
Фантастика:
аниме
фэнтези
попаданцы
5.00
рейтинг книги
Мечник Вернувшийся 1000 лет спустя

Чужак из ниоткуда 2

Евтушенко Алексей Анатольевич
2. Чужак из ниоткуда
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Чужак из ниоткуда 2

Наша навсегда

Зайцева Мария
2. Наша
Любовные романы:
современные любовные романы
эро литература
5.00
рейтинг книги
Наша навсегда

Хозяин Теней

Петров Максим Николаевич
1. Безбожник
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Хозяин Теней

Кодекс Крови. Книга Х

Борзых М.
10. РОС: Кодекс Крови
Фантастика:
фэнтези
юмористическое фэнтези
попаданцы
аниме
5.00
рейтинг книги
Кодекс Крови. Книга Х