This page has been translated automatically.
Видеоуроки
Интерфейс
Основы
Продвинутый уровень
Подсказки и советы
Основы
Программирование на C#
Рендеринг
Профессиональный уровень (SIM)
Принципы работы
Свойства (properties)
Компонентная Система
Рендер
Режимы вывода изображения
Физика
Браузер SDK 2
Лицензирование и типы лицензий
Дополнения (Add-Ons)
Демонстрационные проекты
API Samples
Редактор UnigineEditor
Обзор интерфейса
Работа с ассетами
Контроль версий
Настройки и предпочтения
Работа с проектами
Настройка параметров ноды
Setting Up Materials
Настройка свойств
Освещение
Sandworm
Использование инструментов редактора для конкретных задач
Расширение функционала редактора
Встроенные объекты
Ноды (Nodes)
Объекты (Objects)
Эффекты
Декали
Источники света
Geodetics
World-ноды
Звуковые объекты
Объекты поиска пути
Player-ноды
Программирование
Основы
Настройка среды разработки
Примеры использования
C++
C#
UnigineScript
Унифицированный язык шейдеров UUSL (Unified UNIGINE Shader Language)
Плагины
Форматы файлов
Материалы и шейдеры
Rebuilding the Engine Tools
Интерфейс пользователя (GUI)
Двойная точность координат
API
Animations-Related Classes
Containers
Common Functionality
Controls-Related Classes
Engine-Related Classes
Filesystem Functionality
GUI-Related Classes
Math Functionality
Node-Related Classes
Objects-Related Classes
Networking Functionality
Pathfinding-Related Classes
Physics-Related Classes
Plugins-Related Classes
IG Plugin
CIGIConnector Plugin
Rendering-Related Classes
VR-Related Classes
Работа с контентом
Оптимизация контента
Материалы
Визуальный редактор материалов
Material Nodes Library
Miscellaneous
Input
Math
Matrix
Textures
Art Samples
Учебные материалы
Внимание! Эта версия документация УСТАРЕЛА, поскольку относится к более ранней версии SDK! Пожалуйста, переключитесь на самую актуальную документацию для последней версии SDK.
Внимание! Эта версия документации описывает устаревшую версию SDK, которая больше не поддерживается! Пожалуйста, обновитесь до последней версии SDK.

Система экспорта

Система экспорта позволяет вам использовать плагины по умолчанию и писать собственные плагины для экспорта нод UNIGINE в файл другого формата и сохранения его на диске.

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

Export System

Экспорт структуры системы

Менеджер экспорта используется для создания экспортеров и управления ими, а также для прямого экспорта файлов в неродные форматы, если ранее был зарегистрирован экспортер для таких файлов.

Экспортер#

Exporter — это модуль, используемый системой экспорта для передачи объектов UNIGINE в файлы в различных неродных форматах. Один экспортер может использоваться для экспорта нескольких нод, но не должно быть двух или более экспортеров, зарегистрированных для одного типа ноды.

Каждый экспортер имеет набор параметров, управляющих всем процессом экспорта (например, экспортировать ли источники света, камеры и карты нормалей материалов, сбросить преобразование корневой ноды и т. д.). Экспортер должен быть инициализирован перед использованием.

Основной рабочий процесс#

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

Основной рабочий процесс экспорта ноды выглядит следующим образом:

  1. Проверьте расширение указанного выходного файла и найдите подходящий экспортер среди зарегистрированных.
  2. Извлеките данные сцены из ноды, создайте сцену экспорта и поместите данные в соответствующие структуры экспорта (например, ноды FBX).
  3. Используйте соответствующий экспортер для создания выходных файлов на основе метаданных сцены.

Настройка#

Вы можете рассмотреть плагин FbxExporter в качестве примера для создания собственных пользовательских модулей экспорта. Вы также можете изменить и перестроить этот плагин, чтобы использовать свой собственный экспортер в редакторе.

Чтобы использовать плагин FbxExporter, просто загрузите его с помощью консольной команды plugin_load или следующей параметр командной строки при запуске приложения:

Shell-команды
-extern_plugin UnigineFbxExporter

В общем виде рабочий процесс через C++ API можно представить следующим образом:

Исходный код (C++)
// create an exporter for the exported file ("1.fbx" in our case)
Unigine::Exporter* exporter = Unigine::Export::get()->createExporterByFileName("1.fbx");

// enable the "export_material_normal_maps" parameter 
exporter->setParameterInt("export_material_normal_maps", 1);

// initialize exporter
exporter->init();

// get the node
NodePtr node = World::getNodeByName("material_ball");

// export the node to the specified file path
exporter->doExport(node, "1.fbx");

// exporter deinitialization
exporter->deinit();

Вы также можете экспортировать ноду с настройками по умолчанию следующим образом:

Исходный код (C++)
// get the node
NodePtr node = World::getNodeByName("material_ball");

// export the node to the file of specified format
Unigine::Export::get()->doExport(node, "../data/1/1.fbx")

Встроенные параметры экспорта#

Встроенные экспортеры движка (плагин FbxExporter, плагин UsdExporter) имеют ряд параметров экспорта, которые настраивают поведение экспортера, а также могут использоваться в пользовательских экспортерах.

Имена параметров#

В следующей таблице перечислены имена параметров, доступных из коробки, которые можно установить с помощью метода setParameterInt("name", value).

export_lights

Экспорт нод освещения.

  • 0 — отключено
  • 1 — включить (по умолчанию)
export_cameras

Экспорт нод камеры (только для FbxExporter).

  • 0 — отключить
  • 1 — включено (по умолчанию)
export_surface_to_node

Экспортирует все поверхности как отдельные меши внутри контейнера FBX / файла USD.

  • 0 — disabled
  • 1 — to enable (by default)
export_material_normal_maps

Экспортирует карты нормалей материалов (только для FbxExporter).

  • 0 — отключено
  • 1 — включить (по умолчанию)
reset_root_node_transformation

Сбрасывает корневое преобразование ноды.

  • 0 — отключено (по умолчанию)
  • 1 — включить

Смотрите также#

  • FbxExporter в качестве примера вашего пользовательского плагина экспорта: source/plugins/Export/FbxExporter.
  • Плагин UsdExporter

API системы экспорта:

  • Для получения более подробной информации об управлении системой экспорта с помощью кода обратитесь к статье Классы функциональности экспорта

    Примечание
    Системное API экспорта недоступно для версии Community SDK.
Последнее обновление: 16.08.2024
Build: ()