Hide and Disable Actor in Game

November 30, 2017

UE4 Version: 4.18.3

Github Link: https://github.com/Harrison1/unrealcpp/tree/master/HideActor

For this tutorial we are using the standard first person C++ template with starter content. If you don't know how to add a new actor class to your project, please visit the Add C++ Actor Class post.

To completely hide an actor in game you have to do three things. You have to disable it's collision, disable it from ticking, and hide it in game.

You can add the code to any actor. For this example I created a separate actor demonstrate its purpose.

Create an actor called HideActor. If you call your actor another name, be sure to change it throughout the code. In the header file I create two variables; bool HideInGame to track if we want to disable the actor and void DisableActor to run through all the elements we need to disable. We put both variables in the Disable category to keep them separate from the actor's other attributes.


#pragma once

#include "CoreMinimal.h"
#include "GameFramework/Actor.h"
#include "HideActor.generated.h"

class UNREALCPP_API AHideActor : public AActor

	// Called when the game starts or when spawned
	virtual void BeginPlay() override;

	// Called every frame
	virtual void Tick(float DeltaTime) override;

	UPROPERTY(EditAnywhere, Category = "Disable")
	bool HideInGame;

	UFUNCTION(BlueprintCallable, Category = "Disable")
	void DisableActor(bool toHide);

On BeginPlay() we check to see if HideInGame is true. If true we run DisableActor(). DisableActor() hides the actor, disable it's collisions, and disable it from running every frame.


#include "HideActor.h"

// Called when the game starts or when spawned
void AHideActor::BeginPlay()

	if (HideInGame)

// Called every frame
void AHideActor::Tick(float DeltaTime)

void AHideActor::DisableActor(bool toHide) 
	// Hides visible components

	// Disables collision components

	// Stops the Actor from ticking


Harrison McGuire

Harrison McGuire