Unity UGUI控制text文字间距

Unity ugui相比ngui,提供的功能少之又少,好多特性得需要自己实现。真不知道unity写这个插件后来是不是就没有更新过。发了句牢骚。如果我想控制文字的显示间距,ngui 有两种办法。1:文字之间加空格。2:调节spacing 的x值。

但对于ugui,第二种方法却没有。以前我使用ngui,这种方法用的多了,也方便,因此很想也把它这个特性转到ugui上。

思考了半天,最终想出来了解决方法,以下是实现方式:

1、定义扩展效果类

[RequireComponent(typeof(Text))]
public class Spacing : BaseMeshEffect
{
}

2、添加行间距,列间距(Text的行间距废掉不用了),缓存顶点信息

[SerializeField]
 private float spacing_x;
 [SerializeField]
 private float spacing_y;

private List<UIVertex> mVertexList;

3、获取相关文字的顶点信息数组,通过每六个定点信息代表一个文字来判断列数。通过定点信息的横坐标来判断行数(这个想了半天才找出的解决方案。我先试的纵坐标,结果却不那么好用,大伙把顶点的值打出来就明白了)。这样通过修改文字的顶点的位置信息据解决了。下面是具体的实现:

public override void ModifyMesh(VertexHelper vh)
  {
    if(spacing_x == 0 && spacing_y == 0) { return; }
    if (!IsActive()) { return; }
    int count = vh.currentVertCount;
    if (count == 0) { return; }
    if (mVertexList == null) { mVertexList = new List<UIVertex>(); }
    vh.GetUIVertexStream(mVertexList);
    int row = 1;
    int column = 2;
    List<UIVertex> sub_vertexs = mVertexList.GetRange(0, 6);
    float min_row_left = sub_vertexs.Min(v => v.position.x);
    int vertex_count = mVertexList.Count;
    for (int i = 6; i < vertex_count;)
    {
      if (i % 6 == 0)
      {
        sub_vertexs = mVertexList.GetRange(i, 6);
        float tem_row_left = sub_vertexs.Min(v => v.position.x);
        if (tem_row_left <= min_row_left)
        {
          min_row_left = tem_row_left;
          ++row;
          column = 1;
          //continue;
        }
      }
      for(int j=0;j<6;j++)
      {
        UIVertex vertex = mVertexList[i];
        vertex.position += Vector3.right * (column - 1) * spacing_x;
        vertex.position += Vector3.down * (row - 1) * spacing_y;
        mVertexList[i] = vertex;
        ++i;
      }
      ++column;
    }
    vh.Clear();
    vh.AddUIVertexTriangleStream(mVertexList);
  }

把这个脚本挂上去,修改spceing_x和spacing_y大伙就能看到效果。如果大伙有更好的实现方式,欢迎大家留言讨论,完。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • UGUI实现随意调整Text中的字体间距

    UGUI中是没有可以随意调整字体间的距离的方法,仔细研究一下可以通过控制每个字体的网格顶点位置进行调整字体之间的距离,分析一下最简单情况:输入的文本是单行的,且末尾没有换行符: unity在UnityEngine.UI命名空间中定义了一个BaseMeshEffect抽象类,他提供了一个抽象方法ModifyMesh(VertexHelper vh),使得可以轻松地获得text文本中所有字体 的顶点信息,我们的移动字体的操作将在这里面进行.VertexHelper类主要是用于提供字体网格数据的工具类

  • Unity UGUI控制text文字间距

    Unity ugui相比ngui,提供的功能少之又少,好多特性得需要自己实现.真不知道unity写这个插件后来是不是就没有更新过.发了句牢骚.如果我想控制文字的显示间距,ngui 有两种办法.1:文字之间加空格.2:调节spacing 的x值. 但对于ugui,第二种方法却没有.以前我使用ngui,这种方法用的多了,也方便,因此很想也把它这个特性转到ugui上. 思考了半天,最终想出来了解决方法,以下是实现方式: 1.定义扩展效果类 [RequireComponent(typeof(Text))

  • unity里获取text中文字宽度并截断省略的操作

    前言 在unity的ugui中Text控件,有时我们会有各种各样的需求,比如类似html中css的text-overflow属性,希望一段文字如果不够长就全显示,如果特别长就截断并且后面加上例如-这种后缀. 好吧这样的需求在ugui里貌似没有现成的方法,如果有的话麻烦指点一下~ 实现 大概的思路就是 - 首先要能判断什么时候overflow - 并且支持加上后缀 那么text控件本来是支持overflow然后直接截断的,但是比较暴力,直接砍断,不能加后缀,并不满足我们的需求. 然后如果简单的通过

  • Unity UGUI通过摇杆控制角色移动

    本文实例为大家分享了Unity UGUI通过摇杆控制角色移动的具体代码,供大家参考,具体内容如下 简单版:控制方块的移动. 进阶版:控制人物的移动 知识铺垫: 首先我们必须要知道,在Unity的UGUI中,对UI的操作有八个回调,分别需要实现八个接口.分别是: 鼠标进入,鼠标离开,鼠标点下,鼠标抬起,鼠标开始拖拽,鼠标拖拽中,拖拽结束 如下所示: 我们可以先对这几个接口方法进行一下测试: 测试结束后,大家就会对这些接口方法有一些初步的了解. using UnityEngine; using Un

  • Unity UGUI教程之实现滑页效果

    简介 项目需要...直接展示效果吧: 原理 使用UGUI提供的ScrollRect和ScrollBar组件实现基本滑动以及自己控制每次移动一页来达到滑页的效果. 实现过程 1.创建两个panel,上面的panel用于显示,下面的panel用于存放按钮 2.在TopPanel上添加ScrollRect脚本,用于滑动 3.在TopPanel下创建一个新的Panel,并在子Panel下拜访要显示的对象 4.将该子Panel设置为ScrollRect的活动对象 5.为ScrollRect添加Scroll

  • Unity UGUI实现滑动翻页直接跳转页数

    本文实例为大家分享了Unity UGUI实现滑动翻页,直接跳转页数的具体代码,供大家参考,具体内容如下 首先看一下最终效果 其实这个功能基本上是老生常谈了,所以代码还是很简单 using UnityEngine; using System.Collections; using UnityEngine.UI; using System.Collections.Generic; using UnityEngine.EventSystems; using System; public class Pa

  • Unity UGUI实现滑动翻页效果

    本文实例为大家分享了Unity UGUI实现滑动翻页效果的具体代码,供大家参考,具体内容如下 这个问题真的是老生常谈的事情了,不过在这里还是要说一下,以便以后之需 首先看一下效果图 最后在Content下面是一些Image using UnityEngine; using System.Collections; using UnityEngine.UI; using System.Collections.Generic; using UnityEngine.EventSystems; using

  • Unity UGUI 按钮绑定事件的 4 种方式汇总

    UGUI 可视化创建以及关联事件很方便, 动态创建可以利用创建好的 Prefab 进行实例化, 只是在关联事件上有些复杂, 本文总结了几种给按钮绑定事件的关联方式. 1. 可视化创建及事件绑定 Step 1 : 通过 Hierarchy 面板创建 UI > Button. Step 2 : 创建一个脚本 TestClick.cs, 定义了一个 Click 的 public 方法. Step 3 : 选中 Hierarchy 中的 Button, Add Component 脚本 TestClic

  • Unity UGUI实现卡片椭圆方向滚动

    本文实例为大家分享了UGUI实现卡片椭圆方向滚动的具体代码,供大家参考,具体内容如下 搭建简单的场景 运行效果 卡片移动动画通过插件DoTween实现 控制脚本: using UnityEngine; using System.Collections; using UnityEngine.UI; using DG.Tweening; public class CardMove : MonoBehaviour { GameObject[] sprites; int halfSize; Vector

  • unity 如何获取Text组件里text内容的长度

    我就废话不多说了,大家还是直接看代码吧~ /// <summary> /// 计算字符串在指定text控件中的长度 /// </summary> /// <param name="message"></param> /// <returns></returns> int CalculateLengthOfText(string message,Text tex) { int totalLength = 0; Fon

  • Unity UGUI实现简单拖拽图片功能

    这一篇博客我们来使用 UGUI 实现图片的拖拽功能. 说到拖拽,那必然离不开坐标,UGUI 的坐标有点不一样,它有两种坐标,一种是屏幕坐标,还有一种就是 UI 在Canvas内的坐标(暂时叫做ugui坐标.),这两个坐标是不一样的,所以拖拽是就需要转换.因为鼠标的移动是屏幕坐标,而 UI 的移动是ugui坐标.转换的方法: RectTransformUtility.ScreenPointToLocalPointInRectangle ( - );这个方法可以把屏幕坐标转换成 ugui 坐标.至于

随机推荐