Getting the Widget Component to Always Face the Camera in UE5
When creating an actor that has a widget component attache it be helpful to sometimes have that widget always face the player's camera
data:image/s3,"s3://crabby-images/b4793/b4793fa8bd956c8bb519ea286f9b7ee7c87ea0c8" alt="Unreal Engine 5 Manny with a basic widget component above his head with a name and red progress bar"
Game Engine
Unreal Engine 5.5.0
IDE
Rider 2024.3
Project Name
MyProject
Getting a widget component to face the camera can be achieved simply by using the AlignMeshToTheCamera
material node.
The default material for a widget component is Widget3DPassThrough_Masked_OneSided
which is an instance of Widget3DPassThrough
. So I copied over Widget3DPassThrough
to content folder so I can edit it without consequence. The file path for the material is /Engine/EngineMaterials/Widget3DPassThrough.Widget3DPassThrough
.
data:image/s3,"s3://crabby-images/39813/39813d55354c08786a21d51558b22cb9ed0c17fb" alt="Unreal Engine 5 editor engine directory for Widget3DPassThrough material"
I copied the material over to /Game/Materials/Widgets
and renamed it to M_Widget3DPassThrough_Align
. Open up the material to edit it. Add the AlighMeshToTheCamera
node to the material and attach the World Position Offset
pin to the material's World Position Offset
value pin.
data:image/s3,"s3://crabby-images/e61f9/e61f9399af3b41f1353d1b7a5ad5186278aadd70" alt="Unreal Engine 5 M_Widget3DPassThrough_Align material with AlignMeshToTheCamera node"
To be consistent I created a material instance from M_Widget3DPassThrough_Align
and called it M_Widget3DPassThrough_Align_Masked_OneSided
and updated it match the engine version.
data:image/s3,"s3://crabby-images/56685/566858aca99d642c1d6499ae7c85baa81c7eed48" alt="Unreal Engine 5 material instance align mesh one sided"
Create a new Blueprint and add a widget component to the actor. For testing I added a skeletal mesh a put a health bar component above the actor. In the widget component update the material to our newly created M_Widget3DPassThrough_Align_Masked_OneSided
and then very importantly we must also change the widget's rotation to be absolute.
data:image/s3,"s3://crabby-images/aedef/aedef2595fc58e741a2a6b48d31e35550b0a799e" alt="Unreal Engine 5 Blueprint viewport with updated widget component material and absolute rotation"
Below is the final result.
data:image/s3,"s3://crabby-images/4f1ec/4f1ecac4d6b80e0035f23949a5ead6a2149b06d1" alt="Unreal Engine 5 Quinn running around Manny with a health bar widget component that always faces the camera"
This example can be seen in the project's gym using the BP_MyStructPlayer Blueprint.
I hope this helps.
data:image/s3,"s3://crabby-images/8736f/8736fd5aa817dffd2aab829cec2f6193cdcad9d6" alt="Harrison McGuire"
Harrison McGuire
akhilthambi
Thank you for the simple and useful tip