プレイヤーと重なった建物を透かせる
今回は、プレイヤーと重なった建物を透かせる方法を備忘録にします。
※作業環境:UEバージョン5.3.2
備忘録
カメラ固定型のゲーム制作するときに、プレイヤーが建物の陰に隠れて見えなくなることがあります。
今回は、プレイヤーと重なった建物を透過させて、プレイヤーが見えるようにしていきます。
透過させたい建物のマテリアル設定を確認する
プレイヤーと重なったときに、透過させたい建物をレベルから選択します。
data:image/s3,"s3://crabby-images/5a17b/5a17bba5a2818f9a10ce3287491b13e5cf78bbab" alt=""
上の写真のように建物を選択して、そのブループリントを開きます。
data:image/s3,"s3://crabby-images/57a9b/57a9b033067790a826a472b2c890dfb0dd0eeff0" alt=""
任意のスタティックメッシュを選択して、「Materials」項目を確認します。
data:image/s3,"s3://crabby-images/ed55a/ed55a4f3cfb0376f558a5828e7bf9c7d97fb2075" alt=""
透過させたいマテリアルの保管先に移動します。
「📁🔎」マークをクリックすれば、マテリアル保管場所を表示してくれます。
data:image/s3,"s3://crabby-images/25062/25062ddfdb54f92fe9718a8166d9cbfaa36897e4" alt=""
マテリアルを開きます。
data:image/s3,"s3://crabby-images/1bea9/1bea9d4266acfbb4fa58ff93ecc2ca5cc5ac06d7" alt=""
「Details」の「General」の「Parent」に親となるマテリアルが設定されています。
data:image/s3,"s3://crabby-images/42153/42153bf445e168a35b6c52dba2d77aa05b29a1b8" alt=""
「📁🔎」で保管先を開いて、このマテリアルを開きます。
data:image/s3,"s3://crabby-images/1bd04/1bd042feef49c7fad1e043fd188af9160514c499" alt=""
このマテリアルは親なので、子のマテリアルにも設定変更に影響を与えます。
なので親に透過設定すれば、子にも影響を与えます。
試しにマテリアルを透過してみます。
data:image/s3,"s3://crabby-images/4c8c2/4c8c27d8a81a3abf8e0e81ac75904742d25a9b5b" alt=""
透過するのに「Opacity Mask」項目の設定が必要になりますが、上の写真のように使えない状態の場合があります。
「Opacity Mask」を使えるようにします。
「Material」の「Blend Mode」を「Masked」に変更します。
data:image/s3,"s3://crabby-images/e9949/e99491f85183645b92f691daa5893033f3e9105c" alt=""
「Opacity Mask」が使えるようになりました。
data:image/s3,"s3://crabby-images/ceb34/ceb34ffe7c0312305daad7da6096dda39ba3297f" alt=""
「1」キーを押した状態でクリックすると、下の写真の「0」ノードは配置できます。(Constantノード)
data:image/s3,"s3://crabby-images/77312/773125c4ce4b84e296bcf6e5a932c890764b8734" alt=""
「Value」を「0.0」にして、「Opacity Mask」に繋げます。
保存して、マテリアルビュー画面を見てみると、マテリアルは透明になっています。
data:image/s3,"s3://crabby-images/e4420/e442087f3c86daf2db531e5bb2b4321cc0bf292f" alt=""
「0.0」が透明で「1.0」が不透明といった感じです。
レベル画面に戻り、ビューポート画面を確認すると該当するマテリアルが透明になっています。
data:image/s3,"s3://crabby-images/7153e/7153e14ba6c022ac1ad98456e5c30865b72b6639" alt=""
この機能を活用して作業を進めていきます。
「Material Parameter Collection」を作成する
コンテンツで右クリックして、「Material」の「Material Parameter Collection」を選択します。
data:image/s3,"s3://crabby-images/ef5a2/ef5a27d6fa856941611775b425b430678fa2360d" alt=""
ファイル名は「MPC_Masking」にします。
data:image/s3,"s3://crabby-images/5e604/5e604b9332710bc2a435324efe43afbbc71fe2a1" alt=""
ファイルを開いて、「Vector Parameters」の「+」ボタンをクリックして項目を追加します。
data:image/s3,"s3://crabby-images/dd09e/dd09e036b560b254eed0815d8c851cbf31313453" alt=""
上の写真のように設定します。
「Parameter Name」は「PlayerPosition」にします。
「Material Function」を作成する
コンテンツで右クリックして「Material」の「Material Function」を選択します。
data:image/s3,"s3://crabby-images/b058a/b058a9132e94e485ccef45c788dbfc45fe646025" alt=""
ファイル名は「MF_Mask」にしておきます。
data:image/s3,"s3://crabby-images/164ed/164ed5f6987d53b14b5c06875fb9471b0ae7f1a7" alt=""
ファイルを開きます。
data:image/s3,"s3://crabby-images/219d4/219d4a6a8034f6636a2362e83ca42de99906cbcd" alt=""
以下のリンク先から必要なノードをコピーします。
リンク先に、下の写真の「Copy full snippet(950 lines long)」ボタンがあるのでクリックします。
data:image/s3,"s3://crabby-images/ede3d/ede3d59862eba6f69aa550ef18691377f9755ec9" alt=""
「MF_Mask」に貼り付けます。
data:image/s3,"s3://crabby-images/d4c07/d4c07b58239a43863c81b1b47e4a3b7f1f1a29ee" alt=""
一番右側にある「Shadow Pass Switch」ノードと「Output Result」ノードを繋ぎます。
data:image/s3,"s3://crabby-images/af5a2/af5a2627ad3d4bab31f2b456bcc312dcd614c85b" alt=""
保存して「Material Function」設定完了です。
作成した「Material Parameter Collection」は、ここで使われています
data:image/s3,"s3://crabby-images/64ecd/64ecdb9574260cf5bd41a0987447d985ef47d6b5" alt=""
透過するマテリアルに繋げる
透過させたい建物の親マテリアルファイルに戻ります。
ノード検索で「Material FunctionCall」を選択します。
data:image/s3,"s3://crabby-images/7f542/7f542adf7fae769bcec01bb88d5374c93382f8ca" alt=""
ノードを選択した状態で「Material Function」を「MF_Mask」に変更します。
すでに「MF_Mask」になっている場合はそのままでOKです。
data:image/s3,"s3://crabby-images/0d314/0d31427aa1be0108175d70b4b6c5cf6e2f0d9ead" alt=""
試しで配置した「Constant」ノードを削除して、「MF_Mask」ノードを「Opacity Mask」に繋げます。
data:image/s3,"s3://crabby-images/cb000/cb000e08d808411bb3595591311a5f37fd9dfffa" alt=""
保存します。
プレイヤーのブループリントを設定する
プレイヤーの移動に合わせるように設定します。
プレイヤーのブループリントを開きます。
data:image/s3,"s3://crabby-images/60ec4/60ec4abd180ccb6c0d65006a0b8d5815f51fe396" alt=""
「Event Tick」に処理を繋げていきます。
data:image/s3,"s3://crabby-images/4845d/4845d3a43ae84e415bf2340e651d6a85e390b749" alt=""
今回使用したプレイヤーブループリントは、子クラスなので「Parent:Tick」ノードが繋がれています。
下の写真のようにノードを繋げます。
data:image/s3,"s3://crabby-images/c0f95/c0f95e200bbd8ef7299b5d05847fc1f28d8b7f0f" alt=""
- 「Get Actor Location」ノードで、プレイヤーの取得します。
- 「Set Vector Parameter Value」ノードの「Parameter Value」に「Get Actor Location」ノードを繋げます。
- 「Set Vector Parameter Value」ノードの他の項目を設定します。
これで完成です。
プレイして建物の裏にプレイヤーを移動させてみると、下の写真のような感じになります。
data:image/s3,"s3://crabby-images/2e445/2e44596f98fdf5481a10fbcc75cd2ab6c28cd762" alt=""
他の記事を探す
他の記事も気になる方は、以下の記事の目次を確認ください。