facebook twitter hatena line email

Unity/端末サイズ

提供: 初心者エンジニアの簡易メモ
移動: 案内検索

サンプル

  1. CameraオブジェクトのProjectionをorthographicへ変更しておく。
  2. CanvasのRenderModeをWorldSpaceに変更
void Awake()
{
       TermSize.OrthographicSizeAuto();
}

TermSize.cs

public class TermSize {
   public static void OrthographicSizeAuto () {
       // 縦画面 iPhone6
       float developAspect = 750.0f / 1334.0f;
       // 横画面 iPhone6
       // float developAspect = 1334.0f / 750.0f;
       float deviceAspect = (float)Screen.width / (float)Screen.height;
       float scale = deviceAspect / developAspect;
       Camera mainCamera = Camera.main;
       float deviceSize = mainCamera.orthographicSize;
       float deviceScale = 1.0f / scale;
       if (scale > 1) {
           Debug.Log("scale変更不要");
           return;
       }
       mainCamera.orthographicSize = deviceSize * deviceScale;
    }
}

参考:http://www.project-unknown.jp/entry/2017/01/05/212837

ipad判定

public static bool IsIPad {
    get {
        return SystemInfo.deviceModel.Contains ("iPad");
    }
}

参考:http://westhillapps.blog.jp/archives/35736621.html

縦ipad判定

public static bool IsIPadDeviceAspect() {
    float deviceAspect = (float)Screen.width / (float)Screen.height; // 2048 / 2732 = 0.74963397
    if (deviceAspect > 0.749f && deviceAspect <= 0.751f) {
        return true;
    }
    return false;
}

CanvasScalerを使った自動フィット

  1. CanvasのRenderModeをScreenSpace-Cameraに変更
  2. CanvasのInspectorのCanvasScalerを"Constant Pixel Size "から"Scale With Screen Size"に変更して
  3. CanvasScalerのReferenceResolutionを1080x1920(CanvasのRectTransformの値と同じ)へ

padのときは、調整が必要なので、以下CanvasScalerを使ったautofitを使うとうまくはまる

TermSize.OrthographicSizeAutoCanvasScaler(GameObject.Find("/Canvas").GetComponent<CanvasScaler>());
public static void OrthographicSizeAutoCanvasScaler(CanvasScaler canvasScaler)
{
    Vector2 developValue = new Vector2(1080f, 1920f);
    float developAspect = developValue.x / developValue.y;
    float deviceAspect = (float)Screen.width / (float)Screen.height;
    float scale = deviceAspect / developAspect;
    if (scale < 1)
    {
        canvasScaler.uiScaleMode = CanvasScaler.ScaleMode.ScaleWithScreenSize;
        canvasScaler.referenceResolution = developValue;
        return;
    }
    float width = developValue.y * (float)Screen.width / (float)Screen.height;
    canvasScaler.uiScaleMode = CanvasScaler.ScaleMode.ScaleWithScreenSize;
    canvasScaler.referenceResolution = new Vector2(width, developValue.y);
}

Screen.SafeAreaの使い方

Screen.SafeAreaとは

上部カメラの切り欠きなどを除外した、適切に表示できる四角エリアの範囲

GameObject image = GameObject.Find("Canvas/Image");
ApplySafeArea(image.GetComponent<RectTransform>());
void ApplySafeArea(RectTransform rectTransform)
{
    var safeArea = Screen.safeArea;
    var resolition = Screen.currentResolution;
    rectTransform.sizeDelta = Vector2.zero;
    rectTransform.anchorMax = new Vector2(safeArea.xMax / resolition.width, safeArea.yMax / resolition.height);
    rectTransform.anchorMin = new Vector2(safeArea.xMin / resolition.width, safeArea.yMin / resolition.height);
}

縦型で、実行すると、RectTransformのAnchorsのminとmaxのy値が変更される。

参考:https://tsubakit1.hateblo.jp/entry/2019/10/30/235150

AutoScreenライブラリ

端末画面サイズ判定として、AutoScreenがある。

https://github.com/su10/AutoScreen-for-Unity2021

内部で、Screen.safeArea;を使ってる。

SafeAreaHelperライブラリ

端末画面サイズ判定として、SafeAreaHelperがある。

Unity/おすすめアセット/SafeAreaHelper [ショートカット]

内部で、Screen.safeArea;を使ってる。