Unity UGUI的Outline(描邊)組件的介紹及使用

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

# Unity UGUI的Outline(描邊)組件的介紹及使用 ## 1. 什麼是Outline(描邊)組件? Outline(描邊)組件是Unity UGUI中的一種特效組件,用於給UI元素添加描邊效果。通過設置描邊的顏色、寬度和模糊程度,可以使UI元素在視覺上更加突出。 ## 2. Outli ...


Unity UGUI的Outline(描邊)組件的介紹及使用

1. 什麼是Outline(描邊)組件?

Outline(描邊)組件是Unity UGUI中的一種特效組件,用於給UI元素添加描邊效果。通過設置描邊的顏色、寬度和模糊程度,可以使UI元素在視覺上更加突出。

2. Outline(描邊)組件的工作原理

Outline(描邊)組件通過在UI元素周圍繪製多個相同的UI元素,並設置不同的顏色和大小,從而實現描邊的效果。描邊的寬度和模糊程度可以通過調整參數來控制。

3. Outline(描邊)組件的常用屬性

  • Effect Color:描邊的顏色。
  • Effect Distance:描邊的距離,可以設置為正值或負值。
  • Use Graphic Alpha:是否使用UI元素的透明度作為描邊的透明度。
  • Blur:描邊的模糊程度。
  • Outline:描邊的寬度。

4. Outline(描邊)組件的常用函數

  • ModifyMesh:修改UI元素的網格,用於繪製描邊效果。

5. 完整例子代碼

例子1:給按鈕添加紅色描邊

using UnityEngine;
using UnityEngine.UI;

public class Example1 : MonoBehaviour
{
    public Button button;
    public Outline outline;

    void Start()
    {
        outline.effectColor = Color.red;
        outline.effectDistance = new Vector2(2, -2);
        outline.useGraphicAlpha = true;
        outline.blur = 0;
        outline.outline = 5;
    }
}

操作步驟:

  1. 創建一個按鈕,並將Example1腳本掛載到按鈕上。
  2. 將按鈕的Outline組件拖拽到Example1腳本的outline變數上。
  3. 在Start函數中,設置outline的屬性,包括effectColor、effectDistance、useGraphicAlpha、blur和outline。

註意事項:

  • 可以根據需要調整描邊的顏色、距離、透明度、模糊程度和寬度。

例子2:給文本添加藍色描邊

using UnityEngine;
using UnityEngine.UI;

public class Example2 : MonoBehaviour
{
    public Text text;
    public Outline outline;

    void Start()
    {
        outline.effectColor = Color.blue;
        outline.effectDistance = new Vector2(1, -1);
        outline.useGraphicAlpha = true;
        outline.blur = 0;
        outline.outline = 3;
    }
}

操作步驟:

  1. 創建一個文本對象,並將Example2腳本掛載到文本對象上。
  2. 將文本對象的Outline組件拖拽到Example2腳本的outline變數上。
  3. 在Start函數中,設置outline的屬性,包括effectColor、effectDistance、useGraphicAlpha、blur和outline。

註意事項:

  • 可以根據需要調整描邊的顏色、距離、透明度、模糊程度和寬度。

例子3:給圖片添加綠色描邊

using UnityEngine;
using UnityEngine.UI;

public class Example3 : MonoBehaviour
{
    public Image image;
    public Outline outline;

    void Start()
    {
        outline.effectColor = Color.green;
        outline.effectDistance = new Vector2(3, -3);
        outline.useGraphicAlpha = true;
        outline.blur = 0;
        outline.outline = 7;
    }
}

操作步驟:

  1. 創建一個圖片對象,並將Example3腳本掛載到圖片對象上。
  2. 將圖片對象的Outline組件拖拽到Example3腳本的outline變數上。
  3. 在Start函數中,設置outline的屬性,包括effectColor、effectDistance、useGraphicAlpha、blur和outline。

註意事項:

  • 可以根據需要調整描邊的顏色、距離、透明度、模糊程度和寬度。

例子4:給滑動條添加黃色描邊

using UnityEngine;
using UnityEngine.UI;

public class Example4 : MonoBehaviour
{
    public Slider slider;
    public Outline outline;

    void Start()
    {
        outline.effectColor = Color.yellow;
        outline.effectDistance = new Vector2(2, -2);
        outline.useGraphicAlpha = true;
        outline.blur = 0;
        outline.outline = 5;
    }
}

操作步驟:

  1. 創建一個滑動條對象,並將Example4腳本掛載到滑動條對象上。
  2. 將滑動條對象的Outline組件拖拽到Example4腳本的outline變數上。
  3. 在Start函數中,設置outline的屬性,包括effectColor、effectDistance、useGraphicAlpha、blur和outline。

註意事項:

  • 可以根據需要調整描邊的顏色、距離、透明度、模糊程度和寬度。

例子5:給輸入框添加紫色描邊

using UnityEngine;
using UnityEngine.UI;

public class Example5 : MonoBehaviour
{
    public InputField inputField;
    public Outline outline;

    void Start()
    {
        outline.effectColor = Color.magenta;
        outline.effectDistance = new Vector2(1, -1);
        outline.useGraphicAlpha = true;
        outline.blur = 0;
        outline.outline = 3;
    }
}

操作步驟:

  1. 創建一個輸入框對象,並將Example5腳本掛載到輸入框對象上。
  2. 將輸入框對象的Outline組件拖拽到Example5腳本的outline變數上。
  3. 在Start函數中,設置outline的屬性,包括effectColor、effectDistance、useGraphicAlpha、blur和outline。

註意事項:

  • 可以根據需要調整描邊的顏色、距離、透明度、模糊程度和寬度。

參考資料

__EOF__

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

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

-Advertisement-
Play Games
更多相關文章
  • 博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ...
  • # Spring Cloud Demo 本文介紹Spring Cloud 常用的組件的demo代碼。gitee代碼:https://gitee.com/Aes_yt/spring-cloud-demo 包括Spring Cloud Eureka,Spring Cloud Feign,Spring C ...
  • Java解析、生成Excel比較有名的框架有Apache poi、jxl。但他們都存在一個嚴重的問題就是非常的耗記憶體,poi有一套SAX模式的API可以一定程度的解決一些記憶體溢出的問題,但POI還是有一些缺陷,比如07版Excel解壓縮以及解壓後存儲都是在記憶體中完成的,記憶體消耗依然很大。easyex ...
  • # Java 多態 # 1. 多態 ## 方法或對象具有多種形態。是面向對象的三大特征之一,多態是建立在封裝、繼承基礎之上的 # 2. 多態的實現: ## 方法的重載中,使用不同的形參調用方法體現出了多態 ## 方法的重寫中,使用父類或子類的對象調用方法體現出了多態 ## 對象的多態: ## 對象的 ...
  • QAction 類表示用戶命令的一種抽象,包括命令文本、圖標、命令觸發後要執行的代碼。菜單、工具欄按鈕往往存在相同的功能,將這些命令獨立抽出來,放到 QAction 以象上,可避免編寫重覆的代碼。比如“文件”菜單下有“保存”命令,工具欄上也會有“保存”按鈕。因此,創建一個表示“保存”的 QActio ...
  • > 以前學校上C語言課程都是使用VC++6.0上課,這個學期為了複習一遍C語言,而且自己經常使用VSCode開發前端項目,所以為了方便。這裡把需要的環境和插件配置在這裡介紹一下。 ### Windows環境下安裝C語言編譯器 MinGW-W64 GCCC的下載地址為:https://sourcefo ...
  • # 簡介 ### 按鍵 按鍵是輸入設備,一般來說,按鍵在沒有按下的時候是高電平;當按鍵按下的時候,為低電平。 在***DE2-70 User Manual***中 > Each switch provides a high logic level (3.3 volts) when it is not ...
  • IntelliJ IDEA的遠程開發功能,可以將編譯和運行等消耗資源任務放在伺服器上執行,降低本地電腦負載,但是體驗上和之前的IDEA操作保持一致,破舊的老機器也能煥發青春 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...