Введение в AppSalute Сreator — различия между версиями

Материал из wiki.appsalutecreator.com
Перейти к: навигация, поиск
(Z - порядок объектов)
 
(не показано 168 промежуточных версий 17 участников)
Строка 2: Строка 2:
 
  | width="40%"|[[Learning|Оглавление]] <<  
 
  | width="40%"|[[Learning|Оглавление]] <<  
 
  ! width="20%"|[[Learning|Оглавление]]  
 
  ! width="20%"|[[Learning|Оглавление]]  
  | width="40%" align="right"| >> [[Урок 1: Создание экранов, сцен. Работа с кнопками|Урок 1]]
+
  | width="40%" align="right"| >> [[Создание экранов, сцен. Работа с кнопками|Урок 2]]
 
|}
 
|}
 
----
 
----
 +
{{TOC right}}
 +
----
 +
'''Цель:'''
 +
познакомиться со средой разработки игр AppSalute Сreator.
  
'''§1. Интерфейс приложения SceneEditor'''
+
'''Задачи:'''  
+
* проинсталлировать AppSalute Сreator;
1. Вверху окна приложения расположены кнопки общего меню:
+
* открыть готовый проект в редакторе сцен;
 +
* освоить взаимодействие редактора сцен и редактора ресурсов;
 +
* изучить основные методы редактирования сцены.
  
[[Файл:00 1.PNG]]
 
  
2. Если нажать в меню кнопку Проект, выпадет список команд, с помощью которых можно создать новый или загрузить уже созданный проект, сохранить проект с указанием места сохранения и т.д.
+
== Введение ==
 +
Для начала работы с редактором его необходимо [[Установка и настройка|установить]], загрузив и запустив [[Downloads|инсталлятор]].
 +
По умолчанию все необходимые программы будут размещены '''C:\Program Files\AppSalute Creator''' и материалы для уроков находятся в папке '''Мои Документы\Absolutist\Projects\lessons'''. При желании её можно в дальнейшем перенести в любое удобное место.
 +
После инсталляции запускаем программу Scene Editor, найдя на рабочем столе или в списке приложений иконку:
  
[[Файл:00_2.PNG]]
+
[[Файл:icon_se.png]].
  
3. Если нажать в меню кнопку Дерево, выпадет список команд, с помощью которых можно добавить папку или экран в указаный луйаут, создать новый лайаут, копировать либо удалить элемент и т.д.
+
Для создания игр в AppSalute Сreator используются четыре взаимодействующих между собой приложения:
 +
* [[Файл:Ico_main.png|40px]] '''[[Интерфейс ScenceEditor|Scene Editor]]''' - редактор игровых сцен (экранов), в котором происходит настройка свойств объектов и игровой логики. Это основной инструмент при разработке игры.
 +
* [[Файл:Ico_base.png|40px]] '''[[Редактор ресурсов|Resources Editor]]''' - хранилище медиа-ресурсов (картинки, звуки, видео, анимация), использующихся в игре. Эти ресурсы при помощи мышки перетаскиваются на сцену в Scene Editor.
 +
* [[Файл:Ico_text.png|40px]] '''[[Интерфейс TextEditor|Text Editor]]''' - хранилище всех текстовых ресурсов (надписей) на различных языках. Аналогично графике и звукам при помощи мышки они перетаскиваются в соответствующие свойства объектов, находящихся в Scene Editor. См. также [[Редактор текстовых ресурсов|Урок 6]]
 +
* '''Viewer''' - проигрыватель созданной игры. Обычно запускается непосредственно из Scene Editor. Вы увидите, возможно сыграете, игру в том же виде, как и на любом мобильном устройстве.
  
[[Файл:00 3.png]]
+
[[Файл:Layout.png|right]]
 +
Игра состоит из набора '''экранов'''. На каждом экране может находиться одна или несколько '''сцен'''.
 +
Например, пусть на экране находится игровое поле и панель с интерфейсными кнопками. Эти две области можно оформить при помощи различных сцен. Первая сцена содержит игровые '''объекты''' редактора, например миниигры такие как puzzle и фоновую картинку. Вторая сцена содержит базовые элементы управления (кнопки, чекбоксы), универсальные машины состояний (программирующие логику) и т.д.
  
4. Обозначения значков:
+
Так как игра обычно запускается на различных устройствах (телефон, планшетник, десктоп), важным понятием является '''лейаут''' (layout). Лейаут - размещение элементов игры на экране. Так как мониторы имеют разное разрешение в пикселях и разное соотношение высоты и ширины, для них нужны  разные варианты размещения игровых объектов и интерфейса. Если игра проектируется для разных устройств, должны поддерживаться несколько лейаутов.
  
[[Файл:00 6.png]] — команда создать Новый проект; [[Файл:00 7.png]] — команда загрузить уже созданый проект;
+
[[Файл:lesson_1_layouts.png|400px]]
  
[[Файл:00 8.png]] — сохранить изменения в проекте; [[Файл:00 9.png]] — команда запуска Viewer;
+
В качестве примера справа на рисунке представлена структура некоторого проекта в лейауте с размерами экрана устройства 960x640 пикселей. На этом лейауте находятся экраны, из которых только один экран (pack1) развернут. Внутри него находятся 2 сцены (stg_list1 и stg_main1). Одна сцена (stg_list1) раскрыта и содержит три игровых объекта. Последний из них (tbk_pack1) является сложным объектом, содержащим несколько других.
 +
Таким образом, игровой проект можно представить как '''дерево''', на различных ветках которого находятся игровые объекты.
  
[[Файл:00 10.png]] — перемещение сцен мышью; [[Файл:00 11.png]] — нормальный вид;
+
== Редактор сцен ==
  
[[Файл:00 12.png]] — найти объект по имени; [[Файл:00 13.png]] — общая информация, показывает общие свойства объекта;
+
=== Открытие проекта ===
 
+
[[Файл:00_13a.PNG]] — вызов редактора ресурсов напрямую из редактора сцен; [[Файл:00_13b.PNG]] - анализирование используемых ресурсов.
+
Шаг первый.  
 +
Вверху окна редактора расположено общее меню и кнопки быстрого запуска:
  
5. Справа вверху окна приложения расположена панель Проекта, в котором показано иерархическое дерево проекта с указанием размера лайаута, расположением всех его экранов, сцен и объектов.
+
[[Файл:Меню.png]]
  
[[Файл:00 4.png]]
+
Если нажать пункт меню <tt>Project</tt> (Проект), то выпадет список команд, с помощью которых можно [[Подготовка к работе "Создание проекта"|создать новый]] или загрузить уже созданный проект, сохранить проект с указанием места сохранения и т.д.
  
6. Справа внизу окна приложения расположена панель Свойства элемента с указанием всех модификаций конкретного объекта (например: тип, имя, положение, размер и т.д.)
+
Откроем проект, на основании которого будут проходиться эти уроки. Для этого нажмём в меню пункты <tt>Project</tt> &rarr; <tt>Open</tt> или сразу кнопку быстрого доступа [[Файл:Открыть проект.png]]. Заходим в папку '''Мои документы/Absolutist/Projects/Lessons'''.
 +
Внутри неё кликнем на файл '''lessons.seproj'''
  
[[Файл:00 5.png]]
+
[[Файл:Seproj.JPG|400px]].
  
'''§2. Интерфейс приложения ResourcesEditor'''
+
В результате откроется проект, визуальная часть которого окажется в основной (центральной) части редактора. Чтобы увидеть что-то кроме белого экрана, необходимо на панели Layout, которая находится в правой верхней части экрана, кликнуть мышкой на строчку с надписью '''lesson_1''' (это первый игровой экран приложения). В результате мы должны увидеть:
  
1. Вверху окна приложения расположены кнопки общего меню:
+
[[Файл:Экран.png|1000px]]
  
[[Файл:00 14.PNG]]
+
=== Свойства проекта ===
  
2. Если нажать в меню кнопку File, выпадет список команд, с помощью которых можно создать новый или загрузить уже созданный проект, создать проект по папке и выход (закрытие приложения).
+
В правой части окна редактора расположены две панели '''Layout''' (лейаут) и '''Properties''' (свойства).
 +
На панели Layout показано иерархическое дерево проекта, который пока состоит из одного игрового экрана lesson_1. Если кликнуть на стрелочку (или плюсик, или треугольник, в зависимости от Вашей ОС) слева от надписи lesson_1, то экран раскроется и мы увидим [[Проектирование_экранов_игры#Принципы_формирования_сцен_и_их_наполнения|сцену]], которая находится на [[Проектирование_экранов_игры|экране]]. Она называется lessons_1. Продолжая кликать на стрелочки, раскроем всю структуру этого проекта:
  
[[Файл:00 15.PNG]]
+
[[Файл:Лэйаут.png]]
  
3. Если нажать в меню кнопку View, выпадет список команд, с помощью которых можно указать расположение окна приложения ResourcesEditor всегда поверх других окон, просмотреть графический ресурс в окне приложения.
+
Наиболее простым объектом, находящимся в дереве проекта, является статическая картинка фона, которая называется '''bg'''. Если на неё кликнуть, то ниже в панели '''Properties''' можно увидеть параметры настройки этого объекта (его свойства):
  
[[Файл:00 16.PNG]]
+
[[Файл:Свойства.png]]
  
4. Если нажать в меню кнопку Project, выпадет список команд, с помощью которых можно создавать корневую базу графических ресурсов, добавлять изображения, анимацию, звуки, удалять ресурсы и т.д.
+
Стоит "пораскрывать" ветки настроек объекта bg, нажимая на стрелочки (или плюсики, или треугольники) слева от имен полей. Если навести мышкой на имя поля, то появится краткая подсказка, поясняющий смысл свойства.
  
[[Файл:00 17.PNG]]
+
Панели Layout и Properties могут перетаскиваться мышкой в произвольное место редактора,
 +
располагаться одна под другой или объединяться в одну панель с двумя закладками снизу.
 +
Если панели находятся одна под другой, можно мышкой изменить их относительную высоту. Для этого мышь располагаем между ними, пока она не изменит своей формы со стрелочки на сплиттер (две горизонтальные полоски). Затем, нажав на мышь, таскаем вверх-вниз границу между панелями.
  
5. Если нажать в меню кнопку Help → Online help подгружает через браузер статью Absolutist Framework [[http://ge.absolutist.com/index.php/Absolutist_Framework]]
+
=== Проигрывание проекта ===
  
[[Файл:00 17a.PNG]]
+
В процессе разработки игрового проекта, игру в любой момент можно запустить в отдельном окне вьювера ('''Viewer''') для проверки. Для этого в дереве проекта (панель Layout) необходимо выбрать интересующий нас экран (с которого произойдёт запуск) и нажать кнопку [[Файл:Play111.png]] (или пункт меню <tt>Viewer</tt> &rarr; <tt>Start Viewer</tt>).
  
6. Обозначения значков:
 
  
[[Файл:00 6.png]] — команда создать Новый проект; [[Файл:00 7.png]] — команда загрузить уже созданный проект;
+
[[файл:View.png]]
  
[[Файл:00 21.png]] — добавить новое изображение;  [[Файл:00 22.png]] — добавить новую анимацию;
 
  
[[Файл:00 23.png]] — добавить новый звук; [[Файл:00 18.png]] — создать новую папку в корневой базе;
+
В нашем случае мы увидим летающее над слонёнком солнышко. Оба объекта (и слонёнок, и солнышко) являются активными. Кликните сначала на голову слонёнка - она должна повернуться. Клик на тело слонёнка заставит его подпрыгнуть. При должной сноровке можно кликнуть также на летающее солнышко, что приведёт к кратковременному изменению его формы.
  
[[Файл:00 19.png]] — удалить ресурс.
+
Стоит запомнить три важных правила при работе с вьювером:
 +
* Если приложение редактировалось, то перед запуском вьювера проект необходимо <u>сначала</u> сохранить (меню: <tt>Project</tt> &rarr; <tt>Save Project</tt>).
 +
* Всегда необходимо перед запуском вьювера выбирать экран, который начнёт проигрываться (сейчас такой экран пока один).
 +
* После просмотра во вьювере игры, его необходимо закрыть, нажав (как обычно в Windows) крестик в правом верхнем углу окна.
  
'''§3. Копирование необходимых файлов'''
+
=== Кнопки быстрого запуска ===
  
Создать папку с названием проекта (например, Learning) → загрузить из ''Y:\!MOBILE\Hidden Object Editor\_All_Last_Builds'' редактор сцен SceneEditor, проигрыватель сцен Viewer, редактор ресурсов ResourcesEditor и папку Sources с исходниками графики для формирования базы графическмх ресурсов. Для ускорения работы редактора копируем все содержимое папки на локальный диск.
+
Приведем для справки описание кнопок быстрого доступа к некоторым командам редактора сцен (более подробная информация будет предоставлена в последующих уроках):
  
'''§4. Создание базы графических ресурсов'''
+
*[[Файл:00001.png]] — создать новый проект;
 +
*[[Файл:Открыть проект.png]] — открыть уже созданный проект;
 +
*[[Файл:00002.png]] — сохранить изменения в проекте;
 +
*[[Файл:00003.png]] — нормальный вид;
 +
*[[Файл:Play111.png]] —  запустить Viewer;
 +
*[[Файл:000004.png]] — запустить Viewer с изменением времени;
 +
*[[Файл:000005.png]] — очистить данные;
 +
*[[Файл:00006.png]] — вызов редактора ресурсов;
 +
*[[Файл:00007.png]] — вызов текстового редактора;
 +
*[[Файл:00008.png]] — анализ использованных ресурсов; 
 +
*[[Файл:00009.png]] — поиск объекта по имени или id;
 +
*[[Файл:0000010.png]] — общие свойства объекта.
  
1. Запустить редактор ресурсов ResourcesEditor. В меню File выбрать New Project.
 
  
[[Файл:00_24.PNG]]  [[Файл:00_25.PNG]]
+
== [[Редактор ресурсов]] ==
  
2. В окне базы создания ресурсов в строке "Папка проекта" указать путь на ранее созданную пустую папку Resources, затем в строке "Имя базы ресурсов" вписать имя корневой базы Learning_Base.
+
Второе важное приложение, это редактор ресурсов.
 +
Так как мы открыли готовый проект, то с ним уже связана база графических ресурсов.
 +
Чтобы её увидеть, нажмите кнопку [[Файл:00006.png|20px]] (или меню: <tt>Tools</tt> &rarr; <tt>Resources Editor</tt>).
 +
Откроется новое окно, которое, на самом деле, является независимым приложением:
  
[[Файл:00_26.PNG]]
+
[[Файл:Редактор ресурсов111.png]]
  
3. В корневой базе создать папку Create New Folder (например, папка Lesson_01).
+
Как и в редакторе сцен, вверху окна редактора ресурсов расположено меню и кнопки быстрого доступа: создать базу ресурсов, открыть уже существующую, показать экспорт последних объектов, сохранить изменения в редакторе ресурсов, добавить картинку (png, jpeg), добавить картинку из папки, добавить анимацию, мелодию (mp3, ogg), видео (mp4).
 +
Ниже, в левой панели, находятся папки, внутри которых можно найти различные графические ресурсы, которые мы будем использовать на протяжении этих уроков. Каждая папка названа по имени урока.
 +
Кликнув на стрелочку (или плюсик, или треугольник) слева от папки lesson_1 мы увидим текстовый список из 8 картинок, находящихся в ранее запущенном приложении со слоненком и солнышком.
  
[[Файл:00 27.png]]
+
Если в дереве папок активна данная папка, то на правой панели мы видим список графических ресурсов в виде иконок. Если же в дереве кликнуть на имя конкретной картинки, то в правой панели она будет представлена в натуральную величину. Если кликнуть правой кнопкой мыши на конкретный ресурс отобразится всплывающее подменю, которое аналогично кнопкам быстрого доступа, за исключением одного пункта - <tt>Заменить изображение...</tt>. Замену изображений необходимо делать через всплывающее подменю.
  
4. Загрузить исходники графики из папки Sources → Lesson_01 (аналогична загрузка исходников графики для других уроков).  
+
Текущее приложение содержит фоновую картинку (bg), три картинки частей слонёнка (elephant_body, elephant_head_1, elephant_head_2) и 4 картинки с различным видом солнышка.  
  
[[Файл:00 28.png]] [[Файл:00_29.PNG]]
+
Так как редактор ресурсов является отдельным приложением, он может оказаться под окном редактора сцен. Это не всегда удобно, поэтому зайдем в пункт меню <tt>'''View'''</tt> редактора ресурсов и поставим галочку у пункта <tt>'''Always on Top'''</tt>. Теперь редактор ресурсов окажется поверх редактора сцен (как впрочем, и поверх всех остальных окон). Естественно, галочку можно в любой момент снять или свернуть окно редактора ресурсов.
  
В папке ресурсов Resources автоматически создается папка с корневой базой (в нашем случае Learning_Base), в которой автоматически появляются папка с графическими ресурсами Lesson_01 (для урока 1) и файл Learning_Base.sirx
+
Размер окна редактора ресурсов можно изменять мышкой, схватившись за правый нижний угол окна.
 +
Правую панель, которая выводит картинки, можно “перетащить” в любое место окна редактора ресурсов (для этого необходимо потянуть за её заголовок). Чтобы вернуть панель на фиксированное место, необходимо дважды кликнуть на её заголовке.
  
[[Файл:00 30.png]]
 
  
'''Внимание!''' ''- прямое изменение структуры файлов в папке Resources запрещено. Допускается работа только через редактор ресурсов (ResourcesEditor).''
+
== Редактирование сцены ==
  
5. В случае, если имеется уже готовая база ресурсов (а именно, структурированная папка), то можно использовать ее. Для этого нужно при создании новой базы в строке "Папка с графическими ресурсами" указать путь, где находится готовая база ресурсов.
+
=== Добавление на сцену ===
  
[[Файл:00_30a.PNG]] [[Файл:00_30b.PNG]]
+
Разберемся, как на сцену добавляются новые объекты. Предполагается, что мы одновременно видим окна обоих редакторов. Убедимся, что в панели проекта (Layout) редактора сцен активна текущая сцена lessons_1. Не путайте её с экраном lesson_1, находящимся выше. Рядом с каждым объектом в дереве ресурсов находится иконка, отражающая тип объекта. Рядом с экраном изображено, что-то похожее на фотоаппарат, а рядом со сценой - чистый лист бумаги.  
 +
 +
Нажав мышкой на иконку головы слонёнка в '''редакторе ресурсов''', перетащим её на сцену в '''редактор сцен''', где кнопку мышки отпустим:
  
'''§5. Работа в ResourcesEditor'''
 
  
* Графические ресурсы, которые можно загружать в ResourcesEditor, могут быть двух типов:
+
[[Файл:Add picture.png|800px]]
  
JPEG - изображение, не имеющее прозрачности. Может использоваться для "облегчения веса", в качестве фонового изображения или для паззла;
+
Теперь окно редактора ресурсов можно свернуть, чтобы оно не мешало.  
 +
На сцене мы видим одного полноценного слонёнка и отдельно парящую голову.
 +
В списке объектов (панель Layout) добавился объект elephant_head_2.
 +
Его имя по умолчанию совпадает с именем картинки в редакторе ресурсов.
 +
Если оно не достаточно точно выражает назначение этого объекта, то его '''необходимо'''
 +
изменить в панели Properties (предполагается, что на дереве объектов эта голова сейчас выбрана).
 +
Переименуем её, например, в elephant_ghost (дух слонёнка). Для этого кликнем справа от поля '''имя''' в панели Properties и введем новое название. После окончания редактирования нажимаем Enter. Одновременно с этим изменилось имя на дереве объектов (Layout).
 +
Стоит всегда придерживаться следующего правила:
  
PNG - может поддерживать прозрачность, произвольные границы изображения. Сохраняет высокое качество изображения.  
+
<blockquote>
 +
[[файл:Ok.png|right|32px]]
 +
'''Необходимо присваивать объектам в проекте осмысленные имена, отражающие их роль и функции. Это относится также к именам экранов и сцен.'''
 +
</blockquote>
  
Использование бордеров исключает появление артефактов вокруг png-изображений за счет добавления прозрачной области (в пикселях) по контуру. Это можно сделать, как локально, так для всех изображений:
+
Названия объектов могут повторяться, но это плохой тон. В частности, неудачным примером названий в этом проекте служат похожие имена экрана (lesson_1) и сцены (lessons_1). Плохое имя (move) у летающего солнышка (лучше было бы fly_sun).  
  
Для одного изображения: [[Файл:00_37.PNG]]
+
Обратим внимание, что добавленная голова имеет тип '''image''' (первое поле в панели Properties).
 +
Большинство объектов в начале имеют такой тип. Далее он меняется в зависимости от функциональности объекта (подробнее об этом в следующих уроках).
  
Для всех изображений: [[Файл:00_46.PNG]] [[Файл:00_47.PNG]]
+
<blockquote>
 +
[[файл:Ok.png|right|32px]]
 +
'''Совет''': Переименовывать объекты можно непосредственно в панели Layout, после двойного клика мышкой на имя этого объекта. Редактирование завершается нажатием клавиши Enter.
 +
</blockquote>
  
* Анимация загружается из любой папки с некоторым количеством файлов изображений.
+
=== Изменение положения ===
  
[[Файл:00_40.PNG]] [[Файл:00_41.PNG]]
+
На сцене вокруг добавленной головы находится <span style="color:#007700">зелёная прямоугольная рамка</span> (объект активен).  
 +
Если она <span style="color:#770000">красная</span>, необходимо кликнуть на объект (голову) и он станет активным.
 +
Заметим, что при клике на объекте меняется не только цвет рамки,
 +
но и активный объект на дереве объектов (Layout). Соответственно в панели Properties показываются его свойства.
 +
Стоит покликать на различные объекты на сцене и на дереве проекта, наблюдая одним глазом за их рамкой, а другим за панелями проекта и свойств. В заключение этого увлекательного упражнения необходимо снова сделать активной голову.
  
После загрузки анимации можно изменить ее параметры. Например, изменить скорость анимации (смены кадров) и зациклить, поставив галочку напротив Looped.
+
Активный объект можно таскать мышкой по экрану, задав ему требуемое положение (не оторвите только голову исходному слоненку). Стоит раскрыть свойство "'''положение'''" в панели Properties и понаблюдать, как при таскании головы меняются её координаты.
 +
Начало координат (точка x=0, y=0) расположено в центре сцены. Горизонтальная ось x направлена вправо, а вертикальная ось y - вниз. Если объект находится ниже центра сцены, он будет иметь положительное значение y, а если выше, то отрицательное.
 +
Естественно, положение объекта можно изменить и при помощи прямого редактирования полей '''x''', '''y''' свойства "'''положение'''". Перетащите голову в правый верхний угол сцены.
  
[[Файл:00_42.PNG]]
 
  
В левой части нижнего окна анимации находится список загруженных изображений, в правой - последовательность изображений (кадров), которые можно менять местами, добавлять/удалять, загружать в прямом/обратном порядке. Таким образом, можно "уменьшить вес" анимации за счет использования меньшего количества исходных изображений.
+
=== Модификаторы ===
  
[[Файл:00_43.PNG]] [[Файл:00_44.PNG]] [[Файл:00_45.PNG]]
+
Будем считать, что добавленная голова слона - это дух предков исходного слонёнка.
 +
Духу положено быть полупрозрачным. Это достигается изменением
 +
свойства '''alpha''' в группе '''модификаторы''' на панели свойств (Properties).
 +
Изменим исходное значение 1.00 (непрозрачен) на 0.5 (полупрозрачен).
 +
Значение alpha=0 соответствует полной невидимости объекта (возможно любое значение между 0 и 1).
 +
Обратим внимание, что десятичная точка является именно точкой, а не запятой, как всё ещё учат на 1/6 части суши. Впрочем, если в вашей операционной системе в языковых настройках стоит русский язык, Вы увидите привычную запятую, вместо десятичной точки.  
  
* Звуковые файлы, подгружаемые в ResourcesEditor, могут быть двух форматов:
+
Дополнительно в разделе '''модификаторы''' можно изменить угол ('''angle''') в градусах (поставьте, например -30)
 +
и масштаб картинки (поля '''scale x''' и '''scale y'''). Исходная картинка имеет единичный масштаб, т.е. на сцене выглядит также, как и в редакторе ресурсов. Если масштаб увеличить, то увеличится и картинка (это можно сделать независимо по ширине и высоте).
 +
Соответственно, значение меньшее 1 (но большее нуля) её уменьшит.
 +
Отрицательное значение масштаба переворачивает картинку. Задайте scale_x=-2 и scale_y=2.
 +
В результате должно получиться что-то типа:
  
mp3 - используется как ресурс для длинного звука mus. Звуки такого формата могут воспроизводиться только последовательно.
 
  
ogg - используется как ресурс для короткого звука snd (snd-звуки могут воспроизводиться параллельно) и для подключения голоса voice (если voice подключен к тексту, то воспроизводится последовательно). Имеет меньший объем, чем формат mp3.
+
[[Файл:Mod.png|800px]]
  
[[Файл:00_48.PNG]]
+
Заметим, что при сильном масштабировании (scale) могут появляться дефекты картинки (квадратики пикселей), поэтому злоупотреблять большими значениями, обычно, не стоит.
  
'''§6. Интерфейс приложения TextEditor'''
+
=== Z - порядок объектов ===
  
1. Вверху окна приложения расположены кнопки общего меню:
+
Пришло время посмотреть, что у нас получилось. Для этого сохраняем все изменения
 +
[[Файл:00 8.png]] (нажав кнопку Ok на выскочившем окошке).
 +
Затем запускаем вьювер [[Файл:00 9.png]]. Понаблюдаем за солнцем. Оно движется над фоновой
 +
картинкой "'''bg'''", но ''под'' головой духа слона (он должен, естественно, находится в верхней части сцены). Такая последовательность прорисовки связана с порядком объектов в дереве на панели Layout. Отрисовка происходит сверху вниз (сначала bg, затем move и т.д.). Это правило является иерархическим. Если на дереве находятся объекты, содержащие другие объекты, то сначала рисуется вся эта ветка дерева, а затем поверх неё рисуются нижележащие на дереве объекты на других ветках. Это же правило относится к последовательности рисования сцен. Если на экране несколько сцен, то они рисуются сверху вниз в соответствии с их порядком на дереве. Сама по себе сцена - это невидимый объект (контейнер). Поэтому, рисование сцены означает последовательное рисование всех объектов, которые в ней находятся.
  
[[Файл:00_38.PNG]]
+
Попробуем во вьювере кликнуть на солнце, когда оно оказывается под головой духа слона.
 +
Его форма не изменяется, так как картинка головы, хотя и является полупрозрачной, по умолчанию "обработать". Чтобы изменить ситуацию, закроем вьювер (крестик) и отредактируем поле свойства духа слоненка "пропускать клик" выбрав из соответствующего списка "пропустить" вместо "обработать". Закончив редактирование поля (нажав Enter), сохраняем проект [[Файл:00 8.png]] и снова запускаем вьювер [[Файл:00 9.png]].
 +
Теперь дух, как и положено астральным образованиям, пропускает клик сквозь себя.
  
2. Если нажать в меню кнопку File, выпадет список команд, с помощью которых можно создать новый или загрузить уже созданный проект, сохранить проект с указанием места сохранения и т.д.
+
Порядок рисования объектов можно изменить, перетащив их по дереву в панели Layout.
 +
Эта операция требует определенной сноровки. Наступим на имя объекта elephant_ghost и не отпуская мыши потащим его вверх. Когда он окажется на уровне объекта bg, отпустим мышь. Он станет подобъектом фона,
 +
что отобразится как сдвиг elephant_ghost вправо (у объекта фона bg слева появится стрелочка). Теперь снова схватим elephant_ghost и потащим чуть вниз и влево по дереву.
 +
Когда указатель мыши окажется между объектами bg и move, появится длинная горизонтальная полоска. В этот момент отпускаем мышь, и наш дух размещается между этими объектами.
  
[[Файл:00_39.PNG]]
+
Ниже на рисунке представлены оба варианта положения духа на дереве сцены (слева подобъект elephant_ghost в объекте bg, а справа равноправный с bg объект, но ниже по дереву и, следовательно, рисуемый позже):
  
3. Если нажать в меню кнопку Resource, выпадет список команд, с помощью которых можно добавить папку или экран в указаный луйаут, создать новый лайаут, копировать либо удалить элемент и т.д.
 
  
[[Файл:00 3.png]]
+
[[файл:El.png]]
 +
[[файл:El2.png]]
  
4. Обозначения значков:
+
С точки зрения отрисовки, оба эти варианта приведут к одинаковому результату.
 +
Проверьте это, потренировавшись в таскании, сохранении и запуске вьювера. Подумайте также, почему так происходит.
  
[[Файл:00 6.png]] — команда создать Новый проект; [[Файл:00 7.png]] — команда загрузить уже созданый проект;
+
=== Удаление объектов ===
  
[[Файл:00 8.png]] — сохранить изменения в проекте; [[Файл:00 9.png]] — команда запуска Viewer;
+
Откройте снова окно редактора ресурсов (скорее всего оно находится в свернутом состоянии в панели приложений). Расположите его над окном редактора сцен. Перетащите на сцену из папки lesson_1 какую-нибудь небольшую картинку (например, sun_1). Сверните редактор ресурсов. Новая картинка появилась на сцене и в дереве объектов панели Layout. Чтобы её удалить, нажмите правую кнопку мыши на объекте sun_1 в панели Layout. В вывалившемся меню выберете пункт '''Delete'''. Картинка исчезнет. Эквивалентно, объект можно удалить, кликнув на него в дереве и нажав на клавиатуре кнопку Del.
  
[[Файл:00 10.png]] — перемещение сцен мышью; [[Файл:00 11.png]] — нормальный вид;
+
Заметим, что если объект на сцене сделать активным (кликнув на него - зеленая рамка) и попытаться нажать Del, то ничего не произойдет. Сделано это умышленно. Дело в том, что при удалении уничтожается не только сам объект, но и все его подобъекты. Подобная иерархия видна только на дереве проекта.  
  
[[Файл:00 12.png]] — найти объект по имени; [[Файл:00 13.png]] — общая информация, показывает общие свойства объекта;
+
В качестве упражнения, поместите на сцену две картинки. Одну из них в дереве панели Layout перетащите на другую, сделав её подобъектом. Потаскайте мышкой по сцене обе картинки. Обратите внимание, что подобъект перемещается независимым образом. В тоже время при таскании корневого объекта начнут двигаться они оба. Координаты подобъекта задаются относительно его владельца. Поэтому при перемещении корневого объекта вместе с ним движутся и все подобъекты.
 +
Теперь удалите сразу оба объекта, сделав активным  на дереве корневой объект и нажав затем на кнопку Del (или при помощи правой кнопки мыши).
  
[[Файл:00_13a.PNG]] — вызов редактора ресурсов напрямую из редактора сцен; [[Файл:00_13b.PNG]] - анализирование используемых ресурсов.
 
  
5. Справа вверху окна приложения расположена панель Проекта, в котором показано иерархическое дерево проекта с указанием размера лайаута, расположением всех его экранов, сцен и объектов.
+
=== Другие объекты ===
  
[[Файл:00 4.png]]
+
На нашей сцене кроме картинок находятся еще два типа объектов - это кнопка и машина состояний. С кнопками мы будем работать уже на следующем [[Создание экранов, сцен. Работа с кнопками|уроке]], а машинам состояний посвящены сразу 3 урока, начиная с [[Checkbox как машина состояний|третьего]]. Пока наша задача состоит в их поиске в дереве проекта и первым знакомством с их свойствами.
  
6. Справа внизу окна приложения расположена панель Свойства элемента с указанием всех модификаций конкретного объекта (например: тип, имя, положение, размер и т.д.)
+
Кликнем на стрелочку слева от объекта move в панели Layout. Под ним раскроется подобъект с именем '''sun_1'''. Это кнопка. Сам же объект move является машиной состояния. Кроме указания соответствующего типа в панели Properties (посмотрите на него!), тип объекта помечается иконкой на дереве. Для машины - это шестеренка, а кнопка - это кнопка :).
  
[[Файл:00 5.png]]
+
Кликнув на объект '''sun_1''', рассмотрим его свойства в панели Properties. Кроме уже знакомых по картинке (тип=image) полей, появился ряд других. Например, раскроем стрелочку свойства "'''внешний вид'''". Там находятся несколько полей, из которых заполнены '''up''' и '''down'''. В них заданы имена картинок для изображения отжатой и нажатой кнопки. Как они там оказались выясним в следующем [[Создание экранов, сцен. Работа с кнопками|уроке]].
  
'''§7. Создание проекта'''
+
Рассмотрим теперь объект '''move'''. Не смотря на небольшое количество свойств, это один из самых универсальных и сложных объектов, позволяющих программировать динамическое поведение объектов и их логику. Чтобы краем глаза заглянуть на кухню этого процесса кликните на свойство '''states''', а затем на появившиеся три точки в этом поле. Выскочит следующее окошко:
  
1. Для создания нового игрового проекта необходимо запустить редактор сцен SceneEditor.
 
  
[[Файл:00_31.PNG]]
+
[[файл:Mov prop.png]]            [[файл:Move.png]]
  
2. В верхнем меню Проект выбрать Новый (т.е. создать новый проект).
+
Эта машина состояний, которая имеет одно состояние. В нём задана последовательность команд, которые управляют её движением по экрану. Сама машина в данном случае является невидимым объектом. Однако, она содержит в качестве подобъекта кнопку '''sun_1'''. Поэтому, когда машина move бегает по экрану, вместе с ней движется и кнопка. Клики на себя принимает кнопка, меняя при этом свой внешний вид. Несложно догадаться, что в результате получается солнышко.
  
[[Файл:00 32.png]]
 
  
3. В появившемся окне выбрать размер создаваемой сцены (для уроков используем Layout800x600).
+
== Упражнения ==
  
[[Файл:00 33.png]]
+
* Найдите две машины состояний, связанные со слонёнком, и попробуйте догадаться как они работают (ответы в следующих уроках).
 +
* Откройте демонстрационный проект, находящийся в папке AppSaluteСreator/Projects/Demo/demо. Поиграйтесь с ним.
 +
* Снова откройте учебный проект c которым мы работали (AppSaluteСreator/Projects/Lessons/lessons). Он нам понадобится для следующего урока.
 +
* Затем переходите на [[Создание экранов, сцен. Работа с кнопками|урок 2]].
  
4. В этом же окне нажимаем на значок с многоточием и в папке ресурсов (в нашем случае Resources) указать путь к файлу Learning_Base.sirx.
 
 
[[Файл:00 34.png]]
 
 
 
[[Файл:00 35.png]]
 
 
5. В редакторе сцен в меню Проект → Сохранить → проект Learning. Эту методику действий можно брать за шаблон для создания других проектов.
 
 
Результат: Создана база ресурсов и проект для выполнения Уроков.
 
 
[[Файл:00 36.png]]
 
  
 
----
 
----
Строка 203: Строка 265:
 
  | width="40%"|[[Learning|Оглавление]] <<  
 
  | width="40%"|[[Learning|Оглавление]] <<  
 
  ! width="20%"|[[Learning|Оглавление]]  
 
  ! width="20%"|[[Learning|Оглавление]]  
  | width="40%" align="right"| >> [Урок 1: Создание экранов, сцен. Работа с кнопками|Урок 1]]
+
  | width="40%" align="right"| >> [[Создание экранов, сцен. Работа с кнопками|Урок 2]]
 
|}
 
|}
 +
 +
[[Category:Learning]]

Текущая версия на 11:33, 4 августа 2021

Оглавление << Оглавление >> Урок 2


Цель: познакомиться со средой разработки игр AppSalute Сreator.

Задачи:

  • проинсталлировать AppSalute Сreator;
  • открыть готовый проект в редакторе сцен;
  • освоить взаимодействие редактора сцен и редактора ресурсов;
  • изучить основные методы редактирования сцены.


Введение

Для начала работы с редактором его необходимо установить, загрузив и запустив инсталлятор. По умолчанию все необходимые программы будут размещены C:\Program Files\AppSalute Creator и материалы для уроков находятся в папке Мои Документы\Absolutist\Projects\lessons. При желании её можно в дальнейшем перенести в любое удобное место. После инсталляции запускаем программу Scene Editor, найдя на рабочем столе или в списке приложений иконку:

Icon se.png.

Для создания игр в AppSalute Сreator используются четыре взаимодействующих между собой приложения:

  • Ico main.png Scene Editor - редактор игровых сцен (экранов), в котором происходит настройка свойств объектов и игровой логики. Это основной инструмент при разработке игры.
  • Ico base.png Resources Editor - хранилище медиа-ресурсов (картинки, звуки, видео, анимация), использующихся в игре. Эти ресурсы при помощи мышки перетаскиваются на сцену в Scene Editor.
  • Ico text.png Text Editor - хранилище всех текстовых ресурсов (надписей) на различных языках. Аналогично графике и звукам при помощи мышки они перетаскиваются в соответствующие свойства объектов, находящихся в Scene Editor. См. также Урок 6
  • Viewer - проигрыватель созданной игры. Обычно запускается непосредственно из Scene Editor. Вы увидите, возможно сыграете, игру в том же виде, как и на любом мобильном устройстве.
Layout.png

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

Так как игра обычно запускается на различных устройствах (телефон, планшетник, десктоп), важным понятием является лейаут (layout). Лейаут - размещение элементов игры на экране. Так как мониторы имеют разное разрешение в пикселях и разное соотношение высоты и ширины, для них нужны разные варианты размещения игровых объектов и интерфейса. Если игра проектируется для разных устройств, должны поддерживаться несколько лейаутов.

Lesson 1 layouts.png

В качестве примера справа на рисунке представлена структура некоторого проекта в лейауте с размерами экрана устройства 960x640 пикселей. На этом лейауте находятся экраны, из которых только один экран (pack1) развернут. Внутри него находятся 2 сцены (stg_list1 и stg_main1). Одна сцена (stg_list1) раскрыта и содержит три игровых объекта. Последний из них (tbk_pack1) является сложным объектом, содержащим несколько других. Таким образом, игровой проект можно представить как дерево, на различных ветках которого находятся игровые объекты.

Редактор сцен

Открытие проекта

Шаг первый. Вверху окна редактора расположено общее меню и кнопки быстрого запуска:

Меню.png

Если нажать пункт меню Project (Проект), то выпадет список команд, с помощью которых можно создать новый или загрузить уже созданный проект, сохранить проект с указанием места сохранения и т.д.

Откроем проект, на основании которого будут проходиться эти уроки. Для этого нажмём в меню пункты ProjectOpen или сразу кнопку быстрого доступа Открыть проект.png. Заходим в папку Мои документы/Absolutist/Projects/Lessons. Внутри неё кликнем на файл lessons.seproj

Seproj.JPG.

В результате откроется проект, визуальная часть которого окажется в основной (центральной) части редактора. Чтобы увидеть что-то кроме белого экрана, необходимо на панели Layout, которая находится в правой верхней части экрана, кликнуть мышкой на строчку с надписью lesson_1 (это первый игровой экран приложения). В результате мы должны увидеть:

Экран.png

Свойства проекта

В правой части окна редактора расположены две панели Layout (лейаут) и Properties (свойства). На панели Layout показано иерархическое дерево проекта, который пока состоит из одного игрового экрана lesson_1. Если кликнуть на стрелочку (или плюсик, или треугольник, в зависимости от Вашей ОС) слева от надписи lesson_1, то экран раскроется и мы увидим сцену, которая находится на экране. Она называется lessons_1. Продолжая кликать на стрелочки, раскроем всю структуру этого проекта:

Лэйаут.png

Наиболее простым объектом, находящимся в дереве проекта, является статическая картинка фона, которая называется bg. Если на неё кликнуть, то ниже в панели Properties можно увидеть параметры настройки этого объекта (его свойства):

Свойства.png

Стоит "пораскрывать" ветки настроек объекта bg, нажимая на стрелочки (или плюсики, или треугольники) слева от имен полей. Если навести мышкой на имя поля, то появится краткая подсказка, поясняющий смысл свойства.

Панели Layout и Properties могут перетаскиваться мышкой в произвольное место редактора, располагаться одна под другой или объединяться в одну панель с двумя закладками снизу. Если панели находятся одна под другой, можно мышкой изменить их относительную высоту. Для этого мышь располагаем между ними, пока она не изменит своей формы со стрелочки на сплиттер (две горизонтальные полоски). Затем, нажав на мышь, таскаем вверх-вниз границу между панелями.

Проигрывание проекта

В процессе разработки игрового проекта, игру в любой момент можно запустить в отдельном окне вьювера (Viewer) для проверки. Для этого в дереве проекта (панель Layout) необходимо выбрать интересующий нас экран (с которого произойдёт запуск) и нажать кнопку Play111.png (или пункт меню ViewerStart Viewer).


View.png


В нашем случае мы увидим летающее над слонёнком солнышко. Оба объекта (и слонёнок, и солнышко) являются активными. Кликните сначала на голову слонёнка - она должна повернуться. Клик на тело слонёнка заставит его подпрыгнуть. При должной сноровке можно кликнуть также на летающее солнышко, что приведёт к кратковременному изменению его формы.

Стоит запомнить три важных правила при работе с вьювером:

  • Если приложение редактировалось, то перед запуском вьювера проект необходимо сначала сохранить (меню: ProjectSave Project).
  • Всегда необходимо перед запуском вьювера выбирать экран, который начнёт проигрываться (сейчас такой экран пока один).
  • После просмотра во вьювере игры, его необходимо закрыть, нажав (как обычно в Windows) крестик в правом верхнем углу окна.

Кнопки быстрого запуска

Приведем для справки описание кнопок быстрого доступа к некоторым командам редактора сцен (более подробная информация будет предоставлена в последующих уроках):

  • 00001.png — создать новый проект;
  • Открыть проект.png — открыть уже созданный проект;
  • 00002.png — сохранить изменения в проекте;
  • 00003.png — нормальный вид;
  • Play111.png — запустить Viewer;
  • 000004.png — запустить Viewer с изменением времени;
  • 000005.png — очистить данные;
  • 00006.png — вызов редактора ресурсов;
  • 00007.png — вызов текстового редактора;
  • 00008.png — анализ использованных ресурсов;
  • 00009.png — поиск объекта по имени или id;
  • 0000010.png — общие свойства объекта.


Редактор ресурсов

Второе важное приложение, это редактор ресурсов. Так как мы открыли готовый проект, то с ним уже связана база графических ресурсов. Чтобы её увидеть, нажмите кнопку 00006.png (или меню: ToolsResources Editor). Откроется новое окно, которое, на самом деле, является независимым приложением:

Редактор ресурсов111.png

Как и в редакторе сцен, вверху окна редактора ресурсов расположено меню и кнопки быстрого доступа: создать базу ресурсов, открыть уже существующую, показать экспорт последних объектов, сохранить изменения в редакторе ресурсов, добавить картинку (png, jpeg), добавить картинку из папки, добавить анимацию, мелодию (mp3, ogg), видео (mp4). Ниже, в левой панели, находятся папки, внутри которых можно найти различные графические ресурсы, которые мы будем использовать на протяжении этих уроков. Каждая папка названа по имени урока. Кликнув на стрелочку (или плюсик, или треугольник) слева от папки lesson_1 мы увидим текстовый список из 8 картинок, находящихся в ранее запущенном приложении со слоненком и солнышком.

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

Текущее приложение содержит фоновую картинку (bg), три картинки частей слонёнка (elephant_body, elephant_head_1, elephant_head_2) и 4 картинки с различным видом солнышка.

Так как редактор ресурсов является отдельным приложением, он может оказаться под окном редактора сцен. Это не всегда удобно, поэтому зайдем в пункт меню View редактора ресурсов и поставим галочку у пункта Always on Top. Теперь редактор ресурсов окажется поверх редактора сцен (как впрочем, и поверх всех остальных окон). Естественно, галочку можно в любой момент снять или свернуть окно редактора ресурсов.

Размер окна редактора ресурсов можно изменять мышкой, схватившись за правый нижний угол окна. Правую панель, которая выводит картинки, можно “перетащить” в любое место окна редактора ресурсов (для этого необходимо потянуть за её заголовок). Чтобы вернуть панель на фиксированное место, необходимо дважды кликнуть на её заголовке.


Редактирование сцены

Добавление на сцену

Разберемся, как на сцену добавляются новые объекты. Предполагается, что мы одновременно видим окна обоих редакторов. Убедимся, что в панели проекта (Layout) редактора сцен активна текущая сцена lessons_1. Не путайте её с экраном lesson_1, находящимся выше. Рядом с каждым объектом в дереве ресурсов находится иконка, отражающая тип объекта. Рядом с экраном изображено, что-то похожее на фотоаппарат, а рядом со сценой - чистый лист бумаги.

Нажав мышкой на иконку головы слонёнка в редакторе ресурсов, перетащим её на сцену в редактор сцен, где кнопку мышки отпустим:


Add picture.png

Теперь окно редактора ресурсов можно свернуть, чтобы оно не мешало. На сцене мы видим одного полноценного слонёнка и отдельно парящую голову. В списке объектов (панель Layout) добавился объект elephant_head_2. Его имя по умолчанию совпадает с именем картинки в редакторе ресурсов. Если оно не достаточно точно выражает назначение этого объекта, то его необходимо изменить в панели Properties (предполагается, что на дереве объектов эта голова сейчас выбрана). Переименуем её, например, в elephant_ghost (дух слонёнка). Для этого кликнем справа от поля имя в панели Properties и введем новое название. После окончания редактирования нажимаем Enter. Одновременно с этим изменилось имя на дереве объектов (Layout). Стоит всегда придерживаться следующего правила:

Ok.png

Необходимо присваивать объектам в проекте осмысленные имена, отражающие их роль и функции. Это относится также к именам экранов и сцен.

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

Обратим внимание, что добавленная голова имеет тип image (первое поле в панели Properties). Большинство объектов в начале имеют такой тип. Далее он меняется в зависимости от функциональности объекта (подробнее об этом в следующих уроках).

Ok.png

Совет: Переименовывать объекты можно непосредственно в панели Layout, после двойного клика мышкой на имя этого объекта. Редактирование завершается нажатием клавиши Enter.

Изменение положения

На сцене вокруг добавленной головы находится зелёная прямоугольная рамка (объект активен). Если она красная, необходимо кликнуть на объект (голову) и он станет активным. Заметим, что при клике на объекте меняется не только цвет рамки, но и активный объект на дереве объектов (Layout). Соответственно в панели Properties показываются его свойства. Стоит покликать на различные объекты на сцене и на дереве проекта, наблюдая одним глазом за их рамкой, а другим за панелями проекта и свойств. В заключение этого увлекательного упражнения необходимо снова сделать активной голову.

Активный объект можно таскать мышкой по экрану, задав ему требуемое положение (не оторвите только голову исходному слоненку). Стоит раскрыть свойство "положение" в панели Properties и понаблюдать, как при таскании головы меняются её координаты. Начало координат (точка x=0, y=0) расположено в центре сцены. Горизонтальная ось x направлена вправо, а вертикальная ось y - вниз. Если объект находится ниже центра сцены, он будет иметь положительное значение y, а если выше, то отрицательное. Естественно, положение объекта можно изменить и при помощи прямого редактирования полей x, y свойства "положение". Перетащите голову в правый верхний угол сцены.


Модификаторы

Будем считать, что добавленная голова слона - это дух предков исходного слонёнка. Духу положено быть полупрозрачным. Это достигается изменением свойства alpha в группе модификаторы на панели свойств (Properties). Изменим исходное значение 1.00 (непрозрачен) на 0.5 (полупрозрачен). Значение alpha=0 соответствует полной невидимости объекта (возможно любое значение между 0 и 1). Обратим внимание, что десятичная точка является именно точкой, а не запятой, как всё ещё учат на 1/6 части суши. Впрочем, если в вашей операционной системе в языковых настройках стоит русский язык, Вы увидите привычную запятую, вместо десятичной точки.

Дополнительно в разделе модификаторы можно изменить угол (angle) в градусах (поставьте, например -30) и масштаб картинки (поля scale x и scale y). Исходная картинка имеет единичный масштаб, т.е. на сцене выглядит также, как и в редакторе ресурсов. Если масштаб увеличить, то увеличится и картинка (это можно сделать независимо по ширине и высоте). Соответственно, значение меньшее 1 (но большее нуля) её уменьшит. Отрицательное значение масштаба переворачивает картинку. Задайте scale_x=-2 и scale_y=2. В результате должно получиться что-то типа:


Mod.png

Заметим, что при сильном масштабировании (scale) могут появляться дефекты картинки (квадратики пикселей), поэтому злоупотреблять большими значениями, обычно, не стоит.

Z - порядок объектов

Пришло время посмотреть, что у нас получилось. Для этого сохраняем все изменения 00 8.png (нажав кнопку Ok на выскочившем окошке). Затем запускаем вьювер 00 9.png. Понаблюдаем за солнцем. Оно движется над фоновой картинкой "bg", но под головой духа слона (он должен, естественно, находится в верхней части сцены). Такая последовательность прорисовки связана с порядком объектов в дереве на панели Layout. Отрисовка происходит сверху вниз (сначала bg, затем move и т.д.). Это правило является иерархическим. Если на дереве находятся объекты, содержащие другие объекты, то сначала рисуется вся эта ветка дерева, а затем поверх неё рисуются нижележащие на дереве объекты на других ветках. Это же правило относится к последовательности рисования сцен. Если на экране несколько сцен, то они рисуются сверху вниз в соответствии с их порядком на дереве. Сама по себе сцена - это невидимый объект (контейнер). Поэтому, рисование сцены означает последовательное рисование всех объектов, которые в ней находятся.

Попробуем во вьювере кликнуть на солнце, когда оно оказывается под головой духа слона. Его форма не изменяется, так как картинка головы, хотя и является полупрозрачной, по умолчанию "обработать". Чтобы изменить ситуацию, закроем вьювер (крестик) и отредактируем поле свойства духа слоненка "пропускать клик" выбрав из соответствующего списка "пропустить" вместо "обработать". Закончив редактирование поля (нажав Enter), сохраняем проект 00 8.png и снова запускаем вьювер 00 9.png. Теперь дух, как и положено астральным образованиям, пропускает клик сквозь себя.

Порядок рисования объектов можно изменить, перетащив их по дереву в панели Layout. Эта операция требует определенной сноровки. Наступим на имя объекта elephant_ghost и не отпуская мыши потащим его вверх. Когда он окажется на уровне объекта bg, отпустим мышь. Он станет подобъектом фона, что отобразится как сдвиг elephant_ghost вправо (у объекта фона bg слева появится стрелочка). Теперь снова схватим elephant_ghost и потащим чуть вниз и влево по дереву. Когда указатель мыши окажется между объектами bg и move, появится длинная горизонтальная полоска. В этот момент отпускаем мышь, и наш дух размещается между этими объектами.

Ниже на рисунке представлены оба варианта положения духа на дереве сцены (слева подобъект elephant_ghost в объекте bg, а справа равноправный с bg объект, но ниже по дереву и, следовательно, рисуемый позже):


El.png El2.png

С точки зрения отрисовки, оба эти варианта приведут к одинаковому результату. Проверьте это, потренировавшись в таскании, сохранении и запуске вьювера. Подумайте также, почему так происходит.

Удаление объектов

Откройте снова окно редактора ресурсов (скорее всего оно находится в свернутом состоянии в панели приложений). Расположите его над окном редактора сцен. Перетащите на сцену из папки lesson_1 какую-нибудь небольшую картинку (например, sun_1). Сверните редактор ресурсов. Новая картинка появилась на сцене и в дереве объектов панели Layout. Чтобы её удалить, нажмите правую кнопку мыши на объекте sun_1 в панели Layout. В вывалившемся меню выберете пункт Delete. Картинка исчезнет. Эквивалентно, объект можно удалить, кликнув на него в дереве и нажав на клавиатуре кнопку Del.

Заметим, что если объект на сцене сделать активным (кликнув на него - зеленая рамка) и попытаться нажать Del, то ничего не произойдет. Сделано это умышленно. Дело в том, что при удалении уничтожается не только сам объект, но и все его подобъекты. Подобная иерархия видна только на дереве проекта.

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


Другие объекты

На нашей сцене кроме картинок находятся еще два типа объектов - это кнопка и машина состояний. С кнопками мы будем работать уже на следующем уроке, а машинам состояний посвящены сразу 3 урока, начиная с третьего. Пока наша задача состоит в их поиске в дереве проекта и первым знакомством с их свойствами.

Кликнем на стрелочку слева от объекта move в панели Layout. Под ним раскроется подобъект с именем sun_1. Это кнопка. Сам же объект move является машиной состояния. Кроме указания соответствующего типа в панели Properties (посмотрите на него!), тип объекта помечается иконкой на дереве. Для машины - это шестеренка, а кнопка - это кнопка :).

Кликнув на объект sun_1, рассмотрим его свойства в панели Properties. Кроме уже знакомых по картинке (тип=image) полей, появился ряд других. Например, раскроем стрелочку свойства "внешний вид". Там находятся несколько полей, из которых заполнены up и down. В них заданы имена картинок для изображения отжатой и нажатой кнопки. Как они там оказались выясним в следующем уроке.

Рассмотрим теперь объект move. Не смотря на небольшое количество свойств, это один из самых универсальных и сложных объектов, позволяющих программировать динамическое поведение объектов и их логику. Чтобы краем глаза заглянуть на кухню этого процесса кликните на свойство states, а затем на появившиеся три точки в этом поле. Выскочит следующее окошко:


Mov prop.png Move.png

Эта машина состояний, которая имеет одно состояние. В нём задана последовательность команд, которые управляют её движением по экрану. Сама машина в данном случае является невидимым объектом. Однако, она содержит в качестве подобъекта кнопку sun_1. Поэтому, когда машина move бегает по экрану, вместе с ней движется и кнопка. Клики на себя принимает кнопка, меняя при этом свой внешний вид. Несложно догадаться, что в результате получается солнышко.


Упражнения

  • Найдите две машины состояний, связанные со слонёнком, и попробуйте догадаться как они работают (ответы в следующих уроках).
  • Откройте демонстрационный проект, находящийся в папке AppSaluteСreator/Projects/Demo/demо. Поиграйтесь с ним.
  • Снова откройте учебный проект c которым мы работали (AppSaluteСreator/Projects/Lessons/lessons). Он нам понадобится для следующего урока.
  • Затем переходите на урок 2.



Оглавление << Оглавление >> Урок 2