UnityのLineRendererを利用して、点線を描いてみます。点線だけでなく好きな画像の線を引くこともできます。
はじめに
Unityのバージョンは2021.3.14f1です。
マウスで線を描くのを下記で紹介しています。今回はマウスでクリックした位置への線を点線で書いてみます。
周りに余白のある、下記画像を利用しています(実際に利用しているのは白色です)。
data:image/s3,"s3://crabby-images/a8b1e/a8b1e585595e128d3ac677f95eb23ca85bf4a07c" alt=""
実装開始
まずは動作を確認してからスクリプトで実装していきます。
オブジェクトの作成
Hierarchyで「2DObject」→「Sprites」→「Square」を追加して、名前をPlayerに変更します。
data:image/s3,"s3://crabby-images/d2f73/d2f73b9c1f37fb84c218ddcc2c641f2a4d991d33" alt=""
配下に「CreateEmpty」で空オブジェクトを追加。名前を「Line」に変更して、AddComponentから「LineRenderer」を追加します。
data:image/s3,"s3://crabby-images/f6324/f632497ff01135b845407b0cbffb39d2f67bb01d" alt=""
LinerendererのPositions、Widthを下記のように変更します。
data:image/s3,"s3://crabby-images/bfebf/bfebf4b488ec406e399403baa638348ab88c1994" alt=""
まずは、この線を点線に変更していきます。
点線マテリアルの設定
用意した点画像をUnityに取り込みます。Inspector画面でWrapModeで「Repeat」を選択します。
data:image/s3,"s3://crabby-images/3fd6b/3fd6ba320e9cbac6f243acf2a404686f33e56969" alt=""
Projectフォルダ内で「Create」→「Material」を追加します。名前はPointLineにしておきます。
data:image/s3,"s3://crabby-images/a3b20/a3b20f7d9a7afbfe725667ad169c9c7d04674fbd" alt=""
MaterialのInspectorにあるAlbedoに点の画像をセットします。
data:image/s3,"s3://crabby-images/4c0e9/4c0e954dac3c7f8735777bb7f7d91445af70a681" alt=""
Shaderを「Sprites/Default」に変更します。
data:image/s3,"s3://crabby-images/906b2/906b24b263e1056a48239631d8d524f83e1ca03d" alt=""
LinerendererのTextureModeを「Tile」に変更して、マテリアルを作成したPointLineに変更します。
data:image/s3,"s3://crabby-images/87e48/87e48d67b58c792f8351f58f195b33ccd11b8f0f" alt=""
画像が伸びたようになっているのはWidthを0.5にしたためです。TextureScaleのXを2にすると元画像の比率になります(「Width」×「TextureScaleX」=1にします)。色も分かりやすく変更しておきます。
data:image/s3,"s3://crabby-images/5b1d0/5b1d0ce47ad654b670ade89ea07068816ba01feb" alt=""
これで点線が作成できました。画像を変更することで、好きな線を描くことが出来ます。
スクリプトの作成
マウスでクリックした位置まで線を引いてみます。下記のスクリプトを作成します。
using UnityEngine; public class LineManager : MonoBehaviour { [SerializeField] private LineRenderer rend; private void Start() { rend.enabled = false; rend.positionCount = 1; rend.SetPosition(0, transform.position); } void Update() { if (Input.GetMouseButton(0)) { Vector2 mousePos = Camera.main.ScreenToWorldPoint(Input.mousePosition); rend.enabled = true; rend.positionCount = 2; rend.SetPosition(1, mousePos); } } }
マウスクリックした位置をLinerendererの2番目にセットしています。
Playerにスクリプトを追加して、パラメータのLinerendererをセットします。
data:image/s3,"s3://crabby-images/e5914/e59149d599fb956a1a888fc41b3a68f38930c012" alt=""
実行すると下記のような感じになります。
data:image/s3,"s3://crabby-images/90cf5/90cf590dfae651940b5c8fd5f706253d73808c49" alt=""
点線や破線の場合、画像を用意するのではなくShaderを使う方法もありますね。