Unity UGUI的CanvasScaler(畫布縮放器)組件的介紹及使用

来源:https://www.cnblogs.com/alianblank/archive/2023/07/20/17567945.html
-Advertisement-
Play Games

# Unity UGUI的CanvasScaler(畫布縮放器)組件的介紹及使用 ## 1. 什麼是CanvasScaler組件? CanvasScaler是Unity中UGUI系統中的一個組件,用於控制畫布的縮放和適配。通過CanvasScaler組件,可以實現UI界面在不同解析度下的自適應顯示。 ...


Unity UGUI的CanvasScaler(畫布縮放器)組件的介紹及使用

1. 什麼是CanvasScaler組件?

CanvasScaler是Unity中UGUI系統中的一個組件,用於控制畫布的縮放和適配。通過CanvasScaler組件,可以實現UI界面在不同解析度下的自適應顯示。

2. CanvasScaler的工作原理是什麼?

CanvasScaler組件通過調整畫布的縮放比例,使UI元素在不同解析度下保持一致的顯示效果。它根據設定的參考解析度和屏幕解析度的比例,計算出縮放比例,並將其應用到畫布上。

3. CanvasScaler的常用屬性有哪些?

  • UI Scale Mode:設置畫布的縮放模式,有Constant Pixel Size(像素大小不變)、Scale With Screen Size(根據屏幕大小縮放)和Constant Physical Size(物理大小不變)三種模式可選。
  • Reference Resolution:設置參考解析度,用於計算縮放比例。
  • Screen Match Mode:設置屏幕匹配模式,有Match Width Or Height(寬度或高度匹配)和Expand(擴展)兩種模式可選。
  • Match:設置屏幕匹配模式為Match Width Or Height時,指定寬度或高度的匹配比例。
  • Physical Unit:設置物理單位,用於計算Constant Physical Size模式下的縮放比例。

4. CanvasScaler的常用函數有哪些?

  • SetScaleFactor(float scaleFactor):設置畫布的縮放比例。
  • SetReferencePixelsPerUnit(float referencePixelsPerUnit):設置參考像素單位。
  • SetReferenceResolution(Vector2 referenceResolution):設置參考解析度。
  • SetScreenMatchMode(ScreenMatchMode screenMatchMode, float matchWidthOrHeight):設置屏幕匹配模式和匹配比例。

5. CanvasScaler的使用示例代碼:

示例1:設置畫布的縮放模式為Scale With Screen Size

CanvasScaler canvasScaler = GetComponent<CanvasScaler>();
canvasScaler.uiScaleMode = CanvasScaler.ScaleMode.ScaleWithScreenSize;
canvasScaler.referenceResolution = new Vector2(1920, 1080);
canvasScaler.screenMatchMode = CanvasScaler.ScreenMatchMode.MatchWidthOrHeight;
canvasScaler.matchWidthOrHeight = 0.5f;

操作步驟:

  1. 獲取CanvasScaler組件。
  2. 將uiScaleMode屬性設置為Scale With Screen Size。
  3. 設置referenceResolution屬性為參考解析度,例如1920x1080。
  4. 將screenMatchMode屬性設置為Match Width Or Height。
  5. 設置matchWidthOrHeight屬性為匹配比例,例如0.5表示寬度和高度的匹配比例為1:2。

示例2:設置畫布的縮放模式為Constant Pixel Size

CanvasScaler canvasScaler = GetComponent<CanvasScaler>();
canvasScaler.uiScaleMode = CanvasScaler.ScaleMode.ConstantPixelSize;
canvasScaler.scaleFactor = 2f;

操作步驟:

  1. 獲取CanvasScaler組件。
  2. 將uiScaleMode屬性設置為Constant Pixel Size。
  3. 設置scaleFactor屬性為縮放比例,例如2表示畫布放大兩倍。

示例3:設置畫布的縮放模式為Constant Physical Size

CanvasScaler canvasScaler = GetComponent<CanvasScaler>();
canvasScaler.uiScaleMode = CanvasScaler.ScaleMode.ConstantPhysicalSize;
canvasScaler.referencePixelsPerUnit = 100;

操作步驟:

  1. 獲取CanvasScaler組件。
  2. 將uiScaleMode屬性設置為Constant Physical Size。
  3. 設置referencePixelsPerUnit屬性為參考像素單位,例如100表示每個單位對應100個像素。

示例4:動態設置畫布的縮放比例

CanvasScaler canvasScaler = GetComponent<CanvasScaler>();
canvasScaler.SetScaleFactor(1.5f);

操作步驟:

  1. 獲取CanvasScaler組件。
  2. 調用SetScaleFactor函數,設置畫布的縮放比例為1.5。

示例5:動態設置畫布的參考解析度

CanvasScaler canvasScaler = GetComponent<CanvasScaler>();
canvasScaler.SetReferenceResolution(new Vector2(1280, 720));

操作步驟:

  1. 獲取CanvasScaler組件。
  2. 調用SetReferenceResolution函數,設置畫布的參考解析度為1280x720。

註意事項:

  • 在使用CanvasScaler組件時,需要將Canvas的Render Mode設置為Screen Space - Camera或Screen Space - Overlay,否則CanvasScaler將無效。
  • 在設置參考解析度時,應根據目標平臺的解析度進行調整,以保證UI在不同設備上的顯示效果一致。

參考資料:

__EOF__

本文作者 Blank
本文鏈接
版權聲明:本博客所有文章除特別聲明外,均採用 BY-NC-SA 許可協議。轉載請註明出處!
聲援博主:如果您覺得文章對您有幫助,可以點擊文章右下角 推薦 一下。您的鼓勵是博主的最大動力!

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • # 通用返回類Result > 前言:Java項目搭建時,常常需要去封裝一個通用型的Result工具類,下麵就是我自己封裝的常用的返回類,可以直接使用。(*有部分Swagger註解,使用時可忽略*) ### 第一步、創建ReusltUtils工具類 ```java package com.code. ...
  • 來源:toutiao.com/a6775476659416990212 ## **前言** 在SpringBoot框架中,我們使用最多的是Tomcat,這是SpringBoot預設的容器技術,而且是內嵌式的Tomcat。 同時,SpringBoot也支持Undertow容器,我們可以很方便的用Und ...
  • ## 什麼是 gRPC? gRPC 是由 Google 開發的高性能、開源的 RPC(Remote Procedure Call)框架,用於在客戶端和伺服器之間進行通信。它基於 Protocol Buffers(protobuf)進行消息序列化和反序列化,支持多種通信協議,如 HTTP/2、TCP ...
  • # UDP網路通信編程 - **基本介紹** 1. 類DatagramSocket和DatagramPacket實現了基於UDP協議網路程式。 2. UDP數據報通過數據報套接字DatagramSocket發送和接收,系統不保證UDP數據報一定能夠安全送到目的地,也不能確定什麼時候可以抵達。 3. ...
  • 由於一些歷史原因,重裝系統成為Windows用戶解決疑難雜症的祖傳手藝。受此影響,給硬碟分區幾乎成為了一種執念,少則C、D兩個盤,誇張一點的5~6個盤的也不是沒有。 > PS:macOS和Linux一直都不鼓勵給磁碟分區,雖然不禁止但也不提倡。隨著雲技術和寬頻的提升,越來越多的人更喜歡把自己認為比較 ...
  • 眾所周知,我們是訪問不通OpenAI官方服務的,但是我們可以自己通過代理或者使用第三方代理訪問介面 現在新出台的規定禁止使用境外的AI大模型介面對境內客戶使用,所以我們需要使用國內的大模型介面 國內的效果真的很差,現在如果想合規的使用GPT大模型,可以使用微軟Azure的OpenAI服務,畢竟微軟在 ...
  • # Avalonia 使用EFCore調用SQLite實現Singleton全局註冊 ![image-20230720204001797](https://www.raokun.top/upload/2023/07/image-20230720204001797.png) 本篇博客是我的開源項目[T ...
  • asp.net項目開發過程中用到了多個程式集(dll), 如何根據類型全名(fullname)獲取類型信息? 如果項目(csproj)中設置了引用對應的dll 或nupkg包,但是代碼中沒有任務地方引用改該程式集的類,則實際上運行時,該程式集不會被載入到進程中. 假設有一個 ThirdModels. ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...