目次
はじめに
uGUIで iOS / Androidのセーフエリアに対応するコードの紹介です。セーフエリアに合わせる箇所を上下左右で選択できるようになっています。開発済みのタイトルにも導入しやすいと思います。
コードサンプル
UnityのScreen
クラスを使って、Screen.safeArea
で簡単にセーフエリアを取得できます。
using UnityEngine;
public class SafeAreaAdjuster : MonoBehaviour
{
//セーフエリアに合わせたい箇所をtrueにする。
[SerializeField] bool left;
[SerializeField] bool right;
[SerializeField] bool top;
[SerializeField] bool bottom;
private void Start() {
var panel = GetComponent<RectTransform>();
var area = Screen.safeArea;
var anchorMin = area.position;
var anchorMax = area.position + area.size;
if(left) anchorMin.x /= Screen.width;
else anchorMin.x = 0;
if(right) anchorMax.x /= Screen.width;
else anchorMax.x = 1;
if(bottom) anchorMin.y /= Screen.height;
else anchorMin.y = 0;
if(top) anchorMax.y /= Screen.height;
else anchorMax.y = 1;
panel.anchorMin = anchorMin;
panel.anchorMax = anchorMax;
}
}
使い方
Canvas
内にRootとなるオブジェクトを作り、Rect Transform
のstretchや値を下記の様にして、「SafeAreaAdjuster」を貼り付けてください。
data:image/s3,"s3://crabby-images/d0ed1/d0ed193d6ef08cdfdccdfe0d0958686c68a58cf8" alt=""
セーフエリア合わせにしたいUI素材をRootオブジェクトの子供にしてください。
data:image/s3,"s3://crabby-images/5e05b/5e05b57111fab32c7f940a8a071657e9236112d4" alt=""
data:image/s3,"s3://crabby-images/3732f/3732ff61eceea5e75c71b8e4cbac01fa05a6dec0" alt=""
あとは、Inspector
でセーフエリア合わせにしたい箇所にチェックを入れるだけです。
- Left
- Right
- Top
- Bottom
data:image/s3,"s3://crabby-images/4cbff/4cbfff589c94542d3e358ebfe5eda42cefa26395" alt=""
Device Simulatorでいろいろ試す
Simulator
モードや端末で実行して、いろいろ試してみてください。
data:image/s3,"s3://crabby-images/ff090/ff090696b573002d168de9633611f955005d1a60" alt=""
縦画面 サンプル1(ノッチ上)
data:image/s3,"s3://crabby-images/a66ed/a66ed541e0fc0336e0b3e63e37b3d14b430fdda2" alt=""
data:image/s3,"s3://crabby-images/dc724/dc724c0599ea86650f55023c1cf1d9b41896c6a2" alt=""
縦画面 サンプル2(ノッチ上)
data:image/s3,"s3://crabby-images/987f9/987f9774975e57fb0c857ffc8b8d9e074ce51b14" alt=""
data:image/s3,"s3://crabby-images/2dc15/2dc1530cea55fafb94a5794274f964aa61ca5cca" alt=""
横画面 サンプル1(ノッチ左)
data:image/s3,"s3://crabby-images/a66ed/a66ed541e0fc0336e0b3e63e37b3d14b430fdda2" alt=""
data:image/s3,"s3://crabby-images/90aec/90aeccca5fc9ab43d9c75d65e61261b52790f3ad" alt=""
横画面 サンプル2(ノッチ左)
data:image/s3,"s3://crabby-images/88b91/88b91bd5e0887182a989418139698b053ffbfada" alt=""
data:image/s3,"s3://crabby-images/eac80/eac8081ea4610da2e840687cf1e41d56a5bed1e5" alt=""
横画面 サンプル3(ノッチ右)
data:image/s3,"s3://crabby-images/fb570/fb5701daf7913d0253d99afca1bc7e30ba40b22a" alt=""
data:image/s3,"s3://crabby-images/61a2b/61a2bb3178220be60ea781a22c32252cd1ae29da" alt=""
横画面 サンプル4(ノッチ右)
data:image/s3,"s3://crabby-images/2cc20/2cc20126d3b84c65e97ff81e0cfce642c3e7e37d" alt=""
data:image/s3,"s3://crabby-images/bb371/bb371eaa36862b8d0c50cc00d83cc4dace4061ff" alt=""
参考
実践ゲーム製作メモ帳2
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/0ddce/0ddce7a0b1ffb5c8f92317a10305748a8c89b4b9" alt=""
秒でセーフエリア対応する - 実践ゲーム製作メモ帳2
要は Screen.safeArea に親 RectTransform を合わせればいいんだけど、ググると回りくどい方法しか出てこないので。 対応 1. Canvas と UI の間に Container 的なオブジェ...