TextField 小结

对于textfield中文本设置不同字体:

textfield可以对选中文本设置字体, 当一段文本有两种文本格式(即textformat)时, 可以获取光标所在位置前一个字符的textformat, 这样就可以取到不同样式文本的不同textformat, 而不影响其整体.但当修改整体文本格式时, 原有被修改的文本格式将丢失, 使用新定义的整体文本格式.

注:此处附带一小例子, 见本文最下方附件例一!

-------------------------------------------------------------------

对于textfield中文字设置两种颜色, 布局后变成一种颜色的修改:

new一个textformat赋值给当前textfield, textformat属性可以叠加, 而不要修改原有textformat的align属性.(同理可应用于其他属性)

-------------------------------------------------------------------

访问剪贴板:

 

System.setClipboard("文本内容");//将文本内容放入剪贴板
Clipboard.generalClipboard.setData(ClipboardFormats.TEXT_FORMAT, "文本内容");//将文本内容放入剪贴板
var t:String = Clipboard.generalClipboard.getData(ClipboardFormats.TEXT_FORMAT) as String;//读取剪贴板中内容

    注: 此处访问剪贴板需用户执行操作, 可以是按钮点击或键盘操作

 

-----------------------------------------------------------------
获取计算机安装字体:

 

var arr:Array = Font.enumerateFonts(true); 
arr.sortOn("fontName", Array.CASEINSENSITIVE);

 

------------------------------------------------------------------

TextField文本对齐:

1. 使用TextFormat的align属性

    textFormat.align = TextFormatAlign.CENTER;

    但是这个属性在myEclipse中给出的提示是指定的 align 不是 flash.text.TextFormatAlign 的成员, 用上面的方法没有效果. 

    所以就直接写 textFormat.align = "center"; 这样就好用了. 

2. 使用TextField的autoSize属性

    textField.autoSize = TextFieldAutoSize.RIGHT;

    但是这个属性在myEclipse中给出的提示是指定的 autoSize 不是 flash.text.TextFieldAutoSize 的成员, 用这个的方法也没有效果. 

    有人说是因为设置了TextField的wordWrap属性, 对autoSize产生了影响, 可是去掉了TextField属性, 也没有效果. (API没解释)

    注:textformat的align可实现两端对齐两端对齐, textfield的autoSize不能

---------------------------------------------------------------

TextField控制可编辑:

 

txttalk.type=TextFieldType.DYNAMIC;//不可编辑
txttalk.type=TextFieldType.INPUT;//可编辑

 

--------------------------------------------------------------

TextField 设置可输入中文:

先获取焦点, 再修改IME:

 

input.addEventListener(FocusEvent.FOCUS_IN, focusInHandler);
function focusInHandler(e:FocusEvent):void
{
    IME.enabled = true;
}

 

--------------------------------------------------------------

textfield添加项目符号:

textformat.bullet = true;

---------------------------------------------------------------

textfield替换文本的方式:

textfield.text  ---> String

textfield.htmlText  ---> HTML格式文本

textfield.replaceSelectedText(String)  ---> 可用textfield.setSelection(beginIndex, endIndex)方法设置选中位置

textfield.replaceText(beginIndex, endIndex, String)

---------------------------------------------------------------

TextField 对文字编辑的监听:

这个事件可监听文字的增删改, 均可触发:

 

textField.addEventListener(Event.CHANGE, textChangeHandler);

网上好多都说用这个事件, 但是我加上之后, 这个事件只能监听文本添加, 对于删除不触发监听, 有待学习.

textField.addEventListener(TextEvent.TEXT_INPUT, textInputHandler);

 

  查看了TextArea的源码, 发现里面有个这个, 但是放到我的代码里没好用, 没找到原因为何, 在此先做记录.

 [Bindable("textChanged")]
    
    // Compiler will strip leading and trailing whitespace from text string.
    [CollapseWhiteSpace]
       
    /**
     *  @private
     */
    override public function set text(value:String):void
    {
        // Of 'text', 'textFlow', and 'content', the last one set wins.
        
        super.text = value;
        
        // Trigger bindings to textChanged.
        dispatchEvent(new Event("textChanged"));        
    }

 

附件附件附件附件附件附件附件:

例一:

<?xml version="1.0" encoding="utf-8"?>
<s:WindowedApplication xmlns:fx="http://ns.adobe.com/mxml/2009" 
					   xmlns:s="library://ns.adobe.com/flex/spark" 
					   xmlns:mx="library://ns.adobe.com/flex/mx">
	<s:layout>
		<s:VerticalLayout/>
	</s:layout>

	<fx:Script>
		<![CDATA[
			import mx.controls.Alert;
			import mx.core.UIComponent;
			
			private var tf:TextField = new TextField();
			
			protected function button1_clickHandler(event:MouseEvent):void
			{
				tf.x = tf.y = 100;
				tf.width = 400;
				tf.height = 300;
				tf.border = true;
				tf.borderColor = 0x0000ff;
				tf.text = "好好学习 天天向上";
				tf.type = TextFieldType.INPUT;
				
				var tfor1:TextFormat = new TextFormat();
				tfor1.color = 0x00ffff;
				tfor1.size = 20;
				tfor1.font = "STCaiyun";//华文彩云
				tf.setTextFormat(tfor1, 0, 5);
				
				var tfor2:TextFormat = new TextFormat();
				tfor2.color = 0xff00ff;
				tfor2.size = 20;
				tfor2.font = "STXingkai";//华文行楷
				tf.setTextFormat(tfor2, 5, tf.length);
				
				tf.addEventListener(MouseEvent.CLICK, textClickHandler);
				
				var u:UIComponent = new UIComponent();
				u.addChild(tf);
				bc.addElement(u);
			}
			
			private function textClickHandler(e:MouseEvent):void
			{
				var t:TextFormat = null;
				if(tf.selectionBeginIndex == 0)
				{
					t = tf.getTextFormat(tf.selectionBeginIndex, tf.selectionBeginIndex + 1);
				}
				else
				{
					t = tf.getTextFormat(tf.selectionBeginIndex - 1, tf.selectionBeginIndex);
				}
				Alert.show(t.font);
			}
		]]>
	</fx:Script>

	<fx:Declarations>
		<!-- 将非可视元素(例如服务、值对象)放在此处 -->
	</fx:Declarations>
	<s:Button label="ClickMe" click="button1_clickHandler(event)"/>
	<s:BorderContainer id="bc" width="100%" height="100%"/>
</s:WindowedApplication>


 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值