AutoSizing Flex Mobile spark textarea组件

时间:2012-05-16 12:14:27

标签: flex flex4 flex4.5 flex-mobile

我想让我的 移动spark textarea 组件包装所有内容。我发现了mx_internal做这个的方法,但是我无法调用 mx_internal :: getTextField()。numLines 方法 - 没有这样的......以前有人这样做了吗?

2 个答案:

答案 0 :(得分:3)

以下是移动解决方案:

for(var i:int=0; i < StyleableTextField(txt_genel.textDisplay).numLines; i++) {
        ta_height += StyleableTextField(txt_genel.textDisplay).getLineMetrics(i).height;
}
txt_genel.height = ta_height;

答案 1 :(得分:0)

这里有一个带有少量自定义TextArea类的解决方案,还有一些注释可以解释一下。

package
{   
    import mx.events.FlexEvent;

import spark.components.TextArea;
import spark.components.supportClasses.StyleableStageText;
import spark.events.TextOperationEvent;

public class CustomTextArea extends TextArea
{

    private var _lineNumber:int = 1;
    private var _padding:int;
    private var _minHeight:int;

    public function CustomTextArea()
    {
        super();

        addEventListener(FlexEvent.CREATION_COMPLETE, function setBehaviour(event:FlexEvent):void
        {
            //minHeight to prevent textarea to be too small
            _minHeight = height;
            //padding between textarea and text component inside to calculate line number
            _padding = ((textDisplay as StyleableStageText).x - x) + (width - (textDisplay as StyleableStageText).width);
            //listener for text changing
            addEventListener(TextOperationEvent.CHANGE, setHeight);
        });
    }

    private function setHeight(event:TextOperationEvent):void
    {
        //line number is textwidth divided by component width
        _lineNumber = (((textDisplay as StyleableStageText).measureText(text).width + _lineNumber * _padding) / width) + 1;
        //text height is line number * text height
        var newHeight:int = _lineNumber * (textDisplay as StyleableStageText).measureText(text).height;
        //if new height > min height, set height
        if (newHeight > _minHeight)
            height = newHeight;
    }
}
}

希望这会有所帮助。

编辑:由于行数很多,TextArea的高度上升太多了。应该管理。