Unity UGUI的Canvas(画布)组件的介绍及使用

这篇具有很好参考价值的文章主要介绍了Unity UGUI的Canvas(画布)组件的介绍及使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Unity UGUI的Canvas(画布)组件的介绍及使用

1. 什么是Canvas组件?

Canvas(画布)是Unity UGUI系统中的一个重要组件,用于在屏幕上绘制UI元素。它是UI元素的容器,可以包含各种UI元素,如按钮、文本、图像等。Canvas组件提供了一种方便的方式来管理和渲染UI元素。

2. Canvas组件的工作原理

Canvas组件通过渲染器将UI元素绘制到屏幕上。它使用层级结构来管理UI元素的显示顺序,可以通过设置UI元素的层级来控制它们的显示顺序。Canvas组件还可以设置渲染模式,包括屏幕空间、世界空间和摄像机空间等。

3. Canvas组件的常用属性

  • Render Mode(渲染模式):设置Canvas的渲染模式,包括屏幕空间、世界空间和摄像机空间等。
  • Sorting Layer(排序层级):设置Canvas的排序层级,用于控制UI元素的显示顺序。
  • Order in Layer(层级顺序):设置UI元素在排序层级中的显示顺序。
  • Pixel Perfect(像素完美):启用像素完美模式,可以确保UI元素在不同分辨率下的显示效果一致。
  • Reference Pixels Per Unit(参考像素单位):设置参考像素单位,用于计算UI元素的大小和位置。

4. Canvas组件的常用函数

  • SetRenderMode(RenderMode mode):设置Canvas的渲染模式。
  • SetSortingLayerName(string name):设置Canvas的排序层级名称。
  • SetOrderInLayer(int order):设置UI元素在排序层级中的显示顺序。
  • SetPixelPerfect(bool pixelPerfect):设置是否启用像素完美模式。
  • SetReferencePixelsPerUnit(float pixelsPerUnit):设置参考像素单位。

5. 示例代码

示例1:创建一个屏幕空间的Canvas

using UnityEngine;
using UnityEngine.UI;

public class CanvasExample : MonoBehaviour
{
    void Start()
    {
        // 创建一个屏幕空间的Canvas
        GameObject canvasObject = new GameObject("Canvas");
        Canvas canvas = canvasObject.AddComponent<Canvas>();
        canvas.renderMode = RenderMode.ScreenSpaceOverlay;

        // 创建一个UI元素
        GameObject textObject = new GameObject("Text");
        textObject.transform.SetParent(canvas.transform);
        Text text = textObject.AddComponent<Text>();
        text.text = "Hello World!";
    }
}

操作步骤:

  1. 创建一个空的GameObject,并将脚本挂载到该GameObject上。
  2. 在Start函数中,创建一个屏幕空间的Canvas。
  3. 创建一个UI元素,并将其设置为Canvas的子物体。
  4. 设置UI元素的文本内容为"Hello World!"。

示例2:创建一个世界空间的Canvas

using UnityEngine;
using UnityEngine.UI;

public class CanvasExample : MonoBehaviour
{
    void Start()
    {
        // 创建一个世界空间的Canvas
        GameObject canvasObject = new GameObject("Canvas");
        Canvas canvas = canvasObject.AddComponent<Canvas>();
        canvas.renderMode = RenderMode.WorldSpace;

        // 创建一个UI元素
        GameObject textObject = new GameObject("Text");
        textObject.transform.SetParent(canvas.transform);
        Text text = textObject.AddComponent<Text>();
        text.text = "Hello World!";
    }
}

操作步骤:

  1. 创建一个空的GameObject,并将脚本挂载到该GameObject上。
  2. 在Start函数中,创建一个世界空间的Canvas。
  3. 创建一个UI元素,并将其设置为Canvas的子物体。
  4. 设置UI元素的文本内容为"Hello World!"。

示例3:设置Canvas的排序层级和层级顺序

using UnityEngine;
using UnityEngine.UI;

public class CanvasExample : MonoBehaviour
{
    void Start()
    {
        // 创建一个屏幕空间的Canvas
        GameObject canvasObject = new GameObject("Canvas");
        Canvas canvas = canvasObject.AddComponent<Canvas>();
        canvas.renderMode = RenderMode.ScreenSpaceOverlay;

        // 创建两个UI元素
        GameObject textObject1 = new GameObject("Text1");
        textObject1.transform.SetParent(canvas.transform);
        Text text1 = textObject1.AddComponent<Text>();
        text1.text = "Text 1";
        text1.canvas.sortingLayerName = "UI";
        text1.canvas.sortingOrder = 1;

        GameObject textObject2 = new GameObject("Text2");
        textObject2.transform.SetParent(canvas.transform);
        Text text2 = textObject2.AddComponent<Text>();
        text2.text = "Text 2";
        text2.canvas.sortingLayerName = "UI";
        text2.canvas.sortingOrder = 2;
    }
}

操作步骤:

  1. 创建一个空的GameObject,并将脚本挂载到该GameObject上。
  2. 在Start函数中,创建一个屏幕空间的Canvas。
  3. 创建两个UI元素,并将它们设置为Canvas的子物体。
  4. 设置第一个UI元素的排序层级为"UI",层级顺序为1。
  5. 设置第二个UI元素的排序层级为"UI",层级顺序为2。

示例4:启用像素完美模式

using UnityEngine;
using UnityEngine.UI;

public class CanvasExample : MonoBehaviour
{
    void Start()
    {
        // 创建一个屏幕空间的Canvas
        GameObject canvasObject = new GameObject("Canvas");
        Canvas canvas = canvasObject.AddComponent<Canvas>();
        canvas.renderMode = RenderMode.ScreenSpaceOverlay;
        canvas.pixelPerfect = true;

        // 创建一个UI元素
        GameObject textObject = new GameObject("Text");
        textObject.transform.SetParent(canvas.transform);
        Text text = textObject.AddComponent<Text>();
        text.text = "Hello World!";
    }
}

操作步骤:

  1. 创建一个空的GameObject,并将脚本挂载到该GameObject上。
  2. 在Start函数中,创建一个屏幕空间的Canvas。
  3. 启用像素完美模式。
  4. 创建一个UI元素,并将其设置为Canvas的子物体。
  5. 设置UI元素的文本内容为"Hello World!"。

示例5:设置参考像素单位

using UnityEngine;
using UnityEngine.UI;

public class CanvasExample : MonoBehaviour
{
    void Start()
    {
        // 创建一个屏幕空间的Canvas
        GameObject canvasObject = new GameObject("Canvas");
        Canvas canvas = canvasObject.AddComponent<Canvas>();
        canvas.renderMode = RenderMode.ScreenSpaceOverlay;
        canvas.referencePixelsPerUnit = 100;

        // 创建一个UI元素
        GameObject textObject = new GameObject("Text");
        textObject.transform.SetParent(canvas.transform);
        Text text = textObject.AddComponent<Text>();
        text.text = "Hello World!";
    }
}

操作步骤:文章来源地址https://www.toymoban.com/news/detail-715061.html

  1. 创建一个空的GameObject,并将脚本挂载到该GameObject上。
  2. 在Start函数中,创建一个屏幕空间的Canvas。
  3. 设置参考像素单位为100。
  4. 创建一个UI元素,并将其设置为Canvas的子物体。
  5. 设置UI元素的文本内容为"Hello World!"。

注意事项

  • Canvas组件只能在UI层级下使用,不能用于3D场景中。
  • Canvas组件的渲染模式和排序层级需要根据实际需求进行设置。
  • 在使用Canvas组件时,需要注意UI元素的层级顺序,以确保它们的显示效果正确。

参考资料

  • Unity官方文档 - Canvas
  • Unity官方教程 - UI
  • Unity官方论坛 - UI

到了这里,关于Unity UGUI的Canvas(画布)组件的介绍及使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • Unity Canvas、Canvas Scaler、Graphic Raycaster、EventSystem 组件详解

    Unity Canvas、Canvas Scaler、Graphic Raycaster、EventSystem 组件详解

    https://blog.csdn.net/qq_33789001/article/details/117781577 https://blog.csdn.net/q764424567/article/details/119923544 属性 功能 Pixel Perfect 使UI元素像素对应,效果就是边缘清晰不模糊 Sort Order 多个Canvas时,数值越大越后渲染。值大的 画布,会挡住值小的 Target Display 目标显示器,如果有多个屏幕的话可

    2024年01月21日
    浏览(31)
  • Unity UGUI的所有组件的介绍及使用

    本文将介绍Unity UGUI中的各个组件,包括它们的具体介绍、用途 介绍:Text组件用于在UI界面上显示文本内容。 用途:常用于显示UI界面的标题、按钮标签、提示信息等。 介绍:Image组件用于在UI界面上显示图片。 用途:常用于显示角色头像、道具图标、背景图片等。 介绍:

    2024年02月12日
    浏览(44)
  • Unity UGUI的Button组件的介绍及使用

    UGUI(Unity GUI)是Unity引擎中的一套用户界面系统,Button(按钮)是其中的一个常用组件。Button组件可以用于创建可交互的按钮,用户点击按钮时可以触发相应的事件。 Button组件通过检测用户的点击事件来触发相应的操作。当用户点击按钮时,Button组件会检测到点击事件,并执

    2024年02月12日
    浏览(410)
  • 【Unity】UGUI中Camera Depth,Canvas Sorting Layer、Order in Layer与Particle System渲染层级分析

    【Unity】UGUI中Camera Depth,Canvas Sorting Layer、Order in Layer与Particle System渲染层级分析

    目录   前言 一、项目需求 二、Camera 1.Clear Flags 2.Culling Mask  三、Canvas 1.Sorting Layer 2.Order in Layer 四、Particle System 1.Sorting LayerID 与Order in Layer 总结         最近在做项目的过程中,发现项目中的部分3d模型会被粒子特效所遮挡,这并不是笔者想要的效果,于是经过一番面向

    2024年02月05日
    浏览(11)
  • Unity UGUI的Mask(遮罩)组件的介绍及使用

    Mask(遮罩)组件是Unity UGUI中的一个重要组件,用于限制子对象的可见区域。通过设置遮罩组件,可以实现一些特殊效果,如显示部分图片、裁剪文本等。 Mask组件通过将子对象与遮罩对象进行比较,只显示与遮罩对象重叠的部分,从而实现遮罩效果。遮罩对象可以是任意形状

    2024年02月13日
    浏览(48)
  • Unity UGUI的Text(文本)组件的介绍及使用

    UGUI(Unity Graphic User Interface)是Unity引擎的一套用户界面系统,而Text(文本)组件是UGUI中用于在游戏界面中显示文本的组件。该组件可以用于显示游戏中的文字、数字、标签等信息。 使用UGUI的Text组件可以在游戏界面中实时显示文字信息,方便玩家了解游戏的状态、交互信息

    2024年02月12日
    浏览(48)
  • Unity UGUI的Outline(描边)组件的介绍及使用

    Outline(描边)组件是Unity UGUI中的一种特效组件,用于给UI元素添加描边效果。通过设置描边的颜色、宽度和模糊程度,可以使UI元素在视觉上更加突出。 Outline(描边)组件通过在UI元素周围绘制多个相同的UI元素,并设置不同的颜色和大小,从而实现描边的效果。描边的宽度和模糊

    2024年02月15日
    浏览(46)
  • Unity UGUI的Image(图片)组件的介绍及使用

    UGUI的Image(图片)组件是Unity引擎中的一种UI组件,用于显示2D图像。它提供了一种简单而灵活的方式来在游戏中加载和显示图片。 使用UGUI的Image组件可以方便地在游戏中展示各种图片资源,比如角色头像、道具图标等。它具有以下优点: 易用性 :UGUI的Image组件提供了简单易

    2024年02月11日
    浏览(48)
  • Unity UGUI的RawImage(原始图片)组件的介绍及使用

    RawImage是Unity UGUI中的一个组件,用于显示原始图片。与Image组件不同,RawImage可以直接显示原始图片的像素数据,而不需要经过额外的处理。 RawImage组件通过将原始图片的像素数据直接传递给显卡进行渲染,从而实现显示原始图片的功能。它可以显示各种格式的图片,包括常见

    2024年02月16日
    浏览(48)
  • Unity UGUI的Scrollbar(滚动条)组件的介绍及使用

    Scrollbar组件是Unity中UGUI系统提供的一种UI组件,主要用于在UI界面中提供滚动条功能,使用户可以通过滚动条来查看超出屏幕范围的内容。 Scrollbar组件的工作原理主要是通过改变滚动条的位置来改变关联的内容的显示位置。当用户拖动滚动条时,Scrollbar组件会根据滚动条的位

    2024年02月13日
    浏览(12)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包