data:image/s3,"s3://crabby-images/90a27/90a272e92427a935ee5d334c8fca9e62b8ab71d9" alt="image"
One fundamental is the concept in programming is the function. Functions are self contained code that can be run from anywhere.
Unreal Engine 5 blueprints also have functions that you can use to separate your nodes inside the blueprint editor.
In this guide we will be showing you how to get started with Blueprint Functions in Unreal Engine 5!
What is a Function?
Blueprint Functions are self-contained pieces of logic that you can create once and run from multiple places in your Blueprints. They allow input and output parameters for flexibility.
For example, instead of writing the same logic to calculate damage multiple times, you can create a function called CalculateDamage, call it wherever needed, and update it in one place if changes are required.
Note that a function is created for a specific blueprint actor and can only be used
In this guide we are going to start right from the beginning and create a simple function to help you understand this concept. We then expand upon this and show you more features that functions can have!
Creating a Function
To start, we are going to make a simple function that prints a string to the screen.
Firstly we need to open the blueprint actor that we want to add the function to. In this example we are using the FirstPersonCharacter blueprint from the First Person Shooter template provided by Unreal Engine.
As you can see in the image below, on the left side of the editor window, there is a drop down section named “Functions”. This section is where all of our functions live for this specific blueprint.
We can create a new function by clicking the circle with a plus symbol on the right side of the functions drop down as shown in the image below.
data:image/s3,"s3://crabby-images/6d333/6d333f54143fe7af5ac77e85e0c609bfb89720fe" alt="Creating a function using the Unreal blueprint editor"
Next, we can then give our function a name. It is advised to give our functions readable and clear names to keep our project clean.
Messy names that are confusing make developing a large project difficult so it is best to keep this in mind.
Once the function is named either press enter, or click anywhere in the blueprint window, then click the “Compile” button as indicated in the image. This then creates our function and compiles it into the blueprint so we can start using it in our project.
data:image/s3,"s3://crabby-images/534fc/534fcacb4b9a8bea39309397ff205ed1ef2b4842" alt="Naming the function then clicking the compile issue"
Adding Basic Functionality
Now that we have our new function created and compiled, we can see it doesn’t do anything at the moment. We need to add some simple functionality!
In this first example we are printing a string to the screen. To achieve this we need to add that node to our function.
First, click and drag from the white sidewards triangle on our “My Custom Function” node. This is called an exec pin and allows us to add pieces of code together to run one after another (sequentially).
Once we click and drag then let go of the click, anywhere on the grey background grid, we then are greeted with a popup menu showing all of the blueprint nodes (these are functions!) we can add to our own function.
Click “Print String” in the menu, this creates the “Print String” node in our function graph.
data:image/s3,"s3://crabby-images/f74a4/f74a4c8bda10a0d1c0f66a1570d1c85b3d33883b" alt="Adding the print string node to the new custom function"
As we dragged from the white exec pin, our Print String node is automatically connected to our MyCustomFunction as shown in the image below.
data:image/s3,"s3://crabby-images/10ef6/10ef6c8be1dafd26c01ff593b68bdb4eaf23825b" alt="The created print string node attached to our MyCustomFunction"
When our “My Custom Function” runs, it will now run the Print String node that is connected to it!
You may also see people talking about “call”, “called”, or “calling” functions. This is the same as running a function!
Testing our Print String
Now that our function is setup to print a string to the output log we need to run our function. The easiest way is to run our function on Begin Play!
Begin play is an “Event”. An event is similar to a function but cannot return values and can run a few special asynchronous nodes that functions cannot.
Begin Play is an event that is called when the actor is spawned into the game world. As our FirstPersonCharacter already is in the game world, this Begin Play event runs code when the game starts.
We first want to click the Event Graph button at the top of the blueprint editor.
data:image/s3,"s3://crabby-images/7910c/7910ce7e391856ead13b1527e42d29e338d37bca" alt="Clicking back onto the Event Graph"
Now our main blueprint event graph will appear again on the screen.
data:image/s3,"s3://crabby-images/069c5/069c56ade1240846ed295142464b9e64390de4e2" alt="Back in the event graph in the blueprint editor"
Find somewhere free and right click. In the box that appears search for Event Begin Play and click it to create the event.
data:image/s3,"s3://crabby-images/fca0a/fca0aa559dc49c4ed4ea4a198104a2b469afc9d5" alt="Creating a new BeginPlay event in the event graph"
Unreal Engine will automatically run the Begin Play event as described in the previous section so no setup is required.
Like before, drag from the white exec pin and let go of the mouse click in the grid. In the pop up menu, search for our MyCustomFunction and click it in the list.
data:image/s3,"s3://crabby-images/a033d/a033daf4c61603102dae7f4fb5d4db6ec1c2da4a" alt="Creating our MyCustomFunction as a node connected to the BeginPlay event"
Now our MyCustomFunction is connected to our BeginPlay event. The last step is to press the Compile button and save our blueprint.
data:image/s3,"s3://crabby-images/44ff1/44ff174453c87b628d9449a118149cc697c41808" alt="Making sure to compile and save our changes"
Clicking play now in our FirstPersonMap will print “hello” in our output log.
data:image/s3,"s3://crabby-images/9cdf5/9cdf52eb9fbef22336c3c559cfb579ba3bc495d2" alt="Demonstrating MyCustomFunction printing Hello to the output log."
Adding more functionality
Now we have text printing on the screen! That’s great for testing but not very useful for gameplay. Lets add some more functionality to our blueprint function.
In this next example we are going to make the CalculateDamage function we talked about earlier!
This function will take in a number called “damage“, seeing how much “armor” our character has, then finally subtract the amount of “armor” from our “damage” number. In short we are calculating how much damage is dealt after our “armor” has absorbed some of the damage.
Notes on advanced functionality
Delay nodes are not supported in functions. If your blueprint needs delay nodes, consider using Custom Events. Click here to read our guide on How to use Custom Events in Unreal Engine.
Making the CalculateDamage function
To achieve this goal of our CalculateDamage function, first we need to input data into our function.
Firstly, click the purple “My Custom Event” node. You should now see in the details window on the right side of the editor sections for Input and Output.
data:image/s3,"s3://crabby-images/03f9f/03f9f0dca9a27d32777cb4df4edd1d3fadc9c8e8" alt="Showing the input and output sections of the function editor"
As we are focussing on Input, click the small add button to add a new Input Variable.
data:image/s3,"s3://crabby-images/ef93b/ef93b8778f700b40fc7254592adff895df31fc0d" alt="Adding a new input parameter to our function"
We now see a new input parameter for our function.
data:image/s3,"s3://crabby-images/3c366/3c366f5599f5fd107b12d5a98ce969570dcb2998" alt="The newly created parameter"
In this example we want to pass in a number so we change the “Boolean” to “Float”.
data:image/s3,"s3://crabby-images/9761d/9761d4bd474d192aa29a097f4787fbbdef4597b3" alt="Changing the parameter's type to Float"
Next in the left text box give our new property a name. We are naming this “Damage”.
So far the function should look like this.
data:image/s3,"s3://crabby-images/e6368/e6368eaa753f555f521072151a7ca940aa4b304b" alt="The function now has the Damage input parameter"
Now we are adding some other nodes to calculate our damage value.
To do this first, drag from the green Damage pin into the grid and let go of the mouse click. In the popup search “-” or “subtract” to find the subtract node.
data:image/s3,"s3://crabby-images/31f2d/31f2d1ab33c580059c820b3b54949bd04d41bee7" alt="Adding a subtract float node and connecting it to our Damage parameter"
Next we click and drag from the bottom subtract node pin and let go, in the menu we then click “Promote to variable”. This will create a new variable that we name “Armor” to store our character’s armour number.
data:image/s3,"s3://crabby-images/3c60a/3c60a09cdb061ce82bbd905eac84589d61dd3bc3" alt="Promoting a new Armor variable connected to the subtraction node"
Next, click the new armor variable in the graph and on the right side details panel and set the armor value to any number you want. In this example we set armor to 15.
data:image/s3,"s3://crabby-images/d43b7/d43b77112f89c77f6754f9590ccd48acf3e17297" alt="Setting the value of the Armor variable to 15.0"
Our MyCustomFunction now takes in the Damage value and subtracts Armor from itself, this is then printed into the output log.
data:image/s3,"s3://crabby-images/1099e/1099e5a6b5e601c734e662ba2332f0b71914e7b7" alt="Our finished input parameter"
Returning our value
Our function now calculates values but does not send those values anywhere! We need to “return” this value out of our new function.
Returning a value is the word used to describe the output of our function. In Unreal Engine Blueprints we can have as many input and output values as we like.
First click our MyCustomFunction and look to the details panel on the right side of the editor again.
This time we are clicking the plus button on the Output section.
data:image/s3,"s3://crabby-images/eae46/eae4611884bdb2dfc338d9429950da3e8509d341" alt="Adding a new output parameter to the function"
In the newly created Output result, change the type to Float and set the name to Result.
data:image/s3,"s3://crabby-images/aa29e/aa29eb5777e103e5f2ef534ea027edf128db8230" alt="Setting the name of the output parameter to Result and setting the type to float"
After creating the new output parameter a “Return Node” will be created automatically in the graph.
This Return Node result pin is where we can “return” our values out of the function.
data:image/s3,"s3://crabby-images/f8483/f84838b0e99c51ad339aea7c320daa0d28c6b16e" alt="The engine creates a return node when an output parameter is created"
We then delete the print string from the function as we no longer need it inside the function.
Our final function now looks like this.
data:image/s3,"s3://crabby-images/17b15/17b15dc39280b2d394d7ee22b6bf46579da88372" alt="The finished function doing a basic subtraction"
In the event graph our function now looks like this. We can give it a “damage” value and get a “result” value out from the function!
data:image/s3,"s3://crabby-images/885d3/885d3eb886226b9b3918f01dfeb72353106e66aa" alt="The final function with and input and return value in the event graph"
To test this is working we set damage to 20.0 and connect our returned result value to a print string node.
data:image/s3,"s3://crabby-images/adaa6/adaa6a4bbeb6ec90c7d65c60ee728e7329649709" alt="Setting the damage value to 20.0"
Demonstration
Finally, with our damage set to 20 and our armor set to 15, when we call our MyCustomFunction we get the value 5!
20 – 15 = 5
In the output you can see that our returned value of 5 is printed to the log!
data:image/s3,"s3://crabby-images/6d6d1/6d6d1790e4c847c0620eb0d187328935599562a0" alt="Our final function calculating 20 - 15 and returning 5"
Conclusion
You’ve now taken the first steps in getting started with Blueprint Functions in Unreal Engine 5! These essential aspects of programming allow you to separate logic into reusable nodes, cleaning up your blueprint actors and making your dream game easier to manage.
The basic concept and example covered in this guide provides a foundation to build upon. Whether you’re building gameplay mechanics, working on core technology, or cleaning up your existing code, Blueprint Functions are a fundamental aspect of Unreal Engine development.
Further Reading:
- Click here to read the official blueprint function unreal engine documentation
- Click here to watch Mathew Wadstein’s in depth blueprint function guide on YouTube (Not affiliated or associated with CouchLearn)
Leave a Reply