![見出し画像](https://assets.st-note.com/production/uploads/images/114974087/rectangle_large_type_2_7d20d7810dc9b3fa9b6fb75365346336.png?width=1200)
[UEFN&Verse]ボタンを押すとアイテムがスポーン
今回はボタンとアイテムスポナーを使ってボタンを押すとアイテムが出てくる仕組みを作ってみる
おサルの餌ボタン実験のようだ
プロジェクトの始め方など前提となる設定については以下の記事を参考にして欲しい
大まかな手順
ボタンを配置
Verseデバイスを作成
コーディング
アイテムスポナーを配置
①ボタンを配置
まずはなんでもよいのでプロジェクトをスタートする
新規のプロジェクトでも、何かすでに仕掛かっているプロジェクトでも特に問題はない
(まだ開いてなければ)コンテンツブラウザを開く
![](https://assets.st-note.com/img/1693463250437-DOaMjMUjJb.png?width=1200)
All > Fortnite > Devicesの下に[ボタン]があるのでシーンにドラッグ&ドロップする
![](https://assets.st-note.com/img/1693465309490-UlisMkCIlZ.png?width=1200)
②Verseデバイスを作成
Verse Explorerでプロジェクトルートを右クリックして
Add new Verse file to projectを選択
![](https://assets.st-note.com/img/1693465695761-G5m77kxeJO.png)
Device Nameを適当につけて[作成]する
ここでは"item_button_device"とした
![](https://assets.st-note.com/img/1693468032283-6tMEh9nB9j.png?width=1200)
コンテンツブラウザでAll > [プロジェクト名]コンテンツ > CreativeDevices の下に作られているVerseクラスをシーンに配置する
![](https://assets.st-note.com/img/1693488007183-BpCOu0MFFL.png)
Verseクラス(デバイス?)はプレイ中に見せる必要はないのでユーザーオプションからゲーム中に表示をオフにしておく
![](https://assets.st-note.com/img/1693488390817-QJWxoWRnUu.png)
③コーディング
Verse Explorerから作成たverseファイルをダブルクリックして開く
![](https://assets.st-note.com/img/1693488510069-bfKJwHmYXH.png)
初期状態だと以下のようなプログラムになっている
using { /Fortnite.com/Devices }
using { /Verse.org/Simulation }
using { /UnrealEngine.com/Temporary/Diagnostics }
# See https://dev.epicgames.com/documentation/en-us/uefn/create-your-own-device-in-verse for how to create a verse device.
# A Verse-authored creative device that can be placed in a level
item_button_device := class(creative_device):
# Runs when the device is started in a running game
OnBegin<override>()<suspends>:void=
# TODO: Replace this with your code
Print("Hello, world!")
Print("2 + 2 = {2 + 2}")
まずはVerseクラスとボタンを関連付けるためにクラス定義の下に
2行挿入する
item_button_device := class(creative_device):
@editable
Button:button_device = button_device{}
@editable はその下に定義した変数をエディタに公開するという宣言だ
Button:button_device = button_device{} は
c#風に書き換えるとbutton_device Button = new button_device();
と同じで、変数を定義してインスタンスを生成している
ここで一度ファイルをセーブしてプログラムをビルドしてみる
![](https://assets.st-note.com/img/1693489738941-zZ6BQKkMJ7.png)
Button という変数がエディタに公開されているのがわかる
ここで先ほど追加したボタンを選択することでVerseクラスとボタンが関連付けられることになる
![](https://assets.st-note.com/img/1693490078704-NoDEeeloJH.png)
ボタンが押された時の処理を書くOnBeginの下を以下のように編集する
OnBegin<override>()<suspends> : void =
Button.InteractedWithEvent.Subscribe(OnButtonInteracte)
OnButtonInteracte(Player:agent) : void =
Print("ボタンが押されました")
まずはボタンが押されたときにコールされる関数を定義する
OnInteracte(Player:agent) : void =
Print("ボタンが押されました")
Verseは文法がちょっと変わっているのだがC#風に書き換えればごく普通だ
void OnButtonInteracte(Player agent)
{
Print("ボタンが押されました");
}
定義した関数をOnBeginでButtonインスタンスに登録する
OnBegin<override>()<suspends> : void =
Button.InteractedWithEvent.Subscribe(OnButtonInteracte)
C#のデリゲートみたいなものだ
Button.InteractedWithEvent = OnButtonInteracte;
ソースをビルドして動作確認してみる
ボタンを押すとメッセージがでるのが確認できる
![](https://assets.st-note.com/img/1693494392942-fzdfWMzgyL.png?width=1200)
④アイテムスポナーを配置
コンテンツブラウザからAll > Fortnite > Devicesの下にあるアイテムスポナーをシーンに配置する
![](https://assets.st-note.com/img/1693495055617-MwW8vIjJeX.png?width=1200)
アイテムスポナーの詳細情報で、
タイマーに合わせてアイテムをスポーンをOFF
タイマーに合わせてアイテムをリスポーンをOFF
アイテムリストになんでもよいので適当にアイテムを追加
![](https://assets.st-note.com/img/1693495352266-rsgLinXGre.png)
クラスにいくつかコードを追加
アイテムスポナーインスタンスを定義してエディターに公開
ボタンが押されたときにアイテムをスポーンする関数を追加
item_button_device := class(creative_device):
@editable
Button:button_device = button_device{}
@editable
ItemSpawner:item_spawner_device = item_spawner_device{}
OnBegin<override>()<suspends> : void =
Button.InteractedWithEvent.Subscribe(OnButtonInteracte)
OnButtonInteracte(Player:agent) : void =
Print("アイテムをスポーンします")
ItemSpawner.SpawnItem()
プログラムをビルドして、アイテムスポナーをエディタで関連付ける
![](https://assets.st-note.com/img/1693495772770-5OqgjLikh7.png)
ここでまた動作確認してみる
アイテムがスポーンできているはず
![](https://assets.st-note.com/img/1693495973676-l5rd3EELcQ.png?width=1200)
今回はボタンとアイテムスポナーを使ったが、デバイスはざっと数えると150種類ぐらいあるので何ができるのか探っていこうと思う
NPCや敵の動きの制御などもVerseでできるのだろうか?
しばらくUEFN&Verseシリーズを進めていこうと思う
この記事が気に入ったらサポートをしてみませんか?