Видеоуроки
Interface
Essentials
Advanced
Подсказки и советы
Основы
Программирование на C#
Рендеринг
Принципы работы
Свойства (properties)
Компонентная Система
Рендер
Физика
Редактор UnigineEditor
Обзор интерфейса
Работа с ассетами
Настройки и предпочтения
Работа с проектами
Настройка параметров узла
Setting Up Materials
Настройка свойств
Освещение
Landscape Tool
Sandworm
Использование инструментов редактора для конкретных задач
Extending Editor Functionality
Встроенные объекты
Узлы (Nodes)
Объекты (Objects)
Эффекты
Декали
Источники света
Geodetics
World Objects
Звуковые объекты
Объекты поиска пути
Players
Программирование
Основы
Настройка среды разработки
Примеры использования
UnigineScript
C++
C#
Унифицированный язык шейдеров UUSL
File Formats
Rebuilding the Engine Tools
GUI
Двойная точность координат
API
Containers
Common Functionality
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
Работа с контентом
Оптимизация контента
Материалы
Art Samples
Tutorials

Unigine::ControlsDummy Class

Header: #include <UnigineControls.h>
Inherits from: Controls

This class is used to create controls for players that should not be controlled by the user (for example, when such a player is controlled by an AI). This class allows to create any other completely custom implementation of controls.

The code below shows how to create custom controls and toggle showing the item inventory when 'i' key is pressed on the keyboard. For that, auxiliary state STATE_AUX_0 is used.

Source code (C++)
#include <UnigineApp.h>
using namespace Unigine;
// ...

ControlsDummyPtr my_controls = ControlsDummy::create(); // custom controls
bool inventory_toggled = false; // show item inventory toggle

void update_input(ControlsPtr controls) {
	// Check if the key is pressed and update the state of the specified control.
	// You can use both 'i' or ASCII code (105).
	controls->setState(Controls::STATE_AUX_0, App::getKeyState('i'));
}

// Implement your game logic for showing or hiding item inventory.
void update_game_logic(ControlsPtr controls) {
	// If the control state is positive (the key has been pressed), toggle item
	// inventory on and off.
	if (controls->getState(Controls::STATE_AUX_0)) {
		inventory_toggled = !inventory_toggled;
	}
}

/*
 */
// Update controls each frame according to the user input.
int AppWorldLogic::update() {
	update_input(my_controls);
	update_game_logic(my_controls);
}

ControlsDummy Class

Members


static ControlsDummyPtr create ( ) #

Constructor. Creates a new set of dummy controls.
Last update: 15.12.2020
Build: ()