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

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