当前位置:   article > 正文

Unity UGUI的ContentSizeFitter(内容尺寸适应器)组件的介绍及使用_unity contentsizefitter

unity contentsizefitter

Unity UGUI的ContentSizeFitter(内容尺寸适应器)组件的介绍及使用

1. 什么是ContentSizeFitter组件?

ContentSizeFitter是Unity UGUI中的一个组件,用于自动调整UI元素的大小,以适应其内容的大小变化。它可以根据内容的大小自动调整UI元素的宽度和高度,确保内容不会被截断或溢出。

2. ContentSizeFitter的工作原理

ContentSizeFitter组件通过监听UI元素的子元素的大小变化,自动调整UI元素的大小。它可以根据子元素的大小自动调整UI元素的宽度和高度,以确保子元素的内容不会被截断或溢出。

3. ContentSizeFitter的常用属性

  • Horizontal Fit:水平适应方式,可选值为Unconstrained(不限制)、Preferred Size(首选大小)和 Min Size(最小大小)。
  • Vertical Fit:垂直适应方式,可选值为Unconstrained(不限制)、Preferred Size(首选大小)和 Min Size(最小大小)。

4. ContentSizeFitter的常用函数

  • SetLayoutHorizontal():手动调用此函数可以强制更新水平适应方式。
  • SetLayoutVertical():手动调用此函数可以强制更新垂直适应方式。

5. ContentSizeFitter的使用示例

示例1:自动调整按钮大小以适应文本内容

  1. 创建一个按钮,并添加一个Text组件作为子元素。
  2. 将ContentSizeFitter组件添加到按钮上。
  3. 将Horizontal Fit属性设置为Preferred Size,Vertical Fit属性设置为Preferred Size。
  4. 编写脚本,在Start函数中调用SetLayoutHorizontal()和SetLayoutVertical()函数。
    using UnityEngine;
    using UnityEngine.UI;
    
    • 1
    • 2

public class ButtonAutoSize : MonoBehaviour { private Button button; private Text text;

private void Start()
{
    button = GetComponent<Button>();
    text = GetComponentInChildren<Text>();

    button.GetComponent<ContentSizeFitter>().SetLayoutHorizontal();
    button.GetComponent<ContentSizeFitter>().SetLayoutVertical();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

}


### 示例2:自动调整面板大小以适应子元素
1. 创建一个面板,并添加一些子元素。
2. 将ContentSizeFitter组件添加到面板上。
3. 将Horizontal Fit属性设置为Preferred Size,Vertical Fit属性设置为Preferred Size。
4. 编写脚本,在Start函数中调用SetLayoutHorizontal()和SetLayoutVertical()函数。
```csharp
using UnityEngine;
using UnityEngine.UI;

public class PanelAutoSize : MonoBehaviour
{
    private RectTransform panel;

    private void Start()
    {
        panel = GetComponent<RectTransform>();

        panel.GetComponent<ContentSizeFitter>().SetLayoutHorizontal();
        panel.GetComponent<ContentSizeFitter>().SetLayoutVertical();
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

示例3:自动调整滚动视图大小以适应内容

  1. 创建一个滚动视图,并添加一些子元素。
  2. 将ContentSizeFitter组件添加到滚动视图的Content上。
  3. 将Horizontal Fit属性设置为Preferred Size,Vertical Fit属性设置为Preferred Size。
  4. 编写脚本,在Start函数中调用SetLayoutHorizontal()和SetLayoutVertical()函数。
    using UnityEngine;
    using UnityEngine.UI;
    
    • 1
    • 2

public class ScrollViewAutoSize : MonoBehaviour { private RectTransform content;

private void Start()
{
    content = GetComponent<ScrollRect>().content;

    content.GetComponent<ContentSizeFitter>().SetLayoutHorizontal();
    content.GetComponent<ContentSizeFitter>().SetLayoutVertical();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

}


### 示例4:自动调整网格布局大小以适应子元素
1. 创建一个网格布局,并添加一些子元素。
2. 将ContentSizeFitter组件添加到网格布局的Content上。
3. 将Horizontal Fit属性设置为Preferred Size,Vertical Fit属性设置为Preferred Size。
4. 编写脚本,在Start函数中调用SetLayoutHorizontal()和SetLayoutVertical()函数。
```csharp
using UnityEngine;
using UnityEngine.UI;

public class GridLayoutAutoSize : MonoBehaviour
{
    private GridLayoutGroup gridLayout;

    private void Start()
    {
        gridLayout = GetComponent<GridLayoutGroup>();

        gridLayout.GetComponent<ContentSizeFitter>().SetLayoutHorizontal();
        gridLayout.GetComponent<ContentSizeFitter>().SetLayoutVertical();
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

示例5:自动调整水平布局大小以适应子元素

  1. 创建一个水平布局,并添加一些子元素。
  2. 将ContentSizeFitter组件添加到水平布局的Content上。
  3. 将Horizontal Fit属性设置为Preferred Size,Vertical Fit属性设置为Preferred Size。
  4. 编写脚本,在Start函数中调用SetLayoutHorizontal()和SetLayoutVertical()函数。
    using UnityEngine;
    using UnityEngine.UI;
    
    • 1
    • 2

public class HorizontalLayoutAutoSize : MonoBehaviour { private HorizontalLayoutGroup horizontalLayout;

private void Start()
{
    horizontalLayout = GetComponent<HorizontalLayoutGroup>();

    horizontalLayout.GetComponent<ContentSizeFitter>().SetLayoutHorizontal();
    horizontalLayout.GetComponent<ContentSizeFitter>().SetLayoutVertical();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

}

```

注意事项

  • ContentSizeFitter组件只能用于Layout Group(布局组)的子元素上。
  • ContentSizeFitter组件的调整是在布局计算之后进行的,因此需要手动调用SetLayoutHorizontal()和SetLayoutVertical()函数来更新布局。

参考资料

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/110386
推荐阅读
相关标签
  

闽ICP备14008679号