zoukankan      html  css  js  c++  java
  • 用Flex模拟智能手机表单输入的自动放大功能

    用iphone或itouch登录过微薄的同学们想必都会发现:登录一些手机版网站(比如微薄时),表单中的输入框会自动放大,以方便用户输入,等输入完成后,页面会再次缩小到正常状态。
    在flex开发过程中,有时也会遇到一些输入项很多的表单,可以借鉴iphone上的这种体验,基本思路就是:将整个容器放大,以适应屏幕,然后将获得焦点的文本框定位到屏幕中央。
    下面是演示:
    当UserName与PassWord文本框获得焦点时,表单(其实就是panel)会自动放大,并重新定位,最终将获得焦点的文本框定位在屏幕中央,以方便输入。点击checkbox或login按钮时,会恢复正常大小。
    主要代码:
    <?xml version="1.0" encoding="utf-8"?>
    <s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
    			   xmlns:s="library://ns.adobe.com/flex/spark" 
    			   xmlns:mx="library://ns.adobe.com/flex/mx" applicationComplete="windowedapplication1_applicationCompleteHandler(event)" width="640" height="480" >
    	<fx:Script>
    		<![CDATA[
    			import gs.TweenLite;			
    			import mx.events.FlexEvent;						
    			
    			private var SW:Number;//舞台的宽度
    			private var SH:Number;//舞台的高度
    			private var WH:Number;//panel的高度
    			private var WW:Number;//panel的宽度
    			
    			protected function windowedapplication1_applicationCompleteHandler(event:FlexEvent):void
    			{				
    				SW = stage.stageWidth;
    				SH = stage.stageHeight;
    				WW = loginWin.width;
    				WH = loginWin.height;				
    				initPosAnsScale();				
    			}			
    			
    			private function initPosAnsScale():void
    			{				
    				TweenLite.to(loginWin,0.2,{x:0.5*(SW - WW),y:0.5*(SH - WH),scaleX:1,scaleY:1});
    			}
    			
    			protected override function focusInHandler(e:FocusEvent):void
    			{					
    				var radioX:Number = SW/WW;
    				var radioY:Number = SH/WH;				
    				var radio:Number = Math.min(radioX,radioY);						
    				//注:e.target得到的对象类似于:
    				//HelloWorld0.WindowedApplicationSkin2.Group3.contentGroup.loginWin.
    				//PanelSkin8._PanelSkin_Group1.contents.contentGroup.
    				//txtName.TextInputSkin21.textDisplay
    				trace(e.target);
    				//所以这里要连用3次parent才能得到正确的文件框(txtName)对象
    				var current:DisplayObject = e.target.parent.parent as DisplayObject;
    				
    				//当前焦点对应文本框在舞台上的实际位置
    				var _nX:Number = current.x * radio + loginWin.x;
    				var _nY:Number = current.y * radio + loginWin.y + loginWin.titleDisplay.height*radio;				
    				
    				//当前焦点对应的文本框中心点的实际位置
    				var _cX:Number = _nX + 0.5*e.target.width*radio;
    				var _cY:Number = _nY + 0.5*e.target.height*radio;
    				
    				//计算要移动的距离
    				var _dx:Number = _cX - 0.5*SW;
    				var _dy:Number = _cY - 0.5*SH;
    				
    				//缩放+移动
    				var desX:Number = loginWin.x - _dx;
    				var desY:Number = loginWin.y - _dy;
    				TweenLite.to(loginWin,0.2,{scaleX:radio,scaleY:radio,x:desX,y:desY});
    				
    			}
    			
    			protected override function focusOutHandler(e:FocusEvent):void
    			{
    				initPosAnsScale();				
    			}
    			
    		]]>
    	</fx:Script>
    	<fx:Declarations>
    		<!-- Place non-visual elements (e.g., services, value objects) here -->
    	</fx:Declarations>
    	<s:Panel title="Please Login" id="loginWin" dropShadowVisible="false" width="330" x="139" height="219" y="94">
    		<s:layout>
    			<s:BasicLayout/>
    		</s:layout>
    		<s:Label x="129" y="10" text="UserName"/>
    		<s:TextInput x="96" y="30" id="txtName" focusIn="focusInHandler(event)" focusOut="focusOutHandler(event)"/>
    		<s:Label x="131.5" y="65" text="Password"/>
    		<s:TextInput x="96" y="85" id="txtPwd" displayAsPassword="true" focusIn="focusInHandler(event)" focusOut="focusOutHandler(event)"/>
    		<s:Button x="125" y="148" label="login"/>
    		<s:CheckBox x="113" y="118" label="Remember me" click="focusOutHandler(null)"/>
    	</s:Panel>
    </s:Application>
    
    作者:菩提树下的杨过
    出处:http://yjmyzz.cnblogs.com
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    第六周上机任务
    java第四次作业
    第二次上机练习
    第三周作业
    第一次上机作业
    计算机1802刘思源
    第五次上机作业
    第六周作业
    第四次上机作业
    第三次上机作业
  • 原文地址:https://www.cnblogs.com/yjmyzz/p/2007196.html
Copyright © 2011-2022 走看看