執筆バージョン: Unreal Engine 5.0
|
月がきれいな季節になりました(本記事執筆時)。
こういう季節になると逆に、月から地球を見てみたくなりますよね!
そんなときに便利なのが、Sky Atmosphereです。
実はこのSky Atmosphere、惑星の大気をそのままシミュレートしているので、このままカメラを遠くに連れて行くだけで簡単に、宇宙から見た惑星の姿も再現できちゃいます。
まず何もないレベルを用意し、Sky Atmosphere、Directional Lightをレベルに配置します。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/72050049176440cbfd979f52a6d415cc.png)
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/fc944cc852df980c59c47da2afc53f00.png)
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/b2d0016c18654d1648698d551794922a-1-1024x576.png)
いつもの空ですね!
次に惑星の大地を生成していきます。
とはいえ、今回は月から見た地球を想定しているため、それほど細かいディテールは必要ありません。
巨大な球を作り、それらしいテクスチャを貼ることにしましょう。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/modeling.png)
Modeling Modeを選択し、球を追加します。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/af28498bd35a669d8d7afe7118832dec-1-1024x833.png)
Mode ToolbarよりSphereを選択し、
Radiusを最大値の1,000,000にします(スライドで数字を変更するのではなく、直打ちします)。
なめらかな球に見せたいので、Subdivision TypeをLat Longにし、
Horizontal SlicesとVertical Slicesを100にします。
ついでにPivot LocationもCenteredにしておきます。あとで楽になります。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/fc6fa62bb7c84979113961de384de7e0.png)
レベルに配置したら、原点に移動させ、今後のためもう少し大きくしておきます。
このままの大きさでも良いですが、できるだけ大きくして地球に寄せた方が、より正しいであろう大気のシミュレーションをしてくれます。
しかし大きすぎると反対に扱いが難しくなるので、そのあたりはバランスです。
今回はScaleで30倍にしておきます。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/d1d83d4b79b266efd469d65abe9697c8-1024x574.png)
でかいですね!
次に、大気の大きさを大地に合わせていきます。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/GroundradiusPlanettop.png)
Sky Atmosphereを選択し、Ground Radiusを300にします。
ちなみにここの値の単位はkmで、さきほどModeling ModeでいじったRadiusの単位はcmです。
これでちょうど同じ大きさになっているはずです。
その後、Transform ModeをPlanet Center at Component Transformに変更します。
こうすることで、SphereとSky Atmosphereが重なっているはずです。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/0b9830adc837ad6b2bccbf5b52590e36-1024x576.png)
惑星っぽくなってきました!
次に月の設定をしていきます。
月の大地はLandscapeを使っていきます。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/1c4e6bf50277c0d1d21bc6f72045f7e5.png)
LandscapeのMaterialをStarterContentにあるM_Rock_Slateにします。
大きさ等ほかの設定はデフォルトで大丈夫です。
Landscapeを配置したら、Sphereからかなり遠くに離します。
ただし、Sphereがかなり大きい関係で、移動させるとき普通のカメラ速度だとしんどいと思います。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/f55dd630b0708a2ba4467430e6ef3c64.png)
そこでCamera SpeedとCamera Speed Scalarを最大値にします。
適度に遠いところに配置し、ほどよくLandscapeをいじった状態がこちら。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/30ec395771809b4e3cc7ca33efe2d926-1024x576.png)
これは誰がどう見ても月ですね!
最後にマテリアルの設定を行なっていきます。
今回はマーケットプレイスにある地球のテクスチャを貼ります。
配置したSphereに向かって、テクスチャをContent Browserからドラッグ&ドロップするだけで勝手にマテリアルが生成されます。
本来は質感を設定するためにマテリアルをいじる必要がありますが、Sky Atmosphereのおかげで、地球のテクスチャだけでもそれなりに見えます。
SphereとDirectional Lightの角度をいい感じにしたものがこちら。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/d17c31be79c6c75391f88ab79201c27d-1024x576.png)
ちなみにこのままプレイしても、おそらく地球のど真ん中にスポーンしてしまうと思います。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/disablebounds.png)
World SettingsのEnable World Bounds Checksのチェックを外します。
すると月の上からスタートできるようになります。
ここまでくるとせっかくなので重力も軽くしたいと思います。
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/53839919091f3bc210910612e7967252.png)
![](https://historia.co.jp/wp/wp-content/uploads/2022/10/gravityscale.png)
サードパーソンテンプレートを使っている方は、
BP_ThirdPersonCharacterのCharacter Movement Componentを選択し、Gravity Scaleを0.8ぐらいにします。
これで月から地球を見たくなったときも安心ですね!