SlideShare a Scribd company logo
1 of 45
Download to read offline
Editor Utility Widget
Petit Deep Dive
ゲームデザイナー
キンアジ
動画アーカイブはこちら!(講演超絶ヘタクソですみません!)
第4回UE4何でも勉強会 in 東京アーカイブ
注意
• 「Editor Utility Widget」のことを「EUW」と省略しています。
• スライド内の UE4Editor のキャプチャー画像は
すべて4.24.2を使用しています。
• 以下のEUWの知識をつけてから読むことをお勧めします。(スライドは後日公開)
また、一部の紹介した機能は、後日プロジェクトを公開するのでダウンロードして
ご自身の環境でお試しください。
↓↓EUWのドキュメント
• Editor Utility Widget | Unreal Engine ドキュメント
• Editor Utility Widgetで色々便利にしてみた。by しょーご様
• 【UE4】Editor Utility Widgetについてのあれこれby 株式会社アンナプルナ(キンアジ)
• [UE4]エディタ上で動作するツール・エディタ拡張をUMGで簡単に作れる
Editor Utility Widget についてby おかず様
• 【UE4】メモ:実はEditor Utility WidgetはBlutilityの完全上位互換だった話【★★】by キンアジ
目次
• Details View & Single Property View Widget
• Details View Widget
• Single Property View Widget
• Help Text
• Editor Utility Widgetの罠
• その1
• その2
• その3
• その4
• レベル遷移時に自動でEUWを消す方法
• Editor Utility Widgetの制作事例
今日話すこと
part2!!
Editor Utility Widget(EUW)って?
「Add New」から「Editor Utilities」
→「Editor Utility Widget」で作成可能
• 「User Widget」を使って、エディター拡張ができるものです。 この
EUWは、その機能をエディター上のツールとして使用することができ
ます。 EUWを右クリック→「Run Editor Utility Widget」選択で実行できる。
gif
• 非プレイ中でも機能する
→ゲームを実行していなくても、エディターツールなので機能を使うことができます。
• Editor UtilityなBlueprintが使える
→エディター上でのみ使えるBlueprint(アセットをセーブする「Save Asset」や、
Data TableをReimportする「Fill Data Table from csv String」など)を
使うことができます。
• 特殊なWidget「Details View」「Property View」が使える
→Detail Windowなんかでよく使われているアセットの参照などのUIを使うことができます。
EUWの特徴
では早速Petit Deep Dive!
プチディープ!
Details View & Single Property View
Widget
Details View Widget
Details View Widget
• UObject* を対象に、そのObjectが持っている
UPROPERTYなプロパティと「Call In Editor」をつけたUFUNCTIONな
関数を呼び出すボタンを表示してくれる。
→「Set Object」関数でUObjectを指定。 こんな風に、EUWの中にアセットの参照や、
パラメーターなどを表示してくれる。
超便利!
Details View Widget
• UObject が持つプロパティが多い場合に、表示するプロパティを制限したい
場合、「Categories to Show」と「Property to Show」という配列に
それぞれ、CategoryName,PropertyNameを指定することで
表示するプロパティを制限することができます。
CategoryNameを指定して表示 PropertyNameNameを指定して表示
• Property Viewにフィルターを付けたい場合は、
「bAllowFiltering」をTrueにすることで、
Detail Viewの上に検索ボックスが現れる。(デフォルトでFalse)
Details View Widget
bAllow Filtering=False bAllow Filtering=True
検索ボックスが出てくる!
「View」カテゴリ内にある
Details View Widget
• 表示されるプロパティは、デフォルトではUProperty*の
「PropertyFlags」に「CPF_Edit」をもつUPROPERTY
(EditAnywhere,VisibleDefaultOnlyとか)のみ。
→しかし、「bForceHiddenPropertyVisibility」をTrueにすることで、
すべてのUPROPERTYを表示するようになる。
UObject継承のクラスにいろんなUPROPERTYをつける それをDetailViewで表示する
(Editor Utility WidgetのEventGraph)
Details View Widget
bForceHiddenPropertyVisibility
= False
bForceHiddenPropertyVisibility
= True
このように表示される
プロパティを制御できる
Single Property View Widget
Single Property View Widget
Details View同様プロパティを表示するものだが、
こちらは「PropertyName」を指定して使う。指定したPropertyNameの
プロパティのみ表示してくれる。
プロパティの一つを表示してくれる!
超便利!
Single Property View Widget
• PropertyNameは正しく指定すること。特にbool。
(例えば、エディター上はSceneComponentの「bVisible」というプロパティは
エディター上では「Visible」となっており勘違いしやすい。
正しく「bVisible」と入力する。
Editorで表示される名前じゃなく
実際の変数名で指定するのを気を付ける!
Single Property View Widget
• 「NameOverreide」というプロパティに任意の文字を入れることで、
表示される名前が入力した文字になる。
• 表示できるプロパティに制約が多い(次スライド)
任意の文字を入力
表示名が変化!
Single Property View Widget
• Details Viewとは違いどんなプロパティでも表示できるわけではない。
( bForceHiddenPropertyVisibilityは設定できない)
→ 「PropertyFlags」に「CPF_Edit」をもつUPROPERTYのみ。
・さらに、
UStructProperty,UArrayProperty,UMapProperty,USetProperty
なプロパティも設定できない。
(つまり構造体とか配列とかを設定することはできない)
※SinglePropertyView.cpp参照
FVectorとかも構造体だから
ダメなんだ…RootComponentが持っている変数
「RelativeLocation」を設定
反映されない
Help Text
Help Text
ClassDefaultで設定
Content Browserで
「HelpText=…」と入力
Content Browser上で補助的な検索ワードとなる文字を設定できる。
→どんな機能なのかをあらかじめ記載しておけば、そのテキストで検索が可能。
(UPROPERTY(AssetRegistrySearchable)なプロパティです)
Editor Utility Widgetの罠
その1
• 通常のBlueprintを作成する方法でEUWを作成した場合は、
EUWアセット右クリック→「Run Editor Utility Widget」が使えません
「Editor Utilities」から作成しましょう。
※Runが使えない以外は特に問題はなさそうです。
その2
実はEUWを一度実行してEUWを消しても、EUWのインスタンスは残っています。
→EUWのBPをコンパイルするとリセットされます!
(もしくは他のGCのタイミングで消える)
実行&消す 3つ…?
DebugFilterみると
残っているのがわかる
実行&消す
実行&消す
その3
• EUWがActorではないため、WorldContextが必要な関数があります。
そして、プレイ中か非プレイ中かで、指定するWorldContextが変わってきます。
→FWorldContext
• プレイ中なら「Get Game World」非プレイ中なら「Get Editor World」
でWorldContext用のオブジェクトを取得しよう!
(Editor Scripting Utilitiesプラグインを有効にする必要あり)
WorldContextオブジェクトが必要な関数 これらの関数の返り値をつなげることで、機能するようになる
その4
• Actorの参照をもったまま、別のレベルを開いたりしようとすると
クラッシュします。気を付けましょう。
※変数に保持するだけなら問題なさそうでした。
→Details View系のWidgetの参照が残ってるとクラッシュする。
EUWを開いたまま
別マップを開こうとする
くらっしゅ!!
このクラッシュの回避方法
(レベル遷移時に自動でEUWを消す方法)
まずは、実行中のEUWをBPで消す方法
• EditorUtilitySubsystem.cppの「SpawnAndRegisterTab()」内の
タブを取得する部分をコピーして使用する。
実行中のEUWをBPで消す方法
この辺りをコピー!
実行中のEUWをBPで消す方法
RequestCloseTab()を追加!
いらないところは消す!
• 自作のFunctionLibraryクラスにペーストする。
→SDockTabの関数「RequestCloseTab()」を使ってウィンドウを消す。
LevelEditor.hをinclude
実行中のEUWをBPで消す方法
• Header
実行中のEUWをBPで消す方法
• Moduleは「Blutility,UMGEditor,Slate」の3つを追加
実行中のEUWをBPで消す方法
• ブループリント側
EUWにButtonを登録
それが押されたら、
自身のEUWアセットを指定し、そのEUWを消す
実行中のEUWをBPで消す方法
• 結果 消せた!!
gif
次は、レベルを開く際のイベントをバインド
レベル遷移時に自動でEUWを消す方法
• EUWを継承したクラスを作成
• C++の中身追加部分
UUserWidget::Initialize()の
オーバーライド
(アセットを開いた時のデリゲートを
バインド)
バインド
デリゲートされる処理の中身
開いたアセットが「レベル(UWorld*)」
であれば、EUWを消す。
レベル遷移時に自動でEUWを消す方法
レベルを開く際、
UAssetEditorSubsystem::OnAssetEditorRequestedOpen()
がデリゲートされるので、そのイベントを受け取って、EUWを消す
通常のEUWクラス 作成したEUWクラス
作成したEUWクラスの
ClassDefaultで、
「EUWBPRef」に、
作成した自身のBPアセットを設定する。
レベル遷移時に自動でEUWを消す方法
• ブループリント側(例)
• 結果
レベル遷移時に自動でEUWを消す方法
くらっしゅ回避!!ばいばいエディター!!通常のEUWクラス 作成したEUWクラス
gif gif
Editor Utility Widgetの制作事例
①エディター上でWebを表示
「Web Browser」プラグインを
有効にすることで、「Web Browser」
ウィジェットを使えるようになる。
• 「Web Browser」プラグインをつかうことで、EUW上にWebサイトを表示できる。
ドキュメントなどのリンクを入れることで、いちいちアクティブウィンドウの切り替え
をしなくてもよくなり、すぐにドキュメントに飛んだりできる。
gif
②配置物をPhysicsで設置させる
• LandScapeなどに箱などを設置させるときに、いちいちRotationを細かく
設定するのは面倒です。なので、SimulateしたPhysicsの結果をそのまま
Transformに上書きするEUWを作成。(ブループリントオンリー)
gif
③AssetのFavorite機能
• 選択したアセットをお気に入りに登録できるツール。
Content Browserにはフォルダのお気に入りしかないので、
アセットのお気に入りを自作。
gif
④ScriptEditor
• 自社用に作っているScript用のプラグインのScriptEditor。
関数名をプルダウンで選んだり、引数のデフォルト値を勝手に入力して
くれる。(まだ試作)
このようなテキスト形式で管理!
gif
⑤自動ダンジョン生成ツール
• あらかじめいくつかのマップの部品を作成しておくことで、
自動でその部品を指定した数・アルゴリズムでつなげてくれるツール。
レギュレーションをアルゴリズムに取り込んでおり、一瞬でいろんなパターン
を作成できる。
通路の部品クラスをもったデータアセット
生成する部品クラスの出現ウェイト
生成する部品の数
分岐の数や連続する部品の種類の
ランダムな範囲のカーブアセット
生成失敗したときに再試行する回数
最初や最後の部品を固定するフラグ
生成するアルゴリズムのクラス
gif
以上
ご清聴ありがとうございました
お疲れ様です!

More Related Content

What's hot

What's hot (20)

非同期ロード画面 Asynchronous Loading Screen
非同期ロード画面 Asynchronous Loading Screen非同期ロード画面 Asynchronous Loading Screen
非同期ロード画面 Asynchronous Loading Screen
 
豚×京都 ~UE4でなろう破壊神~ (UE4 VFX Art Dive)
豚×京都 ~UE4でなろう破壊神~ (UE4 VFX Art Dive)豚×京都 ~UE4でなろう破壊神~ (UE4 VFX Art Dive)
豚×京都 ~UE4でなろう破壊神~ (UE4 VFX Art Dive)
 
猫でも分かる UE4の新しいサンプル「Action RPG」について
猫でも分かる UE4の新しいサンプル「Action RPG」について猫でも分かる UE4の新しいサンプル「Action RPG」について
猫でも分かる UE4の新しいサンプル「Action RPG」について
 
猫でも分かるUE4.22から入ったSubsystem
猫でも分かるUE4.22から入ったSubsystem 猫でも分かるUE4.22から入ったSubsystem
猫でも分かるUE4.22から入ったSubsystem
 
UE4 MultiPlayer Online Deep Dive 基礎編2 -Traveling- (historia様ご講演) #ue4dd
UE4 MultiPlayer Online Deep Dive 基礎編2 -Traveling-  (historia様ご講演)  #ue4ddUE4 MultiPlayer Online Deep Dive 基礎編2 -Traveling-  (historia様ご講演)  #ue4dd
UE4 MultiPlayer Online Deep Dive 基礎編2 -Traveling- (historia様ご講演) #ue4dd
 
Editor Utility Widgetで色々便利にしてみた。
Editor Utility Widgetで色々便利にしてみた。Editor Utility Widgetで色々便利にしてみた。
Editor Utility Widgetで色々便利にしてみた。
 
UE4 コリジョン検証 -HitとOverlapイベントが発生する条件について-
UE4 コリジョン検証 -HitとOverlapイベントが発生する条件について-UE4 コリジョン検証 -HitとOverlapイベントが発生する条件について-
UE4 コリジョン検証 -HitとOverlapイベントが発生する条件について-
 
そう、UE4ならね。あなたのモバイルゲームをより快適にする沢山の冴えたやり方について Part 2 <Texture Streaming, メモリプロ...
  そう、UE4ならね。あなたのモバイルゲームをより快適にする沢山の冴えたやり方について Part 2 <Texture Streaming, メモリプロ...  そう、UE4ならね。あなたのモバイルゲームをより快適にする沢山の冴えたやり方について Part 2 <Texture Streaming, メモリプロ...
そう、UE4ならね。あなたのモバイルゲームをより快適にする沢山の冴えたやり方について Part 2 <Texture Streaming, メモリプロ...
 
猫でも分かるUE4のポストプロセスを使った演出・絵作り
猫でも分かるUE4のポストプロセスを使った演出・絵作り猫でも分かるUE4のポストプロセスを使った演出・絵作り
猫でも分かるUE4のポストプロセスを使った演出・絵作り
 
UE4における大規模背景制作事例 描画特殊表現編
UE4における大規模背景制作事例 描画特殊表現編UE4における大規模背景制作事例 描画特殊表現編
UE4における大規模背景制作事例 描画特殊表現編
 
[CEDEC2018] UE4で多数のキャラクターを生かすためのテクニック
[CEDEC2018] UE4で多数のキャラクターを生かすためのテクニック[CEDEC2018] UE4で多数のキャラクターを生かすためのテクニック
[CEDEC2018] UE4で多数のキャラクターを生かすためのテクニック
 
Unreal Engine 4を使って地球を衛る方法
Unreal Engine 4を使って地球を衛る方法Unreal Engine 4を使って地球を衛る方法
Unreal Engine 4を使って地球を衛る方法
 
UE4のローカライズ機能紹介 (UE4 Localization Deep Dive)
UE4のローカライズ機能紹介 (UE4 Localization Deep Dive)UE4のローカライズ機能紹介 (UE4 Localization Deep Dive)
UE4のローカライズ機能紹介 (UE4 Localization Deep Dive)
 
UE4における自動プレイのポストモーテム
UE4における自動プレイのポストモーテム  UE4における自動プレイのポストモーテム
UE4における自動プレイのポストモーテム
 
「Press Button, Drink Coffee」 UE4における ビルドパイプラインとメンテナンスの全体像
「Press Button, Drink Coffee」 UE4における ビルドパイプラインとメンテナンスの全体像「Press Button, Drink Coffee」 UE4における ビルドパイプラインとメンテナンスの全体像
「Press Button, Drink Coffee」 UE4における ビルドパイプラインとメンテナンスの全体像
 
【UE4.25 新機能】ロードの高速化機能「IOStore」について
【UE4.25 新機能】ロードの高速化機能「IOStore」について【UE4.25 新機能】ロードの高速化機能「IOStore」について
【UE4.25 新機能】ロードの高速化機能「IOStore」について
 
第2回UE4勉強会 in 大阪 - マテリアル基礎・初級
第2回UE4勉強会 in 大阪 - マテリアル基礎・初級第2回UE4勉強会 in 大阪 - マテリアル基礎・初級
第2回UE4勉強会 in 大阪 - マテリアル基礎・初級
 
UE4とUnrealC++について
UE4とUnrealC++についてUE4とUnrealC++について
UE4とUnrealC++について
 
UE4のライティング解体新書~効果的なNPRのためにライティングの仕組みを理解しよう~
UE4のライティング解体新書~効果的なNPRのためにライティングの仕組みを理解しよう~UE4のライティング解体新書~効果的なNPRのためにライティングの仕組みを理解しよう~
UE4のライティング解体新書~効果的なNPRのためにライティングの仕組みを理解しよう~
 
メカアクションゲーム『DAEMON X MACHINA』 信念と血と鋼鉄の開発事例
メカアクションゲーム『DAEMON X MACHINA』 信念と血と鋼鉄の開発事例メカアクションゲーム『DAEMON X MACHINA』 信念と血と鋼鉄の開発事例
メカアクションゲーム『DAEMON X MACHINA』 信念と血と鋼鉄の開発事例
 

Similar to Editor Utility Widget Petit Deep Dive

Unity2DとNewGUIについて
Unity2DとNewGUIについてUnity2DとNewGUIについて
Unity2DとNewGUIについて
Keigo Ando
 
ゲームエンジン導入セミナー【UDK編】
ゲームエンジン導入セミナー【UDK編】ゲームエンジン導入セミナー【UDK編】
ゲームエンジン導入セミナー【UDK編】
Junya "Jun" Shimoda
 

Similar to Editor Utility Widget Petit Deep Dive (20)

UE4制作におけるゲームデザイナーのやれること
UE4制作におけるゲームデザイナーのやれることUE4制作におけるゲームデザイナーのやれること
UE4制作におけるゲームデザイナーのやれること
 
UE4のシーケンサーをもっともっと使いこなそう!最新情報・Tipsをご紹介!
UE4のシーケンサーをもっともっと使いこなそう!最新情報・Tipsをご紹介!UE4のシーケンサーをもっともっと使いこなそう!最新情報・Tipsをご紹介!
UE4のシーケンサーをもっともっと使いこなそう!最新情報・Tipsをご紹介!
 
ゲームエンジンの文法【UE4】No.003 最初のプロジェクト: UE4 Editorのインターフェイスを学ぶ
ゲームエンジンの文法【UE4】No.003 最初のプロジェクト: UE4 Editorのインターフェイスを学ぶゲームエンジンの文法【UE4】No.003 最初のプロジェクト: UE4 Editorのインターフェイスを学ぶ
ゲームエンジンの文法【UE4】No.003 最初のプロジェクト: UE4 Editorのインターフェイスを学ぶ
 
[CEDEC+KYUSHU 2017] 最新モバイルゲームの実例からみるUE4のモバイル向け機能・Tipsを全部まるっとご紹介! + UE4.18 モバイ...
[CEDEC+KYUSHU 2017] 最新モバイルゲームの実例からみるUE4のモバイル向け機能・Tipsを全部まるっとご紹介! + UE4.18 モバイ...[CEDEC+KYUSHU 2017] 最新モバイルゲームの実例からみるUE4のモバイル向け機能・Tipsを全部まるっとご紹介! + UE4.18 モバイ...
[CEDEC+KYUSHU 2017] 最新モバイルゲームの実例からみるUE4のモバイル向け機能・Tipsを全部まるっとご紹介! + UE4.18 モバイ...
 
Editor スクリプティング 入門
Editor スクリプティング 入門Editor スクリプティング 入門
Editor スクリプティング 入門
 
[CEDEC2017] 最新モバイルゲームの実例からみるUE4のモバイル向け機能・Tipsを全部まるっとご紹介!
[CEDEC2017] 最新モバイルゲームの実例からみるUE4のモバイル向け機能・Tipsを全部まるっとご紹介![CEDEC2017] 最新モバイルゲームの実例からみるUE4のモバイル向け機能・Tipsを全部まるっとご紹介!
[CEDEC2017] 最新モバイルゲームの実例からみるUE4のモバイル向け機能・Tipsを全部まるっとご紹介!
 
エンタープライズ分野向けUE4最新機能のご紹介
エンタープライズ分野向けUE4最新機能のご紹介エンタープライズ分野向けUE4最新機能のご紹介
エンタープライズ分野向けUE4最新機能のご紹介
 
Unity2DとNewGUIについて
Unity2DとNewGUIについてUnity2DとNewGUIについて
Unity2DとNewGUIについて
 
DIYエフェクト実装: エンジニアレスでエフェクトを組み込める環境づくり
DIYエフェクト実装: エンジニアレスでエフェクトを組み込める環境づくりDIYエフェクト実装: エンジニアレスでエフェクトを組み込める環境づくり
DIYエフェクト実装: エンジニアレスでエフェクトを組み込める環境づくり
 
【Unite 2017 Tokyo】DIYエフェクト実装: エンジニアレスでエフェクトを組み込める環境づくり
【Unite 2017 Tokyo】DIYエフェクト実装: エンジニアレスでエフェクトを組み込める環境づくり【Unite 2017 Tokyo】DIYエフェクト実装: エンジニアレスでエフェクトを組み込める環境づくり
【Unite 2017 Tokyo】DIYエフェクト実装: エンジニアレスでエフェクトを組み込める環境づくり
 
ニコニコ超開発
ニコニコ超開発ニコニコ超開発
ニコニコ超開発
 
シーケンサーの使い方と映像基礎
シーケンサーの使い方と映像基礎シーケンサーの使い方と映像基礎
シーケンサーの使い方と映像基礎
 
ゲームエンジン導入セミナー【UDK編】
ゲームエンジン導入セミナー【UDK編】ゲームエンジン導入セミナー【UDK編】
ゲームエンジン導入セミナー【UDK編】
 
建築革命、更に更に進化!便利さ向上【Unity Reflect ver 3.0 】
建築革命、更に更に進化!便利さ向上【Unity Reflect ver 3.0 】建築革命、更に更に進化!便利さ向上【Unity Reflect ver 3.0 】
建築革命、更に更に進化!便利さ向上【Unity Reflect ver 3.0 】
 
UE4のモバイル向け機能や最新情報などを改めて紹介!2019
UE4のモバイル向け機能や最新情報などを改めて紹介!2019UE4のモバイル向け機能や最新情報などを改めて紹介!2019
UE4のモバイル向け機能や最新情報などを改めて紹介!2019
 
YouTube APIの紹介
YouTube APIの紹介YouTube APIの紹介
YouTube APIの紹介
 
Unityの最新動向と開発事例
Unityの最新動向と開発事例Unityの最新動向と開発事例
Unityの最新動向と開発事例
 
【eVar7】UX4KPI_web担当者forum_part1.2
【eVar7】UX4KPI_web担当者forum_part1.2【eVar7】UX4KPI_web担当者forum_part1.2
【eVar7】UX4KPI_web担当者forum_part1.2
 
【Unity Reflect】足りない要素を追加してみよう~開発導入編~
【Unity Reflect】足りない要素を追加してみよう~開発導入編~【Unity Reflect】足りない要素を追加してみよう~開発導入編~
【Unity Reflect】足りない要素を追加してみよう~開発導入編~
 
【CEDEC2018】一歩先のUnityでのパフォーマンス/メモリ計測、デバッグ術
【CEDEC2018】一歩先のUnityでのパフォーマンス/メモリ計測、デバッグ術【CEDEC2018】一歩先のUnityでのパフォーマンス/メモリ計測、デバッグ術
【CEDEC2018】一歩先のUnityでのパフォーマンス/メモリ計測、デバッグ術
 

Editor Utility Widget Petit Deep Dive