繁体   English   中英

在ActionScript和Flex中计算文本宽度

[英]Calculating Text Width In ActionScript And Flex

我正在尝试根据它将包含的文本来计算WIDE如何制作我的按钮,当我尝试谷歌如何计算像某些文本的宽度一样简单的东西时,我只是试着去试图通过明显无意义的深奥反直觉伏都教。 那里的任何人都可以帮我简化我如何编写这样的函数:

public function HowWideWouldThisTextBeIfItWereInThisButton(Text:String,Container:Button):int {
 ...
}

提前致谢。

只要您在UIComponent中,就可以使用measureText函数。

public function howWideWouldThisTextBeIfItWereInThisButton(text:String,container:Button):int {
   var lineMetrics:TextLineMetrics = container.measureText(text);
   return lineMetrics.width;      
}

话虽这么说,如果你没有设置宽度,flex按钮组件应自动调整大小到文本的宽度。 这样,如果你需要文本宽度,你可以调用textWidth属性。

这适用于任何格式,大小,字体类型。 不要忘记属性“autoSize”和“wordWrap”!

var tf:TextField = new TextField();
addChild(tf);
tf.autoSize = TextFieldAutoSize.LEFT;
tf.wordWrap = false;
tf.text = "Whatever here";
tf.width = tf.textWidth + 4; // add 2 pixels-gutters left & right

你的按钮需要“tf.width”宽...

以下是你在Spark中的表现:

我修改了 - 简化 - 他的例子在这里:

var textMetrics:TextLineMetrics = label.measureText( label.text );  
var textWidth:int = textMetrics.width; 

这是一种有效的方式:

var tempText:Text = new Text();
tempText.regenerateStyleCache(false);
var textWidth:int = tempText.measureText(*yourstring*).width;

我认为textField.textWidth构造工作正常......直到你改变字体大小。 它似乎根据12px字体计算宽度。 因此,如果您有嵌入字体和全局样式,您可以尝试快速解决方案:

var realWidth = myLabel.textField.textWidth * (fontSize / 12);

我在长短串上试过这个,结果是正确的。

约书亚,清楚真的很有帮助。 你在说TextField,MX Label,Spark Label,RichText等吗? 不同的文本组件使用不同的文本引擎,例如FTE和TLF,并且可能具有不同的解决方案。 我当然希望Adobe有一套很好的实用程序或示例代码,可以在实际执行之前预测渲染到控件上的字体大小。 但是,好消息是,在某些情况下 - 比如,一个好的老式TextField,你可以很好地预测这一点。 您只需创建一个TextField,设置它的textFormat字段,自动大小方法和文本。 在将其添加到任何地方之前,您应该能够获得它的大小。 我不记得订单是什么,但是,我记得你设置这些属性的顺序很重要。 如果你无法弄清楚如何做,我可以提供一个代码示例。 现在,对于新的,“改进的”组件,如Spark标签 - 如果我能找到一个该死的方式,我会被惹恼......花了好几个小时就没有办法......或者是某个人知道一种方式:P。

继续quoo的回答的评论 ,这里是用于相同目的的代码,但只是使用TextLineMetrics抓取TextField的宽度:

    public function mtxtWidth(container:TextField):int {
       var lineMetrics:TextLineMetrics = container.getLineMetrics(0);
       return lineMetrics.width;      
    }

听起来你可以使用textWidth

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM