UE4 Dialogue System Part3
Tutorial Project: Tutorial_DialogueSystem
In this part, we will create a dialogue widget which use DialogueSession asset as input to display dialogue on screen.
data:image/s3,"s3://crabby-images/c0635/c06355311bcbe5ba5d423350f9401803550b7f38" alt=""
Step 2
Create function: StartSession and Next.
StartSession’s function signature:
data:image/s3,"s3://crabby-images/f4a02/f4a0244cf812ee03633ec8f044395ef5899e6f17" alt="../../../_images/start_session_sign.png"
Next’s function signature:
data:image/s3,"s3://crabby-images/96372/9637221c9db881bad1b55bc466f69adcdc6979e2" alt="../../../_images/next_sign.png"
Create some variables:
- CurrentSession: DialogueSession(type)
- CurrentDialogueNode: DialogueSessionNode(type)
- NodeIndex: Integer(type)
bind MainText’s Text field to CurrentDialogueNode’s Paragraph property, like this:
data:image/s3,"s3://crabby-images/669a4/669a4f58a188d633bca384e1356f0aaae7fcec31" alt=""
Step 5
Create a DialogueSession asset: Dialogue_Test
data:image/s3,"s3://crabby-images/ff346/ff3468a566e4005679d77ee96d334772134fa306" alt="../../../_images/test_dialogue_session.png"
Step 6
Create a UMG widget: UI_HUD, layout it like this:
data:image/s3,"s3://crabby-images/2a8c8/2a8c82d7932fa97ae373ec8898699c4f5b71c114" alt=""
create a bind for UI_Dialogue’s Visibility:
data:image/s3,"s3://crabby-images/6fee3/6fee39e5fe4a8e855644150fd03304f5b5562b21" alt=""
Step 7
Setup input action mapping: Next
data:image/s3,"s3://crabby-images/f9d52/f9d522fca4813f6cb1d625e1b8fcdaa32fc55156" alt=""
create an UI_HUD widget, add it to viewport and setup for Next event:
data:image/s3,"s3://crabby-images/b9a75/b9a755058dc9d31aa6ab9d9a0febe183cbe3e83d" alt=""
Step 8
Add a test trigger into your test map
data:image/s3,"s3://crabby-images/b2b8d/b2b8d57857f4d9e467be2ac6b0735e0bf96a091a" alt=""
open Level Blueprint, setup BeginOverlap event like this:
data:image/s3,"s3://crabby-images/35aed/35aedbf9be9d37ba1a3ea39156ffe93f8cd18993" alt=""
Step 9
Play. move character to the position of test trigger, now you can see the dialogue widget. press N goto the next paragraph.
data:image/s3,"s3://crabby-images/0bb45/0bb45fc411488d1a22a8dd95af6ca3f4de401c0f" alt=""
Done
That’s all in this part. In the next part, we wiil support dialoguer information such as: name, portrait image.