Пример взят из книги "Unreal Engine scripting with C++ Cookbook".
Некоторые классы Actor и Component поддерживают обработчики событий в виде виртуальных функций. Здесь будет показано как реализовать собственный обработчик события столкновения.
Некоторые классы Actor и Component поддерживают обработчики событий в виде виртуальных функций. Здесь будет показано как реализовать собственный обработчик события столкновения.
Как это сделать...
- Создать в редакторе Unreal Engine пустой С++ класс Actor и назвать его MyTriggerVolume.
- Добавить в заголовочный файл этого класса следующий код:
UPROPERTY() UBoxComponent* TriggerZone; UFUNCTION() virtual void NotifyActorBeginOverlap(AActor* OtherActor) override; UFUNCTION() virtual void NotifyActorEndOverlap(AActor* OtherActor) override;
- А в файл cpp реализацию функций:
void AMyTriggerVolume::NotifyActorBeginOverlap(AActor * OtherActor) { GEngine->AddOnScreenDebugMessage(-1, 1, FColor::Red, FString::Printf(TEXT("%s entered me"), *(OtherActor->GetName()))); } void AMyTriggerVolume::NotifyActorEndOverlap(AActor * OtherActor) { GEngine->AddOnScreenDebugMessage(-1, 1, FColor::Red, FString::Printf(TEXT("%s left me"), *(OtherActor->GetName()))); } - В конструктор класса надо добавить создание компоненты коллизии:
TriggerZone = CreateDefaultSubobject<UBoxComponent>("BoxComponent"); RootComponent = TriggerZone; - Скомпилировать и разместить MyTriggerActor на уровне.
Как это работает...
- Прежде всего был добавлен UPROPERTY, чтобы сборщик мусора не уничтожил ссылку на компонент. Затем было объявлено две функции UFUNCTION. Эти две функции являются реализацией виртуальных функций из родительского класса AActor. Это события, которые срабатывают во время пересечения коллизии объекта.
- В реализации используется FString::printf, чтобы создать одну строку из заданного текста и данных из параметра, т.е. имя объекта, который пересек коллизию.
- OtherActor->GetName() возвращает ссылку на строку с именем объекта и перед тем как его использовать в FString::Format, его необходимо разыменовывать через (*).
- После того как строка готова, она передается в глобальную функцию движка для вывода на экран в виде сообщения.
- Первый параметр AddOnScreenDebugMessage() говорит движку, что можно дублировать строки, второй параметр указывает сколько времени должно сообщение оставаться на экране. Третий - это цвет, а четвертый сама строка.
- Теперь при пересечении компоненты актера чем-либо, происходит UpdateOverlaps, который вызывает NotifyActorBeginOverlap и соответственно мою реализацию этой виртуальной функции.
Комментарии
Отправить комментарий