はじめに
作成したアプリのボタンなどが、画面の端にある場合、一部の端末のノッチと被ってしまうケースがあります
data:image/s3,"s3://crabby-images/93b37/93b3732ea8943bf68d6dc6304c4baca27a58d846" alt=""
実機を持っていなくても、Unity上で様々な端末の実際の見え方を確認できます
※Unity 2019.3 以降が必要です
Device Simulatorの使い方
Gameウィンドウ左上の Game をクリックして Simulator に切り替えるだけです
data:image/s3,"s3://crabby-images/bd450/bd450f1448f7af080f8da99c882ffb67aeb4488a" alt=""
※もし Simulator がなければ、Package Manager からインストールしましょう
Simulatorでは、選択した端末での見た目を確認することができます
上部の Safe Area をクリックすると、黄色い枠でセーフエリアが表示されます
data:image/s3,"s3://crabby-images/a68e8/a68e8f77068448feb45d3be18ff13d2a80dc1079" alt=""
セーフティーエリア内に配置するには
これで見え方を確認できるようになりましたが、全ての端末を一つ一つ確認するのは非常に手間がかかります
そこで、どんな端末でもセーフエリア内に収まるようにしましょう
こちらの記事が参考になりました
まず、Canvas内に空のオブジェクトを作成します
名前はなんでも良いですが、 —SafeArea— と名付けました
data:image/s3,"s3://crabby-images/7db09/7db09bd219e4c8e5156bd15408f59b2349b2048f" alt=""
こちらに以下のスクリプトを追加します
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;
}
}
—SafeArea— に Rect Transform コンポーネントを追加し、下の画像と同じ値に設定します
data:image/s3,"s3://crabby-images/c0980/c0980131a48a3a6b11d9759c80b076d52fc25758" alt=""
先ほどノッチと被っていたボタンを子オブジェクトにします
data:image/s3,"s3://crabby-images/45daf/45daf2120fd6e69b56754352a992b297d63b0992" alt=""
ゲームを開始すると、スクリプトが動き、セーフエリア内にボタンが移動します
data:image/s3,"s3://crabby-images/cda90/cda90fa9fe0f313cfabe1d85d7feca7492f5208b" alt=""
まとめ
iPadや折りたたみスマホなど、最近は端末によってアスペクト比やノッチサイズも様々なので、見栄えの確認が大変ですが、今回の方法を使えば安心してUIの配置ができそうです