ebook img

Разработка игр на языке JavaScript. PDF

128 Pages·2016·0.826 MB·Russian
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Разработка игр на языке JavaScript.

С. А. БЕЛЯЕВ РАЗРАБОТКА ИГР НА ЯЗЫКЕ JAVASCRIPT Учебное пособие •САНКТ(cid:7)ПЕТЕРБУРГ• •МОСКВА•КРАСНОДАР• 2016 ББК 32.973.26(cid:27)018.1я73 Б 43 Беляев С. А. Б 43 Разработка игр на языке JavaScript: Учебное по(cid:27) собие.— СПб.: Издательство «Лань», 2016.— 128с.: ил.— (Учебники для вузов. Специальная литера(cid:27) тура). ISBN 978(cid:15)5(cid:15)8114(cid:15)1980(cid:15)7 Учебное пособие рассматривает ключевые вопросы разработ(cid:27) ки однопользовательских двумерных игр на языке JavaScript. Пособие построено в практическом ключе, когда в отдельных гла(cid:27) вах осуществляется поэтапная разработка различных элементов игры. Впособии не выделена отдельная глава для изучения основ JavaScript, его элементы разбираются в процессе изложения ос(cid:27) новного материала с объяснением базовых особенностей. Читате(cid:27) лю будет легче воспринимать учебное пособие, если он уже вла(cid:27) деет JavaScript, но достаточно владеть любым языком програм(cid:27) мирования. Учебное пособие предназначено для бакалавров и магистров, обучающихся по направлениям «Программная инженерия» и «Прикладная математика и информатика», а также может быть полезно широкому кругу читателей, интересующихся разработ(cid:27) кой современных интернет(cid:27)приложений. ББК 32.973.26(cid:27)018.1я73 Рецензенты: И. И. ХОЛОД— кандидат технических наук, доцент кафедры вычислительной техники СПбГЭТУ «ЛЭТИ»; С. А. ИВАНОВСКИЙ— кандидат технических наук, доцент, зав. кафедрой математического обеспечения и применения ЭВМ СПбГЭТУ «ЛЭТИ». Обложка Е. А. ВЛАСОВА © Издательство «Лань», 2016 © С.А.Беляев, 2016 © Издательство «Лань», © художественное оформление, 2016 ВВЕДЕНИЕ Современные технологии разработки интернет(cid:7)прило(cid:7) жений шагнули далеко вперед. Можно найти множество учебников, посвященных HTML, CSS, JavaScript ит.п. Все они подробно описывают различные элементы язы(cid:7) ков и могут использоваться в качестве справочников, од(cid:7) нако для их успешного применения необходимо иметь опыт проектирования и разработки приложений. Вдан(cid:7) ном учебном пособии не только описываются элементы языка программирования, но и приводится множество практических примеров, позволяющих решать реальные задачи. Аизучение на основании реальных задач, когда видишь результат, гораздо эффективнее, чем решение не(cid:7) интересных, но очень полезных учебных примеров. Прин(cid:7) ципы построения игры, описанные в данном учебном по(cid:7) собии, могут быть с минимальными изменениями распро(cid:7) странены на другие языки программирования. JavaScript во многих аспектах проще для начального изучения программирования, чем другие языки, но он име(cid:7) ет особенности, отличающие его от классических объект(cid:7) но(cid:7)ориентированных языков, таких как Java, C++, C# ит.п. Тем не менее, он вполне может быть первой сту(cid:7) пенькой в изучении реального программирования. Владе(cid:7) ние языком JavaScript дает существенные преимущества при разработке приложений для Интернета, так как боль(cid:7) шинство современных браузеров поддерживают JavaScript и без его использования достаточно сложно создать привле(cid:7) 4 Введение кательный сайт или интернет(cid:7)приложение. Альтернати(cid:7) вами могут служить, например, Adobe Flash или Microsoft Silverlight, но для своей работы они требуют установки дополнительных надстроек браузера, без которых их ис(cid:7) пользование невозможно. Учебное пособие состоит из семи глав. Каждая глава заканчивается вопросами для самопроверки и упражне(cid:7) ниями для закрепления материала. Впервой главе описываются базовые элементы HTML для подключения JavaScript на веб(cid:7)странице и отображе(cid:7) ния графики, рассматриваются основы языка, которые будут использованы в учебном пособии. Вторая глава посвящена загрузке, обработке и отобра(cid:7) жению игровой карты. Вней читатель познакомится с воз(cid:7) можностями построения как карт, умещающихся на од(cid:7) ном экране, так и карт, которые выходят за рамки одного экрана, без снижения эффективности обработки незави(cid:7) симо от размеров игрового поля. Втретьей главе рассматривается эффективная загруз(cid:7) ка изображений для визуального представления объектов игры, при этом обрабатываются несколько рисунков, объе(cid:7) диненных в один. Четвертая глава описывает взаимодействие с пользо(cid:7) вателем, обработку событий, полученных от клавиатуры и мыши. Отдельное внимание уделено общепринятым под(cid:7) ходам к обработке событий в игровых приложениях. Впятой главе рассматривается реализация физики поведения объектов игры. В шестой главе приведено построение менеджера игры, который объединяет в себе управление всеми ее элемен(cid:7) тами. Седьмая глава посвящена звуку. Главы строятся по принципу последовательной разра(cid:7) ботки, поэтому в каждой новой главе вводится необходи(cid:7) мый функционал в объекты, разработанные на предыду(cid:7) щих страницах. Рекомендуется последовательное изуче(cid:7) ние материала. Взаключении приводятся возможные направления дальнейшего развития описанных решений. ГЛАВА 1 БАЗОВЫЕ ЭЛЕМЕНТЫ ЯЗЫКА 1.1. ПЕРВАЯ HTML(cid:19)СТРАНИЦА JavaScript является скриптовым языком, который ис(cid:7) пользуется в рамках HTML (от англ. HyperText Markup Language), поэтому для успешной разработки на JavaScript необходимы базовые знания HTML. Простейшая HTML(cid:7)страница может быть отображена с использованием следующего кода: (cid:2)(cid:3)(cid:4)(cid:5)(cid:6)(cid:7)(cid:8)(cid:9)(cid:10)(cid:11)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) (cid:2)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) (cid:11)(cid:2)(cid:12)(cid:17)(cid:18)(cid:19)(cid:16) (cid:11)(cid:2)(cid:13)(cid:20)(cid:13)(cid:15)(cid:17)(cid:16)(cid:21)(cid:22)(cid:23)(cid:24)(cid:25)(cid:26)(cid:11)(cid:27)(cid:28)(cid:23)(cid:25)(cid:29)(cid:30)(cid:31)(cid:25)(cid:2) (cid:13)(cid:20)(cid:13)(cid:15)(cid:17)(cid:16) (cid:11)(cid:2)(cid:14)(cid:17)(cid:13)(cid:18)(cid:11)!(cid:12)(cid:18)"#(cid:17)(cid:13)$%&(cid:7)’()%(cid:16) (cid:11)(cid:2) (cid:12)(cid:17)(cid:18)(cid:19)(cid:16) (cid:11)(cid:2)*+(cid:19),(cid:16) (cid:11)-(cid:22)(cid:27)(cid:28).(cid:24)(cid:25)(cid:26)(cid:11)(cid:27)(cid:28)(cid:23)(cid:25)(cid:29)(cid:30)(cid:31)(cid:25) (cid:11)(cid:2) *+(cid:19),(cid:16) (cid:2) (cid:12)(cid:13)(cid:14)(cid:15)(cid:16) Здесь строка (cid:2)(cid:3)(cid:4)(cid:5)(cid:6)(cid:7)(cid:8)(cid:9)(cid:10)(cid:11)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) показывает, что мы используем HTML пятой версии (HTML5), теги (cid:2)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) и (cid:2) (cid:12)(cid:13)(cid:14)(cid:15)(cid:16) обрамляют тело страницы, содержащей раздел с заголовком (от <(cid:12)(cid:17)(cid:18)(cid:19)(cid:16)(cid:11)до (cid:2) (cid:12)(cid:17)(cid:18)(cid:19)(cid:16)) и основное тело (от (cid:2)*+(cid:19),(cid:16) до (cid:2) *+(cid:19),(cid:16)). Теги (cid:2)(cid:13)(cid:20)(cid:13)(cid:15)(cid:17)(cid:16) и (cid:2) (cid:13)(cid:20)(cid:13)(cid:15)(cid:17)(cid:16) предназначены для указания заголовка, отображаемого в закладке браузера. Конструкция, содержащая открывающий и закрывающий теги, например, /(cid:2)(cid:13)(cid:20)(cid:13)(cid:15)(cid:17)(cid:16)(cid:21)(cid:22)(cid:23)(cid:24)(cid:25)(cid:26)(cid:11)(cid:27)(cid:28)(cid:23)(cid:25)(cid:29)(cid:30)(cid:31)(cid:25)(cid:2) (cid:13)(cid:20)(cid:13)(cid:15)(cid:17)(cid:16)0 называет(cid:7) ся элементом. Тег (cid:2)(cid:14)(cid:17)(cid:13)(cid:18)(cid:16) в данном примере с помощью 6 Глава 1 атрибута charset указывает кодировку, использованную для написания страницы (вданном примере это %&(cid:7)’()%, но в случае создания файла в Windows, скорее всего, будет использована кодировка «Windows(cid:7)1251»). Если сохра(cid:7) нить приведенный код HTML(cid:7)страницы в файле с расши(cid:7) рением «.html», например, first.html, то его можно будет открыть с помощью любого браузера. Если кодировка ука(cid:7) зана не правильно, то пользователь не сможет прочитать русский текст, это означает, что следует изменить коди(cid:7) ровку. HTML— богатый язык, который позволяет отобра(cid:7) жать большое количество элементов. Врамках учебного пособия будут использованы только некоторые из них, необходимые и достаточные для создания однопользова(cid:7) тельских двумерных интернет(cid:7)игр. Для браузеров, не под(cid:7) держивающих HTML5, можно использовать тег (cid:2)(cid:19)(cid:20)1(cid:16), ко(cid:7) торый сам по себе без применения специальных настроек не отображается, но с помощью атрибута style предстает перед пользователем в самых разных видах. Данный ат(cid:7) рибут требует от разработчика знания языка разметки CSS (от англ. Cascading Style Sheets), который активно исполь(cid:7) зуется для стилизации информации на HTML(cid:7)страницах. Начиная с HTML пятой версии поддерживается гиб(cid:7) кий элемент canvas, позволяющий отображать графику. Простейший пример включения элемента canvas в HTML(cid:7) страницу: (cid:2)(cid:3)(cid:4)(cid:5)(cid:6)(cid:7)(cid:8)(cid:9)(cid:10)(cid:11)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) (cid:2)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) (cid:2)(cid:12)(cid:17)(cid:18)(cid:19)(cid:16) (cid:2)(cid:13)(cid:20)(cid:13)(cid:15)(cid:17)(cid:16)2(cid:28).(cid:23)(cid:25)(cid:26)(cid:11)(cid:27)(cid:28)(cid:23)(cid:25)(cid:29)(cid:30)(cid:31)(cid:25)(cid:2) (cid:13)(cid:20)(cid:13)(cid:15)(cid:17)(cid:16) (cid:2)(cid:14)(cid:17)(cid:13)(cid:18)(cid:11)!(cid:12)(cid:18)"#(cid:17)(cid:13)$%&(cid:7)’()%(cid:16) (cid:2) (cid:12)(cid:17)(cid:18)(cid:19)(cid:16) (cid:2)*+(cid:19),(cid:16) (cid:2)!(cid:18)31(cid:18)#(cid:11)(cid:20)(cid:19)$%!(cid:18)31(cid:18)#4(cid:19)%(cid:11)5(cid:20)(cid:19)(cid:13)(cid:12)$%)66%(cid:11)(cid:12)(cid:17)(cid:20)7(cid:12)(cid:13)$%866%(cid:11)#(cid:13),(cid:15)(cid:17)$ %*+"(cid:19)(cid:17)"9:;<(cid:11)#+(cid:15)(cid:20)(cid:19)(cid:11)*(cid:15)(cid:18)!=>%(cid:16) (cid:11)2(cid:25)?(cid:11)@(cid:23)(cid:25)AB(cid:22)(cid:23)(cid:11)(cid:29)(cid:22)(cid:11)C.DD(cid:22)(cid:23)E(cid:30)(cid:24)(cid:25)(cid:22)(cid:28)(cid:11)FG(cid:22)H(cid:22)(cid:29)(cid:28)(cid:11)!(cid:18)31(cid:18)# (cid:11)(cid:2) !(cid:18)31(cid:18)#(cid:16) (cid:11)(cid:2) *+(cid:19),(cid:16) (cid:2) (cid:12)(cid:13)(cid:14)(cid:15)(cid:16) Базовые элементы языка 7 Вданном примере открывающий тег (cid:2)!(cid:18)31(cid:18)#(cid:16) имеет несколько атрибутов: id— идентификатор, который ис(cid:7) пользуется для уникального обозначения элемента на стра(cid:7) нице (элементов может быть множество), width указыва(cid:7) ет его начальную ширину, height— высоту, style— стиль отображения (CSS). При сохранении приведенного кода в HTML и открытии в браузере будет отображена страница с прямоугольником, нарисованным черным цветом, ко(cid:7) нечно, если браузер поддерживает canvas. Дело в том, что данный элемент языка выделяет на экране область, в ко(cid:7) торую будет выводиться графика, но по умолчанию canvas пустой. Соответственно, если удалить атрибут style, со(cid:7) здающий сплошную (solid) рамку (border) толщиной в 1пиксел (1px) черного цвета (black), то страница ока(cid:7) жется совершенно пустой. Мы будем называть canvas— холст. Следует отметить, что HTML и JavaScript одинаково обрабатывают одинарные и двойные кавычки, т.е. поме(cid:7) стить атрибут в одинарные кавычки— это то же самое, что поместить его в двойные кавычки. Работа с холстом подробно описана в[1]–[4]. 1.2. ОТОБРАЖЕНИЕ ПРЯМОЙ НА ХОЛСТЕ Для взаимодействия с холстом требуется знание Java(cid:7) Script (рис.1.1). Программирование на JavaScript подроб(cid:7) но описано в[5], [6]. Рис. 1.1 Отображение прямой в canvas 8 Глава 1 (cid:2)(cid:3)(cid:4)(cid:5)(cid:6)(cid:7)(cid:8)(cid:9)(cid:10)(cid:11)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) (cid:2)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) (cid:2)*+(cid:19),(cid:16) (cid:2)!(cid:18)31(cid:18)#(cid:11)(cid:20)(cid:19)$%!(cid:18)31(cid:18)#4(cid:19)%(cid:11)5(cid:20)(cid:19)(cid:13)(cid:12)$%I66%(cid:11)(cid:12)(cid:17)(cid:20)7(cid:12)(cid:13)$%:66% #(cid:13),(cid:15)(cid:17)$%*+"(cid:19)(cid:17)"9:;<(cid:11)#+(cid:15)(cid:20)(cid:19)(cid:11)*(cid:15)J(cid:17)>%(cid:16)(cid:2) !(cid:18)31(cid:18)#(cid:16) (cid:2)#!"(cid:20);(cid:13)(cid:16) (cid:11)K@(cid:23)(cid:25)L(cid:22)(cid:29)(cid:30)(cid:22)(cid:11)M(cid:11)!(cid:18)31(cid:18)# 1(cid:18)"(cid:11)!(cid:18)31(cid:18)#(cid:11)$(cid:11)(cid:19)+!J(cid:14)(cid:17)3(cid:13)N7(cid:17)(cid:13)(cid:10)(cid:15)(cid:17)(cid:14)(cid:17)3(cid:13)O,4(cid:19)P%!(cid:18)31(cid:18)#4(cid:19)%Q> 1(cid:18)"(cid:11)!(cid:13)<(cid:11)$(cid:11)!(cid:18)31(cid:18)#N7(cid:17)(cid:13)(cid:6)+3(cid:13)(cid:17)<(cid:13)P%R(cid:19)%Q>(cid:11) (cid:11)K@(cid:23)(cid:25)L(cid:22)(cid:29)(cid:30)(cid:22)(cid:11)M(cid:11)M.(cid:29)(cid:28)(cid:22)M(cid:27)(cid:28)A !(cid:13)<N(cid:14)+1(cid:17)(cid:7)+PS6T(cid:11)U6Q>(cid:11) (cid:11)(cid:21)(cid:22)(cid:23)(cid:22)H(cid:22)L(cid:22)(cid:29)(cid:30)(cid:22)(cid:11)MA(cid:23)(cid:27).(cid:23)(cid:25) !(cid:13)<N(cid:15)(cid:20)3(cid:17)(cid:7)+P:66T(cid:11)S6Q>(cid:11) (cid:11)V.BD(cid:25)(cid:29)(cid:30)(cid:22)(cid:11)G(cid:30)(cid:29)(cid:30)(cid:30) !(cid:13)<N#(cid:13)"+=(cid:17)PQ>(cid:11) (cid:11)K(cid:28).@(cid:23)(cid:25)E(cid:22)(cid:29)(cid:30)(cid:22)(cid:11)G(cid:30)(cid:29)(cid:30)(cid:30) (cid:2) #!"(cid:20);(cid:13)(cid:16) (cid:2) *+(cid:19),(cid:16) (cid:2) (cid:12)(cid:13)(cid:14)(cid:15)(cid:16) Код JavaScript должен быть описан в рамках элемента script. Обращение к холсту может выглядеть следующим образом: 1(cid:18)"(cid:11)!(cid:18)31(cid:18)#(cid:11)$(cid:11)(cid:19)+!J(cid:14)(cid:17)3(cid:13)N7(cid:17)(cid:13)(cid:10)(cid:15)(cid:17)(cid:14)(cid:17)3(cid:13)O,4(cid:19)P%!(cid:18)31(cid:18)#4(cid:19)%Q> Здесь ключевое слово var используется для обозначе(cid:7) ния переменной, за ключевым словом следует имя пере(cid:7) менной, в нашем случае— canvas. Язык JavaScript под(cid:7) держивает «произвольное» именование переменных, но рекомендуется давать осмысленные названия, чтобы в дальнейшем разработчик не запутался, что обозначает каждая переменная. Встроенная переменная document указывает на DOM(cid:7) модель HTML(cid:7)страницы. Изучение DOM(cid:7)модели выходит за рамки данного учебного пособия. Достаточно знать, что вызов функции getElementById с указанием в качестве параметра идентификатора элемента с HTML(cid:7)страницы позволяет получить доступ к этому элементу. Вданном случае— доступ к элементу canvas с идентификатором "canvasId". Спомощью переменной canvas можно осуществлять настройки элемента canvas, например, изменить его раз(cid:7) меры, параметры отображения графики и т.п. Но, соб(cid:7) Базовые элементы языка 9 ственно, для доступа к 2D графике необходимо создать еще одну переменную: 1(cid:18)"(cid:11)!(cid:13)<(cid:11)$(cid:11)!(cid:18)31(cid:18)#N7(cid:17)(cid:13)(cid:6)+3(cid:13)(cid:17)<(cid:13)P%R(cid:19)%Q> Спомощью ключевого слова var создается переменная ctx (обычно ее называют «контекст»), в которую сохраня(cid:7) ется результат вызова функции getContext с параметром "2d" у переменной canvas. Теперь создано все необходимое для отображения гра(cid:7) фики. !(cid:13)<N(cid:14)+1(cid:17)(cid:7)+PS6T(cid:11)U6Q> Спомощью функции moveTo курсор перемещается в заданные координаты. Здесь необходимо обратить внима(cid:7) ние, что левый верхний угол имеет координаты (0,0), уве(cid:7) личение первой координаты— движение по горизонтали вправо, увеличение второй координаты— движение по вертикали вниз. Функция moveTo не приводит к появле(cid:7) нию видимых линий. !(cid:13)<N(cid:15)(cid:20)3(cid:17)(cid:7)+P:66T(cid:11)S6Q> Спомощью функции lineTo курсор перемещается с ото(cid:7) бражением линии в заданные координаты. !(cid:13)<N#(cid:13)"+=(cid:17)PQ> Функция stroke делает видимой созданную линию— рисует контур (см. рис.1.1). Важно отметить, что JavaScript различает большие и маленькие буквы, поэтому var— это ключевое слово, а Var, VAR, vaR и vAr такими не являются. 1.3. ОТОБРАЖЕНИЕ ПРЯМОУГОЛЬНИКА И ЗИГЗАГА Настройка холста подразумевает задание таких пара(cid:7) метров, как ширина и высота, шрифт текста, типы ли(cid:7) ний, цвет и т.п. (рис.1.2). (cid:2)(cid:3)(cid:4)(cid:5)(cid:6)(cid:7)(cid:8)(cid:9)(cid:10)(cid:11)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) (cid:2)(cid:12)(cid:13)(cid:14)(cid:15)(cid:16) (cid:2)*+(cid:19),(cid:16) (cid:2)!(cid:18)31(cid:18)#(cid:11)(cid:20)(cid:19)$%!(cid:18)31(cid:18)#4(cid:19)%(cid:11)5(cid:20)(cid:19)(cid:13)(cid:12)$%I66%(cid:11)(cid:12)(cid:17)(cid:20)7(cid:12)(cid:13)$%:66% 10 Глава 1 #(cid:13),(cid:15)(cid:17)$%*+"(cid:19)(cid:17)"9:;<(cid:11)#+(cid:15)(cid:20)(cid:19)(cid:11)(cid:14)(cid:18)7(cid:17)3(cid:13)(cid:18)>%(cid:16)(cid:2) !(cid:18)31(cid:18)#(cid:16) (cid:2)(cid:19)(cid:20)1(cid:11)(cid:20)(cid:19)$%"(cid:17)#J(cid:15)(cid:13)%(cid:16)(cid:2) (cid:19)(cid:20)1(cid:16) (cid:2)#!"(cid:20);(cid:13)(cid:16) 1(cid:18)"(cid:11)!(cid:18)31(cid:18)#(cid:11)$(cid:11)(cid:19)+!J(cid:14)(cid:17)3(cid:13)N7(cid:17)(cid:13)(cid:10)(cid:15)(cid:17)(cid:14)(cid:17)3(cid:13)O,4(cid:19)P%!(cid:18)31(cid:18)#4(cid:19)%Q> 1(cid:18)"(cid:11)!(cid:13)<(cid:11)$(cid:11)!(cid:18)31(cid:18)#N7(cid:17)(cid:13)(cid:6)+3(cid:13)(cid:17)<(cid:13)P%R(cid:19)%Q> !(cid:18)31(cid:18)#N5(cid:20)(cid:19)(cid:13)(cid:12)(cid:11)$(cid:11)R66>(cid:11) (cid:11)W(cid:27)(cid:28)(cid:25)(cid:29).(cid:24)(cid:30)(cid:28)X(cid:11)?(cid:30)(cid:23)(cid:30)(cid:29)A(cid:11)(cid:24)(cid:11)R66(cid:11)C(cid:30)M(cid:27)(cid:22)G.(cid:24) !(cid:18)31(cid:18)#N(cid:12)(cid:17)(cid:20)7(cid:12)(cid:13)(cid:11)$(cid:11)Y6>(cid:11) (cid:11)W(cid:27)(cid:28)(cid:25)(cid:29).(cid:24)(cid:30)(cid:28)X(cid:11)(cid:24)Z(cid:27).(cid:28)A(cid:11)(cid:24)(cid:11)Y6(cid:11)C(cid:30)M(cid:27)(cid:22)G.(cid:24) !(cid:13)<N#(cid:13)"+=(cid:17)[(cid:13),(cid:15)(cid:17)(cid:11)$(cid:11)%7"(cid:17)(cid:17)3%>(cid:11) (cid:11)W(cid:27)(cid:28)(cid:25)(cid:29).(cid:24)(cid:30)(cid:28)X(cid:11)(cid:31)(cid:24)(cid:22)(cid:28)(cid:11)G(cid:30)(cid:29)(cid:30)(cid:30)(cid:11)((cid:11)B(cid:22)G(cid:22)(cid:29)Z\ !(cid:13)<N](cid:20)(cid:15)(cid:15)[(cid:13),(cid:15)(cid:17)(cid:11)$(cid:11)%*(cid:15)J(cid:17)%>(cid:11) (cid:11)W(cid:27)(cid:28)(cid:25)(cid:29).(cid:24)(cid:30)(cid:28)X(cid:11)(cid:31)(cid:24)(cid:22)(cid:28)(cid:11)B(cid:25)G(cid:30)(cid:24)M(cid:30)(cid:11)^(cid:30)_A(cid:23)Z(cid:11)( (cid:11)(cid:27)(cid:30)(cid:29)(cid:30)\ !(cid:13)<N#(cid:12)(cid:18)(cid:19)+5O(cid:15)J"(cid:11)$(cid:11):6>(cid:11) (cid:11)W(cid:27)(cid:28)(cid:25)(cid:29).(cid:24)(cid:30)(cid:28)X(cid:11)(cid:23)(cid:25)BH(cid:22)(cid:23)(cid:11)(cid:28)(cid:22)(cid:29)(cid:30)(cid:11)((cid:11):6(cid:11)C(cid:30)M(cid:27)(cid:22)G.(cid:24) !(cid:13)<N#(cid:12)(cid:18)(cid:19)+5(cid:6)+(cid:15)+"(cid:11)$(cid:11)%*"+53%>(cid:11) (cid:11)W(cid:27)(cid:28)(cid:25)(cid:29).(cid:24)(cid:30)(cid:28)X(cid:11)(cid:31)(cid:24)(cid:22)(cid:28)(cid:11)(cid:28)(cid:22)(cid:29)(cid:30)(cid:11)( (cid:11)M.(cid:23)(cid:30)‘(cid:29)(cid:22)(cid:24)Z\ (cid:11)K(cid:28).@(cid:23)(cid:25)E(cid:22)(cid:29)(cid:30)(cid:22)(cid:11)C(cid:23)(cid:26)H.A_.GX(cid:29)(cid:30)M(cid:25)(cid:11)P<T(cid:11),T(cid:11)?(cid:30)(cid:23)(cid:30)(cid:29)(cid:25)T(cid:11)(cid:24)Z(cid:27).(cid:28)(cid:25)Q !(cid:13)<N"(cid:17)!(cid:13)P:6T(cid:11)I6T(cid:11))6T(cid:11)a6Q> !(cid:13)<N](cid:20)(cid:15)(cid:15)PQ>(cid:11) (cid:11)b(cid:25)C.G(cid:29)(cid:30)(cid:28)X(cid:11)(cid:31)(cid:24)(cid:22)(cid:28).H !(cid:13)<N#(cid:13)"+=(cid:17)PQ>(cid:11) (cid:11)K(cid:28).@(cid:23)(cid:25)B(cid:30)(cid:28)X(cid:11)M.(cid:29)(cid:28)A(cid:23) (cid:2) #!"(cid:20);(cid:13)(cid:16) (cid:2) *+(cid:19),(cid:16) (cid:2) (cid:12)(cid:13)(cid:14)(cid:15)(cid:16) Рис. 1.2 Отображение прямоугольника в canvas Здесь canvas.width позволяет проверять или устанав(cid:7) ливать значение ширины элемента canvas, canvas.height позволяет аналогично работать с высотой. При работе с контекстом (переменная ctx) есть возможность настраи(cid:7) вать цвет линии (strokeStyle), цвет заполнения фигуры (fillStyle), размер тени (shadowBlur), цвет тени (shadow(cid:19) Color), с помощью функции rect(x, y, ширина, высота) ото(cid:7) бражать прямоугольники и заполнять их цветом— функ(cid:7) ция fill().

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.