Unity の Post Processing の効果の 1 つにレンズの歪みを制御する「Lens Distortion」があります。
Lens Distortion を使うと、ドアスコープや魚眼レンズのように中央が拡大されて周辺部分は縮小し、丸みを帯びた見た目になります。
data:image/s3,"s3://crabby-images/9ba08/9ba08863f60aaaccb511e475e06e327dbd3148a4" alt="Unity の Lens Distortion を比較"
本記事では Lens Distortion の解説と、その効果を使って魚眼レンズ風のカメラ演出を作ってみます。
目次
バージョン情報
Unity 2019.4.20f1
Post Processing 3.0.3
Lens Distortion とは?
Lens Distortion とは Unity の Post Processing(ポストプロセス)で使える効果の 1 つで、カメラに適用することでレンズの歪みを制御できます。
data:image/s3,"s3://crabby-images/0db47/0db471f0184d8bb2539caab9074ff15bcddaef5a" alt="Post Processing の Lens Distortion"
設定できるプロパティは 6 つあります。
data:image/s3,"s3://crabby-images/570e9/570e9f8396471d3d983d290e5994a0901103372b" alt="Lens Distortion のプロパティ"
プロパティ | 説明 |
---|---|
Intensity | 歪み量の合計値を設定します。 |
X Multiplier | X 軸に強度乗数を設定します。 この軸の歪みを無効にするには 0 を設定します。 |
Y Multiplier | Y 軸に強度乗数を設定します。 この軸の歪みを無効にするには 0 を設定します。 |
Center X | X 軸の歪みの中心点を設定します。 |
Center Y | Y 軸の歪みの中心点を設定します。 |
Scale | グローバル画面のスケーリングの値を設定します。 |
Lens Distortion で魚眼レンズ風のカメラ演出を作成
実際に Lens Distortion を使って魚眼レンズ風のカメラ演出を作っていきます。
オブジェクトを配置
まずはカメラに映る対象となるオブジェクトを配置します。
オブジェクトを生成するなりアセットを使うなりで自由に配置してください。
data:image/s3,"s3://crabby-images/6ca62/6ca621ca60350641b87396e569edc403006e0ebd" alt="アセットの配置"
上記画像に登場する人型の 3D モデルには「Human Characters (FREE Sample Pack)」という無料のアセットを使用しました。
Post Processing のインストール方法
既に Post Processing をインストール済の方はスキップして下さい。
Unity の上部メニューから 「Window」->「Package Manager」を選択します。
data:image/s3,"s3://crabby-images/ac026/ac026d03daf0623e7dee969adc64fdb9ddc7b738" alt="Unity の Package Manager の場所"
「Post Processing」を検索して選択し、右下の「Install」からインストールを実行します。
data:image/s3,"s3://crabby-images/8eab1/8eab11d280e7047976d3452380c49d410bd4e24a" alt="Post Processing のインストール"
Post Processing の項目の右側にチェックマークが付けばインストール完了です。
data:image/s3,"s3://crabby-images/72760/72760f2e51f90b4986e4cf231d991226eac7e815" alt="Post Processing をインストール済"
Post Process 用の Layer を追加
ポストプロセス用のレイヤーを追加します。
Inspector ウィンドウにて Layer を選択して「Add Layer…」からレイヤーを追加します。
data:image/s3,"s3://crabby-images/d859a/d859a99b41860649ee4bd9084f22078cf3292eec" alt="Unity で Layer の追加"
レイヤー名は好きな名前で大丈夫です。ここでは「Post Processing」と名付けました。
data:image/s3,"s3://crabby-images/317ef/317ef2b6a77c092c463f521663b029cc35449797" alt="Unity で Layer 名の設定"
Post-Process Layer の設定
対象のカメラオブジェクトに「Post-Process Layer」コンポーネントを追加します。
カメラオブジェクトを選択し、 Inspector ウィンドウにて「Add Component」から「Post-process Layer」を選択します。
data:image/s3,"s3://crabby-images/12302/12302dc8027e898091aafb92779dd5fc81a42489" alt="Post-Process Layer コンポーネントの追加"
追加したコンポーネントの Layer を設定します。こちらに先程追加した「Post Processing」レイヤーを選んで設定します。
data:image/s3,"s3://crabby-images/497bb/497bb7f01fca60a691e4bc0f7bc0835eb5b2f652" alt=""
これでカメラの設定は完了です。
Post-Process Volume の設定
Hierarchy ウィンドウ上で右クリックし「3D Object」->「Post-Process Volume」 を選択し、「Post-Process Volume」オブジェクトを追加します。
data:image/s3,"s3://crabby-images/a3241/a3241afebb9a348ee8c02864d6c963e6dab8ece1" alt="Post-Process Volume の作成"
追加した「Post-Process Volume」の Inspector ウィンドウを確認して、Layer を「Post Processing」に変更します。
data:image/s3,"s3://crabby-images/7d653/7d653c16cfdd95ebbe51ce03c16250bbc53e4c38" alt="Unity で Layer の変更"
Post-Process Volume コンポーネントにて「IsGlobal」にチェックを入れます。
data:image/s3,"s3://crabby-images/d41bc/d41bc709062bb13c44a5cdaa6c6682ede4ee3cec" alt=""
「Profile」プロパティの右側にある「New」ボタンを選択すると、新たに「Post-process Volume Profile」が生成されて、自動で「Profile」にセットされます。
data:image/s3,"s3://crabby-images/0cce5/0cce57d5513a9872974cff613aabde99ab8a5da8" alt="Post-Process Volume の Profile を生成"
これで Post-Process Volume の設定は完了です。
Lens Distortion(レンズの歪み)の適用
先程追加した「Post-process Volume」を使い、レンズの歪みを制御するポストプロセスである「Lens Distortion」を適用します。
「Post-process Volume」コンポーネントの下部にある「Add effect…」ボタンを選択し「Unity」-> 「Lens Distortion」を選択します。
data:image/s3,"s3://crabby-images/6a456/6a456067c8441f2af8a84e127813f9e1d946ba2f" alt="Lens Distortion の効果を追加"
追加された「Lens Distortion」コンポーネントのプロパティはデフォルトでチェックボックスがオフになっています。使用するプロパティにチェックを入れて値を設定して下さい。
以下の画像では「Intensity」を 60 に設定しています。この値を変更することでレンズの歪み量を調整できます。
data:image/s3,"s3://crabby-images/570e9/570e9f8396471d3d983d290e5994a0901103372b" alt="Lens Distortion のプロパティ"
Lens Distortion を適用した結果が以下の画像です。
簡単な設定で魚眼レンズ風のカメラ演出が作成できました。
data:image/s3,"s3://crabby-images/0db47/0db471f0184d8bb2539caab9074ff15bcddaef5a" alt="Post Processing の Lens Distortion"
おわりに
ゲーム開発においては、今回の Lens Distortion を使うことでドアスコープを覗いた時の演出などに使えそうだなと感じました。
Post Processing でできる演出は他にも色々あるので、気になる方は他の演出も調べてみて下さい。
参考資料
- Post Processing Stack v2 overview | docs.unity3d.com
- Lens Distortion | docs.unity3d.com
関連記事