13.4K Views
October 08, 19
スライド概要
2019年10月6日に行われた「UNREAL FEST EAST 2019」における「「SAMURAI SPIRITS」におけるエフェクトの実装例」の登壇資料です。
●公式サイト
https://unrealengine.jp/unrealfest/
===
前半 エフェクトツール「Effekseer」を使ったエフェクト制作事例のご紹介
後半 エフェクトツール内にある機能をUE4で実現する際に問題になった点やその解決法のご紹介
Unreal Engineを開発・提供しているエピック ゲームズ ジャパンによる公式アカウントです。 勉強会や配信などで行った講演資料を公開しています。 公式サイトはこちら https://www.unrealengine.com/ja/
エフェクトツール機能の実装例 株式会社 SNK 大前 祐人 #ue4fest
自己紹介 大前 祐人 株式会社 SNK ゲームプログラマー 2018年入社、業歴2年目 今年発売の「SAMURAI SPIRITS」ではエフェクトツールの開発を担当 #ue4fest
注意事項 ※UE4.22で実装し直したものになります ・ゲームはUE4.21を使用しています ※実装例では1つのMaterialで完結するようにしています ・実際にゲームで使用した物と相違している部分があります #ue4fest
目次 ① Effekseerについて ② フェイスカリング実装例 ③ エフェクト反転時のテクスチャ反転防止例 ④ アルファクランチ実装例 ⑤ フレームブレンド実装例 ⑥ 背景エフェクトが出ない問題とその解決 #ue4fest
目次 ① Effekseerについて ② フェイスカリング実装例 ③ エフェクト反転時のテクスチャ反転防止例 ④ アルファクランチ実装例 ⑤ フレームブレンド実装例 ⑥ 背景エフェクトが出ない問題とその解決 #ue4fest
#ue4fest
Effekseerの紹介 • Effekseerとは オープンソースで開発されているエフェクトツール GitHub上で公開されている (9/12時点の最新バージョンは1.43b) #ue4fest
Effekseerの紹介 • Effekseerとは オープンソースで開発されているエフェクトツール GitHub上で公開されている (9/12時点の最新バージョンは1.43b) • 今回行った拡張について 1.31をベースに独自機能の拡張 #ue4fest
目次 ① Effekseerについて ② フェイスカリング実装例 ③ エフェクト反転時のテクスチャ反転防止例 ④ アルファクランチ実装例 ⑤ フレームブレンド実装例 ⑥ 背景エフェクトが出ない問題とその解決 #ue4fest
フェイスカリング実装例 裏面カリング 表面カリング カリング無し #ue4fest
フェイスカリング実装例 ・どんな機能? #ue4fest
フェイスカリング実装例 ・どんな機能? ・指定した向きの面を非表示 #ue4fest
フェイスカリング実装例 ・どんな機能? ・指定した向きの面を非表示 ・既存の設定で解決できない? #ue4fest
フェイスカリング実装例 ・どんな機能? ・指定した向きの面を非表示 ・既存の設定で解決できない? ・Material内のTwoSidedでは、表面か両面表示しか選べない #ue4fest
フェイスカリング実装例 ・どんな機能? ・指定した向きの面を非表示 ・既存の設定で解決できない? ・Material内のTwoSidedでは、表面か両面表示しか選べない ・裏面表示が無いので作る #ue4fest
フェイスカリング実装例 ・実装の肝「TwoSidedSign」 #ue4fest
フェイスカリング実装例 ・実装の肝「TwoSidedSign」 ・表面なら+1.0, 裏面なら-1.0を出力 #ue4fest
フェイスカリング実装例 ・実装の肝「TwoSidedSign」 ・表面なら+1.0, 裏面なら-1.0を出力 ・公式Documentでは法線の反転に使用 #ue4fest
フェイスカリング実装例 ・実装の肝「TwoSidedSign」 ・表面なら+1.0, 裏面なら-1.0を出力 ・公式Documentでは法線の反転に使用 ・板ポリの1枚でトランプが出来る #ue4fest
フェイスカリング実装例 ・実装方法 #ue4fest
フェイスカリング実装例 ・実装方法 ・「TwoSided」を有効 #ue4fest
フェイスカリング実装例 ・実装方法 ・「TwoSided」を有効 ・カリング面を指定出来るパラメータを追加 #ue4fest
フェイスカリング実装例 ・実装方法 ・「TwoSided」を有効 ・カリング面を指定出来るパラメータを追加 ・消したい面のαを0、表示したい面のαを1になるように計算 #ue4fest
フェイスカリング実装例 ・実装 #ue4fest
フェイスカリング実装例 ・全体像 #ue4fest
フェイスカリング実装例 ・完成 #ue4fest
目次 ① Effekseerについて ② フェイスカリング実装例 ③ エフェクト反転時のテクスチャ反転防止例 ④ アルファクランチ実装例 ⑤ フレームブレンド実装例 ⑥ 背景エフェクトが出ない問題とその解決 #ue4fest
エフェクト反転時のテクスチャ反転防止例 #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・エフェクトが反転とは? #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・エフェクトが反転とは? ・2P側のエフェクトはXスケールが-1.0倍される #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・エフェクトが反転とは? ・2P側のエフェクトはXスケールが-1.0倍される ・頂点のX座標が反転する為、テクスチャの向きが変わる #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・実装の肝「Xスケールの符号」 #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・実装の肝「Xスケールの符号」 ・マテリアル関数、ObjectScaleの検討 #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・実装の肝「Xスケールの符号」 ・マテリアル関数、ObjectScaleの検討 ・取得出来るのがスケールの大きさなので 今回は使えない #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・計算で「Xスケールの符号」を求める #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・計算で「Xスケールの符号」を求める ・+方向のX軸と、オブジェクトのX軸との内積で判定 #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・計算で「Xスケールの符号」を求める ・+方向のX軸と、オブジェクトのX軸との内積で判定 ※+方向のX軸(左手座標系) #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・計算で「Xスケールの符号」を求める ・+方向のX軸と、オブジェクトのX軸との内積で判定 ※+方向のX軸(左手座標系) ※変換後の向き(-スケールの場合) #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・+方向のX軸を求める #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・+方向のX軸を求める ・Cross(WorldY軸, WorldZ軸)で求める #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・+方向のX軸を求める ・Cross(WorldY軸, WorldZ軸)で求める ※+方向のX軸もワールドで求める (オブジェクトのX軸はワールド変換で取得する為) #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・+方向のX軸を求める ・Cross(WorldY軸, WorldZ軸)で求める ※+方向のX軸もワールドで求める (オブジェクトのX軸はワールド変換で取得する為) = #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・オブジェクトのX軸を求める #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・オブジェクトのX軸を求める ・V(1, 0, 0)をTransformVector(Local To World)するだけ = #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・+方向のX軸と、オブジェクトのX軸で内積を求める #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・+方向のX軸と、オブジェクトのX軸で内積を求める #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・+方向のX軸と、オブジェクトのX軸で内積を求める ・+スケールの場合は1.0, -スケールの場合は-1.0が得られる #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・内積結果をUV反転で使いやすい様に加工 #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・内積結果をUV反転で使いやすい様に加工 ・+スケール = 0.0, -スケール = 1.0 になるように加工 ・例) 1.0 - Clamp(dot, 0.0, 1.0) #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・UV値に対して計算を行う #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・UV値に対して計算を行う ・(加工後の値 – U値)で反転 #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・UV値に対して計算を行う ・(加工後の値 – U値)で反転 ・+スケールの場合Absで絶対値に ※0.0 – U = -U #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・最後にTextureのUVsに繋ぐ #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・全体像 #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・完成 反転防止あり 反転防止なし #ue4fest
エフェクト反転時のテクスチャ反転防止例 ・完成 #ue4fest
目次 ① Effekseerについて ② フェイスカリング実装例 ③ エフェクト反転時のテクスチャ反転防止例 ④ アルファクランチ実装例 ⑤ フレームブレンド実装例 ⑥ 背景エフェクトが出ない問題とその解決 #ue4fest
アルファクランチの実装例 #ue4fest
アルファクランチの実装例 ・どんな機能? #ue4fest
アルファクランチの実装例 ・どんな機能? ・Dissolve #ue4fest
アルファクランチの実装例 ・どんな機能? ・Dissolve ・閾値を設定、その閾値以下のα値を切り捨てる #ue4fest
アルファクランチの実装例 ・どんな機能? ・Dissolve ・閾値を設定、その閾値以下のα値を切り捨てる ・動的に閾値を変える事で千切れを表現 #ue4fest
アルファクランチの実装例 ・閾値 #ue4fest
アルファクランチの実装例 ・閾値 ・0~1の範囲を指定 #ue4fest
アルファクランチの実装例 ・閾値 ・0~1の範囲を指定 ・(α値 - 閾値)が0.0以下の部分が表示されない #ue4fest
アルファクランチの実装例 ・閾値 ・0~1の範囲を指定 ・(α値 - 閾値)が0.0以下の部分が表示されない ・サンプルではTimeノードを使用、実際に使用する場合は動 的パラメータを使用する #ue4fest
アルファクランチの実装例 ・実装 #ue4fest
アルファクランチの実装例 ・実装 ・α値から閾値を引き、Ceilノードで二値化 #ue4fest
アルファクランチの実装例 ・実装 ・α値から閾値を引き、Ceilノードで二値化 ・そのままオパシティマスク(オパシティ)に繋ぐ #ue4fest
アルファクランチの実装例 ・一旦完成 #ue4fest
アルファクランチの実装例 ・エッジに色を付ける #ue4fest
アルファクランチの実装例 ・エッジに色を付ける ・EdgeThreshold #ue4fest
アルファクランチの実装例 ・エッジに色を付ける ・EdgeThreshold ・この数値以下のα値の 部分に色を付ける #ue4fest
アルファクランチの実装例 ・エッジに色を付ける ・EdgeThreshold ・この数値以下のα値の 部分に色を付ける ・Ceilで二値化して線形補間 #ue4fest
アルファクランチの実装例 ・全体像 #ue4fest
アルファクランチの実装例 ・完成 #ue4fest
目次 ① Effekseerについて ② フェイスカリング実装例 ③ エフェクト反転時のテクスチャ反転防止例 ④ アルファクランチ実装例 ⑤ フレームブレンド実装例 ⑥ 背景エフェクトが出ない問題とその解決 #ue4fest
フレームブレンドの実装例 #ue4fest
フレームブレンドの実装例 ・どんな機能? #ue4fest
フレームブレンドの実装例 ・どんな機能? ・フリップブックテクスチャのカラーを補間 #ue4fest
フレームブレンドの実装例 ・どんな機能? ・フリップブックテクスチャのカラーを補間 ・数フレーム毎にテクスチャの切り替える場合や スローモーションになる場合に有効 #ue4fest
フレームブレンドの実装例 ・どんな機能? ・フリップブックテクスチャのカラーを補間 ・数フレーム毎にテクスチャの切り替える場合や スローモーションになる場合に有効 ・実装方法 #ue4fest
フレームブレンドの実装例 ・どんな機能? ・フリップブックテクスチャのカラーを補間 ・数フレーム毎にテクスチャの切り替える場合や スローモーションになる場合に有効 ・実装方法 ・現在のフレームの色と次のフレームのカラーを線形補間 #ue4fest
フレームブレンドの実装例 ・実装 #ue4fest
フレームブレンドの実装例 ・実装 ・Flipbook用にUVを変換するMFを実装 #ue4fest
フレームブレンドの実装例 ・実装 ・Flipbook用にUVを変換するMFを実装 #ue4fest
フレームブレンドの実装例 ・MF_FlipbookUVの実装 #ue4fest
フレームブレンドの実装例 ・MF_FlipbookUVの実装 ①UVを1枚分のサイズに ②UVを描画したい画像までオフセット ① ② #ue4fest
フレームブレンドの実装例 ・MF_FlipbookUVの実装 ・UVの開始地点、UVのサイズを求める #ue4fest
フレームブレンドの実装例 ・MF_FlipbookUVの実装 ・UVの開始地点、UVのサイズを求める ・UVのサイズを変換、UV開始地点までオフセット #ue4fest
フレームブレンドの実装例 ・現在の画像番号を取得 #ue4fest
フレームブレンドの実装例 ・現在の画像番号を取得 ・0~(最大枚数-1) #ue4fest
フレームブレンドの実装例 ・現在の画像番号を取得 ・0~(最大枚数-1) ・サンプルでは右図の通り ・実際にはライフタイムや次のテク スチャまでのフレーム数で計算す る形に #ue4fest
フレームブレンドの実装例 ・UV値の取得 #ue4fest
フレームブレンドの実装例 ・UV値の取得 ・MF_FlipbookUVを使用 ・現在のテクスチャのUV ・次のテクスチャのUV #ue4fest
フレームブレンドの実装例 ・カラーの取得と補間 #ue4fest
フレームブレンドの実装例 ・カラーの取得と補間 ・それぞれのカラーを取得 ・現在フレームの小数値で 線形補間 #ue4fest
フレームブレンドの実装例 ・全体像 #ue4fest
フレームブレンドの実装例 ・完成 ブレンドなし ブレンドあり #ue4fest
目次 ① Effekseerについて ② フェイスカリング実装例 ③ エフェクト反転時のテクスチャ反転防止例 ④ アルファクランチ実装例 ⑤ フレームブレンド実装例 ⑥ 背景エフェクトが出ない問題とその解決 #ue4fest
背景エフェクトが出ない問題とその解決 #ue4fest
背景エフェクトが出ない問題とその解決 ・現象 #ue4fest
背景エフェクトが出ない問題とその解決 ・現象 ・レベル上に配置した背景エフェクトが表示されない #ue4fest
背景エフェクトが出ない問題とその解決 ・現象 ・レベル上に配置した背景エフェクトが表示されない ・他のステージだと表示されている #ue4fest
背景エフェクトが出ない問題とその解決 ・原因 #ue4fest
背景エフェクトが出ない問題とその解決 ・原因 ・レベル上に配置されているアクターの初期化順がバラバラ #ue4fest
背景エフェクトが出ない問題とその解決 ・原因 ・レベル上に配置されているアクターの初期化順がバラバラ ・背景エフェクトの初期化時に、依存先のアクターの初期 化が行われていなかった #ue4fest
背景エフェクトが出ない問題とその解決 ・原因 ・レベル上に配置されているアクターの初期化順がバラバラ ・背景エフェクトの初期化時に、依存先のアクターの初期 化が行われていなかった ・他のステージで表示されていたのは、運よく初期化順が正しい 順番で行われていた為 #ue4fest
背景エフェクトが出ない問題とその解決 ・EffekseerPluginの構造 #ue4fest
背景エフェクトが出ない問題とその解決 ・EffekseerPluginの構造 ・EffekseerSystemComponent(以下EfkSystem) ・エフェクトを更新、描画 #ue4fest
背景エフェクトが出ない問題とその解決 ・EffekseerPluginの構造 ・EffekseerSystemComponent(以下EfkSystem) ・エフェクトを更新、描画 ・EffekseerEmitterComponent(以下EfkEmitter) ・作成したエフェクトのアセットを設定 ・レベル上に配置、スポーンさせる事で再生、描画 ・EfkSystemを参照する必要がある #ue4fest
背景エフェクトが出ない問題とその解決 ・実際に起こっていた事 #ue4fest
背景エフェクトが出ない問題とその解決 ・実際に起こっていた事 1, EfkEmitterの初期化、再生(EfkSystemに登録) 2, EfkSystemの初期化(再生リストの初期化) #ue4fest
背景エフェクトが出ない問題とその解決 ・実際に起こっていた事 1, EfkEmitterの初期化、再生(EfkSystemに登録) 2, EfkSystemの初期化(再生リストの初期化) ・理想の動作 #ue4fest
背景エフェクトが出ない問題とその解決 ・実際に起こっていた事 1, EfkEmitterの初期化、再生(EfkSystemに登録) 2, EfkSystemの初期化(再生リストの初期化) ・理想の動作 1, EfkSystemの初期化(再生リストの初期化) 2, EfkEmitterの初期化、再生(EfkSystemに登録) #ue4fest
背景エフェクトが出ない問題とその解決 ・解決法(逃げ方) #ue4fest
背景エフェクトが出ない問題とその解決 ・解決法(逃げ方) ・EfkSystemはレベル上に配置したまま #ue4fest
背景エフェクトが出ない問題とその解決 ・解決法(逃げ方) ・EfkSystemはレベル上に配置したまま ・EfkEmitterを配置せずにSpawnActorでタイミングをずらし て生成 #ue4fest
背景エフェクトが出ない問題とその解決 ・解決法(逃げ方) ・EfkSystemはレベル上に配置したまま ・EfkEmitterを配置せずにSpawnActorでタイミングをずらし て生成 ・レベルBPに記述 #ue4fest
背景エフェクトが出ない問題とその解決 ・結果 #ue4fest
背景エフェクトが出ない問題とその解決 ・結果 ・根本の解決は出来なかったが、回避は出来た #ue4fest
背景エフェクトが出ない問題とその解決 ・結果 ・根本の解決は出来なかったが、回避は出来た ・反省点 #ue4fest
背景エフェクトが出ない問題とその解決 ・結果 ・根本の解決は出来なかったが、回避は出来た ・反省点 ・背景エフェクトがあるレベルに毎回処理を書く必要が出た ・後に背景エフェクトに対してロジックを組む必要が出た #ue4fest
背景エフェクトが出ない問題とその解決 ・結果 ・根本の解決は出来なかったが、回避は出来た ・反省点 ・背景エフェクトがあるレベルに毎回処理を書く必要が出た ・後に背景エフェクトに対してロジックを組む必要が出た ・初めからC++に処理を逃がすべきだった #ue4fest
本講演は以上になります #ue4fest
募集中! https://www.snk-corp.co.jp/recruit/index.php ・ゲームプログラマー ・テクニカルデザイナー ・CGデザイナー #ue4fest
ご清聴ありがとうございました #ue4fest