This page has been translated automatically.
Видеоуроки
Interface
Essentials
Advanced
Полезные советы
Программирование на C#
Принципы работы
Свойства (properties)
Компонентная Система
Рендер
Физика
Редактор UnigineEditor
Обзор интерфейса
Работа с ассетами
Настройки и предпочтения
Работа с проектами
Настройка параметров узла
Setting Up Materials
Setting Up Properties
Освещение
Landscape Tool
Sandworm (Experimental)
Использование инструментов редактора для конкретных задач
Extending Editor Functionality
Встроенные объекты
Nodes
Objects
Effects
Decals
Light Sources
Geodetics
World Objects
Sound Objects
Pathfinding 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
Внимание! Эта версия документация УСТАРЕЛА, поскольку относится к более ранней версии SDK! Пожалуйста, переключитесь на самую актуальную документацию для последней версии SDK.
Внимание! Эта версия документации описывает устаревшую версию SDK, которая больше не поддерживается! Пожалуйста, обновитесь до последней версии SDK.

Unigine::ControlsDummy Class

Header: #include <UnigineControls.h>
Inherits: 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: ()