Starling Feathers Controls ScreenNavigator

本文介绍ScreenNavigator类在应用中显示屏幕或菜单的强大系统,并演示如何通过事件导航在不同屏幕间切换。提供了MenuScreen和OptionsScreen两个示例代码,展示如何创建按钮触发事件,实现界面间的跳转。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

说明:

The ScreenNavigator class offers a powerful system for displaying screens or menus in your application and navigating between them. It supports navigation based on events (or as3-signals, if you prefer), and it can inject properties into screens as they are shown.


示例:

var navigator:ScreenNavigator = new ScreenNavigator();
			navigator.addScreen( "start", new ScreenNavigatorItem( MenuScreen) );
			navigator.addScreen( "options", new ScreenNavigatorItem( OptionsScreen) );
			this.addChild( navigator );
			
			navigator.showScreen( "start" );
			navigator.addEventListener("showOptions",showOptions);
			function showOptions(e:Event):void{
				navigator.showScreen("options");
			}

MenuScreen代码:

package lft.fctest
{
	import feathers.controls.Button;
	import feathers.controls.Screen;
	
	import starling.events.Event;
	
	/**
	 * Author:大飞狼
	 * <br>Date: 2014-9-12 下午3:30:30
	 * <br>Synopsis:
	 */
	public class MenuScreen extends Screen
	{
		public function MenuScreen()
		{
			super();
		}
		override protected function initialize():void{
			var button:Button=new Button();
			button.label="点击切换到options";
			addChild(button);
			button.addEventListener(Event.TRIGGERED,buttonTriggered);
		}
		
		private function buttonTriggered(e:Event):void
		{
			dispatchEventWith("showOptions",true);
		}
	}
}

OptionsScreen代码

package lft.fctest
{
	import feathers.controls.PanelScreen;
	
	/**
	 * Author:大飞狼
	 * <br>Date: 2014-9-11 下午3:53:42
	 * <br>Synopsis:
	 */
	public class OptionsScreen extends PanelScreen
	{
		public function OptionsScreen()
		{
			super();
	
		}
		override protected function initialize():void
		{
			super.initialize();
			this.headerProperties.title = "Options";
		}
	}
}


效果:



更多说明参考:

http://wiki.starling-framework.org/feathers/screen-navigator

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值