LoginSignup
0
0

More than 3 years have passed since last update.

ブループリントからLevelSeqeuencerへオブジェクトを追加する

Posted at

最近、Unrealengine4.26でブループリントでSeqeuence周りをさわっているのですが、非常に出来る事が増えていました。
しかし、ドキュメントは少なく、手探りで検証を進めた内容をメモとして残しておきます。
作成したブループリントは、エディタユーティリティウィジェットで実行しています。

環境

バージョン : Unrealengine4.26

オブジェクトをLevelSeqeuencerに配置する

ノード説明用のブループリントです。
サンプルAブループリント.png

実行結果です。ブループリント(BP_A)とスケルタルメッシュ(FbxSphere)が追加されます。
実行結果.png

ノードの説明

  • GetCurrentLevelSeqeuenceノード

SequenceEditorで開いているLevelSeqeuencerを取得できます。
当然ですが、LevelSeqeuencerが開かれていない場合は、IsValidが通りません。

GetCurrentLevelSeqeuence.png

  • AddSpawnablefromClassノード

ブループリントをLevelSeqeuencerにBindできます。

AddSpawnableFromClass.png

  • AddSpawnablefromInstanceノード

スケルタルメッシュやスタティックメッシュなどのオブジェクトをLevelSeqeuencerにBindできます。

AddSpawnableFromInstance.png

  • RefreshCurrentLevelSeqeuenceノード

SequenceEditorで開いているLevelSeqeuencerに更新をかけます。
こちらのノードを呼び出さない場合には、SequenceEditorに更新がかからず、LevelSeqeuencerを開き直す必要があります。

RefreshCurrentLevelSeqeuence.png

  • SaveLoadedAssetノード

アセットを保存する事ができます。
サンプルノードの上の例だと、このノードが入っていない為、LevelSeqeuencerは保存されていない状態になっていると思います。
OnlyifisDirtyは、Dirty状態(アスタリスクが付いている)になっているアセットだけを保存するかのフラグとなります。

SaveLoadedAsset.png

LevelSeqeuencerにフォルダを追加する

フォルダとその中にオブジェクトを追加しています。
ブループリントの流れとしては、ルートにフォルダを作成し、各オブジェクトをスポーンし、AddChildPbjectBindingノードを呼んでフォルダに関連付けます。

同じ階層にオブジェクトを追加する_ブループリントの例.png

結果として、以下のようになります。
同じ階層にオブジェクトを追加する_実行結果.png

ノードの説明

  • AddRootFolderToSeqeuenceノード

Sequencerにフォルダを追加します。NewFolderNameは、追加するフォルダ名です。
このノードで返ってくるのは、UMovieSceneFolderになります。

AddRootFolderToSeqeuenceノード.png

  • AddChildObjectBindingノード

AddRootFolderToSeqeuenceノードで追加したフォルダに、オブジェクトを関連付けます。
AddRootFolderToSeqeuenceノードから返されるUMovieSceneFolderを第一引数にすれば、いくつでも同じ階層に置けます。

AddChildObjectBindingノード.png

LevelSeqeuencerに配置したオブジェクトに親子付けする

オブジェクトにフォルダを追加するトラックサンプルです。
親子付けするには、UMovieScene3DAttachTrackUMovieScene3DAttachSectionを使用します。
既に紹介したフォルダは、例外ですが、Sequencerに追加されるオブジェクトは、トラックとセクションを持っています。
トラックの中にセクションがあり、必ず二つとも必要になります。
トラックとセクションは、4.26だけでも多くの種類がブループリントで実装されていますが、必要なプロパティへのアクセスが出来なかったり、セクションに渡す構造体がブループリントからはアクセス出来いない部分もあり、PythonやC++で扱うケースがまだ多いようです。
このサンプルでは、C++でフォローしています。

親子付けする_ブループリントの例.png

結果として以下のようになります。
親子付けする_実行結果.png

ノードの説明

キャストノードの説明は省略します。

  • MakeBindingIDノード

Sequencerに追加する為のBindingIDを作成します。ここで帰って来るのは、FMovieSceneObjectBindingIDになります。

MakeBindingIDノード.png

  • AddTrack & AddSectionノード

AddTrackは、任意のトラックを追加します。今回は使用していませんが、AddSectionも紹介します。
AddSectionも任意のセクションを追加します。ただ、AddTrackで帰ってきたUMovieSceneTrackをそのまま繋ぐため、引数を気にする必要はありません。
AddSectionが実行されれば、トラックに対応したセクションが追加されるようです。

AddTrack_AddSection.png

  • AddConstraintノード

C++で実装が必要だった部分になります。
このノードは、UMovieScene3DConstraintTrackAddConstraintを呼び出しています。
引数は、AddConstraintを実行する為のものです。
ブループリントから、ConstraintBindingIDをUMovieScene3DAttachSectionに渡す方法は、実装されておらず、C++を使用しています。
AddSectionノードを使用していない理由は、AddConstraintで、AddSectionが実行される為です。

AddConstraitノード.png

UMovieScene3DAttachSectionにブループリントからでもアクセス可能な、AttachSocketNameとAttachComponentNameとConstraintBindingIDのセッターが用意されている為、ブループリントで完結するように見えますが現バージョンでは、SetConstraintBindingIDは正しく動作しない為、ConstraintBindingIDを別の方法で渡せれば実現可能かもしれません。

親子付けする_ブループリントの例_ノード紹介.png

  • SetRangeノード

SetRangeは、セクションの範囲を決めます。UMovieSceneSectionで実装されている為、UMovieScene3DAttachSectionに限らず、どのセクションでも使用します。

SetRangeノード.png

SetRangeは、この範囲を設定する為のものです。

SetRange説明.png

  • FrameNumberノード

FrameNumberは、Seqeuencer系の動作で主に使用されています。

FrameNumberノード.png

以上となります。
C++からのフォローがいるとは言え、ブループリントで完結する部分も増えてきました。
今後のバージョンアップに期待です。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0