ギリギリになりましたが、2025/2/11までの無料アセットを紹介します。
ざっくり
SICKA DYNASTYは中華系のお寺や竜の像などが入った環境系です。建物はモジュラー形式なので、そういう舞台が必要になった場合には役に立つかも。重め。
data:image/s3,"s3://crabby-images/cd99e/cd99efd06033c5a085006f17e07ebc7ce575f7ea" alt=""
Clay Potsは土器25個で4GBのちょっとファイルサイズでかすぎアセットですがそのうち3.5GBくらいはライトベイクされた情報とのこと。。。
あと、Lowpoly側も結構ポリゴン数があるとのこと。。。
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
よっしーの環境ではデモレベルが激重でなかなか起動せず未確認。
個人的本命は Ultimate Interaction Manager | Fab
でしたが、マニュアルが簡素でバグも多く、ちょっと現時点ではお薦めし難い内容でした(;^ω^)
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
Discordに参加して、レシートを管理者に承認されると非公開ページが見れたり、サポートを受けられるとのことです。(英語)
ほかにもたくさんシステム系アセットを作られている方なので、ほかにも使いたいものがある方は検討されてみては。
とはいえ、すべてBPで作られていて、自分でインタラクションシステムを作る際にも参考にできることも多々あるので、勉強がてら中身を見てみるのはおすすめいたします。
実装を説明するのは営業妨害になるので、本記事では、使い方のみ紹介します。
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
たぶん現時点どこよりも詳しい解説記事でしょうw
基本的コンセプトは、
インタラクション(ものを取る・扉開けるなどの作用)させたいものにコンポーネントを追加したら、あとはちょっとした設定だけで、アイコン表示させたり、開始・終了・更新イベントを作れるよ
といったものです。
data:image/s3,"s3://crabby-images/2ac33/2ac331d1baecfc85dee6cba4cb4fecf221e018f5" alt=""
data:image/s3,"s3://crabby-images/22f03/22f0384408743c04efa7ca176b7dd5dd29c39a95" alt=""
data:image/s3,"s3://crabby-images/29caf/29caf4051575d8d48c7600eda5be1df7bbd37a55" alt=""
プレイヤー(操作する側)準備
サードパーソンテンプレートで説明します。
1.IMC_Default に InputAction_Interaction を登録し、Eキーを割当て(なんでもOK)
data:image/s3,"s3://crabby-images/7919c/7919cccad12c1993d2ce1ba0b16b679d63cd4a4e" alt=""
2. ワールドセッティング(or ゲームモード)で プレイヤーコントローラ を新規作成し設定
data:image/s3,"s3://crabby-images/fa9e0/fa9e0032789653f231a55d37a0b213744b376da0" alt=""
ここでは NewPlayerController という名前にしています。
3. NewPlayerController に Manager_InteractionTarget を追加
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
キーアサイン設定処理は、サードパーソンテンプレートではBP_ThirdPersonCharacterでやっているので必要ありません。
※ ローカル判定している処理を追加したほうがいいかもしれませんが、バグが多そうなのでサーバーでは使えないかも。。。
4.リスポーンとかキャラ変・キーマップ変更する場合は、PlayerController_Interaction の下側の処理をコピペでつなぐ
data:image/s3,"s3://crabby-images/2a846/2a8467eab61b550533284ac9c5b33e7ae43f5e11" alt=""
もの側の設定
1. 対話したいアクタに Manager_InteractionTarget コンポーネントを追加
data:image/s3,"s3://crabby-images/fe994/fe9945ca0acc0746738a02966075330c33510de2" alt=""
2. 詳細/Interaction Settings / Interaction Typeをえらぶ
Tap ワンタップ・Hold 長押し・Repeat 連打
3. 詳細欄下のほう On Interaction** イベントを使って、やりたい処理を実装する
data:image/s3,"s3://crabby-images/80152/801523ae1ab1c0907b0c10487b1dff827ac112f4" alt=""
- Begin 開始 必ず動く
- End 終了 たぶん必ず動く : ステータス 完了 / キャンセル
- Update 更新 : alpha 進捗率、 Repeated 連打回数
- Reactivated 再起動 EndのあとDuration経過後
- Deactivated 停止 EndのあとDuration経過後
Begin/End は開始直後、終了時に必ず動く
End は連打・長押しを途中でやめた場合も動く(Resultの列挙子で完了/キャンセルが判別可)
data:image/s3,"s3://crabby-images/75047/750473f7b48087e27b98d5c84bbfcb0a86082629" alt=""
更新は長押し・連打用。Alphaで進捗率0~1、Repeatedで連打の回数カウント。
End後に一発動く場合があるので要注意
data:image/s3,"s3://crabby-images/b0e55/b0e55f71a92bdc9afe1d2bc5149ef90305cd5558" alt=""
data:image/s3,"s3://crabby-images/8488e/8488e026a8e630cab7c135e259a92c3bb2be88e0" alt=""
連打には時間内に次押さないと回数が減るクールダウン時間設定あり
Reactivated (再起動時) / Deactivated (停止時) は終了方法選択次第で動く/動かないケースあり
data:image/s3,"s3://crabby-images/f6874/f6874aafc524d93a2c78cea17603c89bc39971d9" alt=""
使いたい場合は0秒でもいいので「After Duration」を含む「On Finished/Finish Method」を選ぶ
data:image/s3,"s3://crabby-images/62652/626529ccc89949dcfdeb20f6ffaeab4d527d105c" alt=""
困りごと
途中からインタラクト可能に切り替える方法がなさげ
→ コリジョンは動的につくられるので、GetChildComponentなどで検索してNoCollisionにするとか?
用語
POI : Point of Interest 注目する点 ここになんかアイテムあるよ
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
サイレントヒルでアイテムあるところに「〇」でるやつですね
大事そうな設定
- Marker Settings
- Marker Component Name: 目印出す位置をコンポーネント名で指定
- Interaction Settings
- Interaction Zone Component to Attach: コリジョン中心をコンポーネント名で指定
- Inner Zone Radius: 内側コリジョンサイズ 操作できる距離
- Outer Zone Extent: 外側コリジョンサイズ POIアイコンが表示される距離
- Interaction Type: 操作タイプ タップ/連打/長押し
- On Finished
- Finish Method: 作用後の状態 消去/自動復帰/停止 (と操作タイプの組合せで17種類)
Marker Component Name
目印出す位置をコンポーネント名で指定する(指定コンポーネントの原点+オフセットで調整可能)
data:image/s3,"s3://crabby-images/42b77/42b77779716bf3a13cfad0d7d8d36ad6aeb0b078" alt=""
左から MarkerTarget、Cylinder、CollisionTarget、hoge(存在しない場合はアクタ原点)を指定
何もないところを指定したいときはシーンコンポーネントなどを追加する
Interaction Zone Component to Attach
コリジョン中心をコンポーネント名で指定
data:image/s3,"s3://crabby-images/1f2f1/1f2f151600a711ca846243e2e69cedd2ee811856" alt=""
左から MarkerTarget、Cylinder、CollisionTarget、hoge(存在しない場合はアクタ原点)を指定
留意点
- Sphereコリジョンのみ
- レベル編集中は非表示で、ゲーム中の非表示はEnable Debugオン/オフで切り替え可能
Inner Zone Radius / Outer Zone Extent
内 Innerがインタラクション操作可能になる(マーカー表示する)コリジョン
外 OuterがPOI表示するコリジョン
- 内外の中心位置は同じ
- 外径は内径に「追加する」幅指定 かつ 最小10
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
inner100で+extentが10なら外径は110です
Interaction Type
操作タイプ Tap 1回押す/ Repeat 連打/ hold 長押し
data:image/s3,"s3://crabby-images/2ac33/2ac331d1baecfc85dee6cba4cb4fecf221e018f5" alt=""
data:image/s3,"s3://crabby-images/22f03/22f0384408743c04efa7ca176b7dd5dd29c39a95" alt=""
data:image/s3,"s3://crabby-images/29caf/29caf4051575d8d48c7600eda5be1df7bbd37a55" alt=""
Finish Method
17種類 (下記の組み合わせ)
- 終了タイプ
- Destroy: アクタごと破壊される
- Reactivate: 再起動 再度インタラクションできる状態に戻る
- Deactivate: 停止 アクタは残るが使えなくなる
- 状況タイプ
- Completed: 完了
- Cancel: 中断
- タイマー
- なし
- After Duration: End後、〇秒経過後に終了状態に移行
data:image/s3,"s3://crabby-images/62652/626529ccc89949dcfdeb20f6ffaeab4d527d105c" alt=""
その他設定
プレイヤー側
Interactor Manager: プレイヤーコントローラに追加したこのコンポーネントをクリックすると、詳細パネルに設定オプションが表示されます。
data:image/s3,"s3://crabby-images/50229/502299eeade00ad3f3ac601fb5f7aafe5cc838e4" alt=""
Default Widget Pool Size:デフォルトのウィジェットプールサイズ: 再生開始時に作成されるウィジェット数を制御します。このシステムは、メモリを節約するためにウィジェットプールを使用しています。
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
ようは、あらかじめプレイヤーにアイコン用のウィジェットを何個作るか。
Pending Target Check Interval: 保留ターゲットチェック間隔: 保留ターゲットリストをチェックする秒数。ティックと同じように考え、このフロートの値によって保留中のターゲットをチェックし、もし保留中のターゲットがなければ、ティックは全く行われない。
Interaction Input Action: インタラクション入力アクション: インタラクションのために定義する入力アクションのリファレンス。
Widget Screen Margin:ウィジェット画面マージン: 画面の4辺の画面外インジケータのマージンを制御します。
Screen Radius Percent:スクリーン半径パーセント: 0~1 オフスクリーンインジケータの半径をコントロールします。これは、オフスクリーンマーカーにサークルエフェクトを作成します。
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
下2つは設定変えてもよくわかりませんでした(;’∀’)
もの側
Display Progress: 進捗を表示するフラグ: プログレスバーの表示をコントロールします。false の場合、進捗を表示する代わりにランダムなアニメーションを再生します。
Display Triangle: 三角形を表示するフラグ: プログレスバーに三角形のアイコンを表示します。
Flash POI/Target Icon: マーカーを点滅させるかフラグ
Rotate Interaction Icon: プログレスバーのアイコンを回転させるかフラグ
Colors And Icons: 色とアイコン設定
Highlight Settings アウトライン強調によりハイライトさせるもの指定。コンポーネント単位で配列へ登録。そのひとつひとつにアウトラインシェーダが適用されます。
Interaction Text: 各インタラクション状態のテキストを追加します。
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
押し続けるのか連打かは伝えないとイラつかせちゃうよね
Interaction Type: インタラクションのタイプをタップ、ホールド、リピートから選択します。
Network Handle Method: インタラクション中に他のプレイヤーがインタラクションするのをブロックするか、有効にしておきます。
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
マルチプレイ対応だけど、イマイチちゃんと動かない?いろいろエラーでる
Hold Seconds: 長押し秒数。
Repeat Count: リピート回数
Repeat Cooldown: リピート時の各タップ間の秒数。
Cooldown Enabled: クールダウン有効: 無効にするとキャンセルされるまで待ちます。
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
キャンセルされるまで待ちます
の意味わからず。。。
Display Interaction Key: 相互作用キーを表示する: 画面上のプログレスバーにキーを表示します。
Use Custom Keys: カスタムキーを使用する: すべての入力を無効にし、配列からカスタムキーをチェックする。
Custom Keys: カスタムキー チェックするキーの配列。基本はプレイヤー側で設定したIAに紐づくけど、別なキーで操作させたい場合に指定できるもの。(デモでは最初のブースで右のやつがFキーになっている)
表示サイズ関連
マーカーの種類・色や文字は指定できるけど、ウィジェットのサイズは個別に設定する機能はないので、直接ウィジェットのサイズを変更する必要があります。
data:image/s3,"s3://crabby-images/4ad63/4ad63c379f4ffbbf38e31d1f69f7ab282ff51e58" alt=""
各コンテナのWidth/Height Overrideや
data:image/s3,"s3://crabby-images/86400/86400cc3bda534ae7f16b256c6901538edbf9530" alt=""
Textのフォントサイズ
Triangle ▽は円の中心からの距離を設定します。
data:image/s3,"s3://crabby-images/87548/875489d48e8ca3cd2151754c8f52d31c76e948c8" alt=""
おまけ(Simulate Physics
Simulate Physicsを使いたい場合、ルートがシーンコンポーネントだとコリジョンがついてこない
たぶんコリジョンはコンストラクト時にルートの子になっているので、メッシュが動いてもついてこない(メッシュの名前を指定しても、メッシュの子関係にしたものを指定してもNG)
ルートをSimulate Physics対象メッシュにするとよさげ
ルートがシーンコンポーネントの場合
data:image/s3,"s3://crabby-images/5f2f5/5f2f56f8aca600c117217b7a8c5af12eddc752e5" alt=""
ルートがメッシュの場合
data:image/s3,"s3://crabby-images/b97ef/b97ef83fe5166edbb5054407b60197358a03daf6" alt=""
設定方法
data:image/s3,"s3://crabby-images/2f59f/2f59ff18150bf7dc800eee852e02d09ce5064a9b" alt=""
シーンコンポーネントをムーバブルにする
data:image/s3,"s3://crabby-images/51fd4/51fd41b6189fafe4a9ff1a1ce6fd82860aca77d5" alt=""
と、置き換えできるので、Simulate Physics有効なCubeをアクタのルートにする
data:image/s3,"s3://crabby-images/7e2fa/7e2fae4688e24d0187b0455ca183dd571936180a" alt=""
おわりに
私は多分今後使いません。。が、いろいろ勉強になりました。
data:image/s3,"s3://crabby-images/e474b/e474b5da3f576450eabddaee75e20e6b68589868" alt="よっしー"
実行ピンがひとつもつながらなくてもタイムライン定義できるんだな など
コメント