Unityには強力な地形生成機能が備わっている今回はそれの使い方を学ぼう
プロジェクトの作成
terrainappという名前で3Dプロジェクトを新規に作成する。
Standard Assetsのインポート
TerrainはStandard Assetsをインポートすると使えるようになる。まずはアセットストアを開いてStandard Assetsをすべてインポートしよう。
現在(2023)アセットストアからダウンロードできないようです。
以下からダウンロードしてください。
joytas.net/downloads/standard.unitypackage
data:image/s3,"s3://crabby-images/e2acb/e2acb4bd576464894e92544f1024fbcecd5e1a80" alt=""
data:image/s3,"s3://crabby-images/57b53/57b535991f474cddae3eb89c539b5e5d99bbeb96" alt=""
バージョンによるエラーの修正
実行するUnityのバージョンによってはスクリプトエラーがでることがある。
もし、SimpleActivatorMenu.csにエラーが発生した場合には以下のように修正する。
using System;
using UnityEngine;
using UnityEngine.UI;
#pragma warning disable 618
namespace UnityStandardAssets.Utility
{
public class SimpleActivatorMenu : MonoBehaviour
{
// An incredibly simple menu which, when given references
// to gameobjects in the scene
public Text camSwitchButton;
public GameObject[] objects;
private int m_CurrentActiveObject;
//略
}
Terrainの作成
新規から3DオブジェクトからTerrainを作成する
data:image/s3,"s3://crabby-images/89f28/89f28a14cf2b2a897ac8715c5c3d9aaf9aa1f5ad" alt=""
Terrainの初期設定
data:image/s3,"s3://crabby-images/aa034/aa03456163d6d16fe8719ca17983fed99d05bca5" alt=""
Terrainは処理が重いので以下のように設定する。(ハイスペックパソコンの場合不要)
Pixel Error -> 50
マッピング精度の設定。この値が大きいほど精度が低くなる。
Detai Density->0.1
Terrainに配置される草などの密度に影響する。低いと草木がまばらに表示される。
地面の設定
Terrainの地面の初期状態の高さは0である。これだと掘り下げることができないのでまずは全体の高さを100に設定しFlatten Allを押す
data:image/s3,"s3://crabby-images/bde01/bde014f05ceebe1d3390e93399b813340b22ef98" alt=""
これでTerrainの標高が100mになった。Trerrainがグローバル空間の原点に配置されるようにtransformを調整する。(terrainの大きさは初期値1000*1000)
data:image/s3,"s3://crabby-images/02625/02625bd90afe6f8d07c54c66c668c35c716862ee" alt=""
地形の作成
data:image/s3,"s3://crabby-images/c8257/c8257e9e9c7f06503736a221df3af0b1e8248097" alt=""
それでは実際に地面を作成していこう。
Raise or Lower Terrain
一番基本となる作業がRaise or Lower ツールだ。
これはペン先形状を選び、ブラシサイズと変化度を調整しながらお絵かきをするようにTerrainの形状を変更していく。クリックすることで地形が盛り上がり、shiftを押しながらクリックすることで下げることができる。
このあと、川や池なども配置するのでそれを考慮しながら作成するとよい。
data:image/s3,"s3://crabby-images/b559a/b559a9b8e6c26d41c588edf247563d1f94f877ae" alt=""
Set Height
ある程度共通の高さの部分を作りたい場合はSet Heighツールが便利だ。
基準となる高さを選択し、その高さにしたい部分をドラッグして塗っていく。
data:image/s3,"s3://crabby-images/a612b/a612b3786d89f30ec5d83ff2b7cf7966d7eeec73" alt=""
Smooth Height
凸凹になりすぎた部分があった場合はSmooth Heightを選択し、なぞっていくことで平均化することができる。
data:image/s3,"s3://crabby-images/0d631/0d631fc7aa0aa36a7543d7ae88a582f5748976a7" alt=""
地面の着色
地面に着色をしていく、まずはPaintTextureからEditTerrainLayersをクリック
data:image/s3,"s3://crabby-images/d72ed/d72edef04e05136fc6b92db20e6fd428fc354640" alt=""
プルダウンが開くのでCreate Layerをクリック。
検索窓にgraと入力して、GrassHillAlbedoを選択する
data:image/s3,"s3://crabby-images/cd478/cd478b3534fe4c187171663332e580e248957f7b" alt=""
grassで全体がペイントされた!
data:image/s3,"s3://crabby-images/6cc69/6cc69dbba80c2dbab6f4b2a37b0b737b22340e4b" alt=""
同じ手順で以下のテクスチャをCreateLayerから追加しよう。
○CliffAlbedoSpecular
○GrassRockyAlbedo
○MudRockyAlbedoSpecular
○SandAlbedo
data:image/s3,"s3://crabby-images/c1bd1/c1bd1170f9862398b7226738f3278c27e296936f" alt=""
あとは先程と同じようにLayerを選択して、ペン先や太さなどを調整しながらペイントしていく。
data:image/s3,"s3://crabby-images/e854b/e854b335aafed06e0e2a06df309eebfd8d6360c3" alt=""
木を植える
木のアイコンを選びEditTreesを押す
data:image/s3,"s3://crabby-images/b6cdc/b6cdc4beddb3cb94b1646fa8a8dc7d07fed75903" alt=""
プルダウンからAdd Treeを選ぶとWindowが開くので以下のようにBroadleaf_Desktopを選択
data:image/s3,"s3://crabby-images/9a5e2/9a5e297af3c468739ade075a849125a755f53f4c" alt=""
選択ができたらAddを押す
data:image/s3,"s3://crabby-images/024ad/024ad1d09212a3ba2ade03c2144055864494e1f5" alt=""
ペイント
ブラシのサイズ、木を生やす密度、木の高さなどを設定しながらペイントしていく。shiftを押すことによって生やしすぎた場所などから消去することができる
data:image/s3,"s3://crabby-images/75a4a/75a4ac5e0c73a24776690e8da2966496999c1772" alt=""
data:image/s3,"s3://crabby-images/dc9e9/dc9e9f9e072cc65dea2bd488b843e84c10afa470" alt=""
木の種類を増やす
先程と同じ手順を踏んで、以下の木も登録しよう。
○Conifer_Desktop
○Palm_Desktop
data:image/s3,"s3://crabby-images/12de4/12de47a8f85b80d3e1b323573dd485552a7b9bff" alt=""
木の種類を選択しながらTerrainをペイントしていく
data:image/s3,"s3://crabby-images/b414a/b414ab36ed2e0845a80d8455344d6ac7225a0ccf" alt=""
草を生やす
草のアイコンを選択し、EditDetailsを押してまずは素材を作成する
data:image/s3,"s3://crabby-images/ec6fe/ec6fec21659a7b6a00fb9dae2ef7bd50298aa6d2" alt=""
プルダウンからAdd Grass Textureを選択すると画面が開くので
GrassFrond01AlbedoAlphaを選択し、Addする
data:image/s3,"s3://crabby-images/1a69a/1a69a72650200bacccda2fefae5e237668ff095d" alt=""
あとは木と同様にペイントしていこう。ただし、草は非常に負荷が高いのでかなり近づかなければ見ることができない。この距離はセッティングのDetailDistanceから調整できる。長く設定すると遠くから見えるようになるが、ここらへんはマシンスペックと相談しながら行なうとよいだろう。
data:image/s3,"s3://crabby-images/969a5/969a5c2a3c6df85d1921d000d6d87b9e92e89e6f" alt=""
根気がいる作業だが、じっくりと行おう。
data:image/s3,"s3://crabby-images/b1e84/b1e84821942a54231098b0919371b5fcc49aa059" alt=""
水の配置
水を配置していこう。Projectビューの検索まどに
WaterPro
と入力して
WaterProDaytime
プレファブをヒエラルキーにドラッグする
data:image/s3,"s3://crabby-images/c9236/c923686c8c1ca7b1114ca7814548012ee7feb7c6" alt=""
Scaleを1000*1000にして海面の高さ(PositionのY)を地形に合わせて調整する。
data:image/s3,"s3://crabby-images/9c2e1/9c2e1cc56c80346ee9ba347b8b088474b45ef5dd" alt=""
必要であれば、複数プレファブを配置する。(このMapでは川と池の2つを配置した)
data:image/s3,"s3://crabby-images/29695/2969591a813179d790dd062166284cfae63de125" alt=""
風を吹かせる
ヒエラルキーから3DObject->Wind Zoneを作成する
data:image/s3,"s3://crabby-images/77172/7717262149f3ce8ef83ff6783d1489aeda433ba1" alt=""
風の強さであるMainを0.2,ランダム性を与えるTurbulenceを0.3に設定しよう。
ゲームを再生していみると風で木や草が揺れることがわかる。
data:image/s3,"s3://crabby-images/e39a1/e39a1c31d44208c50d40ad5faabe7628be7d4000" alt=""
空を追加
Asset Storeにアクセスし
Wispy Skybox
をダウンロード&インポートする(すべて)
Window->Rendering->Lighting Settingsを選ぶ
data:image/s3,"s3://crabby-images/62a60/62a6073a0b22425d112e499c95621bef911db1b8" alt=""
Skybox Materialに
WispySkyboxMat
を設定する
data:image/s3,"s3://crabby-images/4d270/4d27029fe86052d5ae8c558b8f755ad62c471112" alt=""
空がリアルになった!
data:image/s3,"s3://crabby-images/38b33/38b33f08983ef63db01e4f4560dac24b9c2b2fc1" alt=""
skyboxで昼夜を表現する
Projectビューから新規materialを選択し、名前をMySkyboxとして、シェーダーを
Skybox->procedural
にする
再び
Window->Rendering->Lighting Settings
を開いてSkybox MaterialをMySkyboxにする
data:image/s3,"s3://crabby-images/29305/29305139542935efab3fedf78a52df972004b50b" alt=""
おお、空が変わった!
data:image/s3,"s3://crabby-images/96560/96560d799fdff5c22edd3c161ff3ba9eb2cba36b" alt=""
SkyboxProceduralシェーダーはdirectionalLight(太陽)の角度によって描画が変わる
Directional Lightを選択してRotationのxを動かしてみよう。
data:image/s3,"s3://crabby-images/8951f/8951f4e12ba02bafba31999b038c01104fee4c9e" alt=""
太陽の向きによって昼夜が再現される
data:image/s3,"s3://crabby-images/497ad/497ad3d3bb0d632e6a1bb59b6d66a60006036708" alt=""
スクリプトサンプル
以下のようなSkyControllerスクリプトを作成し、DirectionalLightに付与すると自動的に昼夜が入れ替わる。(この作例ではわかりやすいように30秒で1日間を表している)
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class SkyController : MonoBehaviour
{
// Update is called once per frame
void Update()
{
transform.Rotate(new Vector3(-12f * Time.deltaTime,0f,0));
}
}
コメント