【狂云歌之unity_vr】unity里获取text中文字宽度并截断省略

【狂云歌之unity_vr】unity⾥获取text中⽂字宽度并截断省略
【狂云歌之unity_vr】unity⾥获取text中⽂字宽度并截断省略
前⾔
 在unity的ugui中Text控件,有时我们会有各种各样的需求,⽐如类似html中css的text-overflow属性,希望⼀段⽂字如果不够长就全显⽰,如果特别长就截断并且后⾯加上例如…这种后缀
 好吧这样的需求在ugui⾥貌似没有现成的⽅法,如果有的话⿇烦指点⼀下~检查井井座
实现
 ⼤概的思路就是
- ⾸先要能判断什么时候overflow
- 并且⽀持加上后缀
文字拼接 那么text控件本来是⽀持overflow然后直接截断的,但是⽐较暴⼒,直接砍断,不能加后缀,并不满⾜我们的需求。
 然后如果简单的通过字符个数截断,那根本不⾏,如果根据中英⽂字符来根据长度截断,这个我试过,然⽽字体并不⼀定是⼀个中⽂相当于俩英⽂字符,于是乎如果有⼀⼤排lllll或者iii什么的,悲剧⽆以⾔表。
 所以我们需要知道⼀段⽂字所对应的渲染之后的长度。如果从text的preferwidth或者通过添加content size filter组件应该也能完成类似任务,不过我倾向于直接算好长度去填充。
 这个功能核⼼代码为
Font myFont = text.font;  //chatText is my Text component
myFont.RequestCharactersInTexture(message, text.fontSize, text.fontStyle);
CharacterInfo characterInfo = new CharacterInfo();
char[] arr = message.ToCharArray();
foreach (char c in arr)
{
myFont.GetCharacterInfo(c, out characterInfo, text.fontSize);
totalLength += characterInfo.advance;
}
 其中text为Text⽂本控件,RequestCharactersInTexture主要相当于指定需要渲染哪些字符(然后根据CharacterInfo.characterInfo是可以拿到本次⽣成的去重后的字符集)。接下来通过myFont.GetCharacterInfo(c, out characterInfo, text.fontSize);分别去获得每个字符的信息,然
后characterInfo.advance就拿到了每个字符的渲染长度。
 拿到每个字符长度之后那就简单多了,计算⼀下需要截断的字符总长度,如果⼤于限制长度,就除去后缀长度后,截取⼦字符串,然后再接上后缀。这个事情就搞定了。
效果如下:
全部如下,这个例⼦是需要⼀个text和⼀个button,点击button,随机⽣成⽂字在text上。
using UnityEngine;
using System.Collections;
using UnityEngine.UI;
public class TextWidth : MonoBehaviour {
public Text text;
public Button button;
const string suffix = "...";
const int MAX_WIDTH = 200;
int suffixWidth = 0;
string[] seeds = { "是都", "60°", "qの", "【】" , "d a", "as", "WW", "II", "fs", "as", "WW", "II", "fs" };
/
/ Use this for initialization
void Start () {
Init();
}
void Init()
{
//计算后缀的长度
suffixWidth = CalculateLengthOfText(suffix);
Debug.Log("suffixWidth : " + suffixWidth);
}
string StripLengthWithSuffix(string input, int maxWidth = MAX_WIDTH)
{
int len = CalculateLengthOfText(input);
Debug.Log("input total length = " + len);
//截断text的长度,如果总长度⼤于限制的最⼤长度,
//那么先根据最⼤长度减去后缀长度的值拿到字符串,在拼接上后缀
if (len > maxWidth)
红外多点触摸屏{
return StripLength(input, maxWidth - suffixWidth) + suffix;
}else
{
return input;
}
}
//随机⽣成个字符串
void Rand()
{
int min = 12;
int max = 16;
int num = (int)(Random.value * (max - min) + min);
Debug.Log("-------------------------\n num : " + num);
string s = "";
for (int j = 0; j < num; j++)
{
int len = seeds.Length;
int index = (int)(Random.value * (len));
s += seeds[index];
}
Debug.Log("s : " + s);
< = StripLengthWithSuffix(s);
Debug.Log("StripLength " + );
}
/// <summary>
/
// 根据maxWidth来截断input拿到⼦字符串
/// </summary>
/// <param name="input"></param>
/// <param name="maxWidth"></param>
/// <returns></returns>
string StripLength(string input, int maxWidth = MAX_WIDTH)
{
int totalLength = 0;
Font myFont = text.font;  //chatText is my Text component
myFont.RequestCharactersInTexture(input, text.fontSize, text.fontStyle);
CharacterInfo characterInfo = new CharacterInfo();
char[] arr = input.ToCharArray();
int i = 0;
foreach (char c in arr)
{
myFont.GetCharacterInfo(c, out characterInfo, text.fontSize);
int newLength = totalLength + characterInfo.advance;
if (newLength > maxWidth)
{
Debug.LogFormat("newLength {0},  totalLength {1}: ", newLength, totalLength);
if (Mathf.Abs(newLength - maxWidth) > Mathf.Abs(maxWidth - totalLength)){
break;
}else
{
totalLength = newLength;
i++;
break;
}
}
totalLength += characterInfo.advance;
i++;
}
Debug.LogFormat("totalLength {0} : ", totalLength);
return input.Substring(0, i);
}
/// <summary>
/// 计算字符串在指定text控件中的长度
/// </summary>
/// <param name="message"></param>
/// <returns></returns>
int CalculateLengthOfText(string message)
{
自动弹簧机
int totalLength = 0;
Font myFont = text.font;  //chatText is my Text component
myFont.RequestCharactersInTexture(message, text.fontSize, text.fontStyle);
流化床CharacterInfo characterInfo = new CharacterInfo();
char[] arr = message.ToCharArray();
foreach (char c in arr)
{
myFont.GetCharacterInfo(c, out characterInfo, text.fontSize);
totalLength += characterInfo.advance;
}
pe打包带return totalLength;
}
}
后续
这个效果基本达到要求,如果仔细看的话,并不能保证每个截取后的字符串⼀定是对齐的,这个也跟字符串有关,毕竟字符串长度是离散的,貌似没有办法像word⼀样在⼀⾏多⼀个⽂字的时候还可以挤⼀挤放下~

本文发布于:2024-09-21 10:43:23,感谢您对本站的认可!

本文链接:https://www.17tex.com/tex/2/344143.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:长度   后缀   字符   字符串   截断   貌似
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议