一起來玩鳥 Starling Framework(3)Button!
週末夜來介紹個簡單的DisplayObject就好。不論是在電腦上或行動裝置上,跟使用者互動次數最多的,大概就是按鈕了。因此,Starling有個Button類別,來做出這個常用的互動元件。
同樣是因為由Sparrow移植過來的影響,Button的行為完全是行動裝置上的按鈕。它只有一個一般狀態的Texture,按鈕上的文字,以及壓下狀態的Texture(也可以不要)。事件只有一個:Event.TRIGGERED。沒有mouse over的狀態,也沒有useHandCursor可用。
Document Class依然不需要更動,再新增一個Game3.as當做Starling的rootClass,程式碼如下
publicclassGame3extendsSprite
{
privatevar _container:Sprite;
privatevar _msgText:TextField;
[Embed(source ="/assets/btnBg.png")]
privatestaticconstBtnBitmap:Class;//embed一張圖片當做Button平常的狀態
[Embed(source ="/assets/btnDownBg.png")]
privatestaticconstBtnDownBitmap:Class;//embed一張圖片當做Button壓下的狀態
publicfunctionGame3()
{
super();
addEventListener(Event.ADDED_TO_STAGE, init);
}
privatefunction init(e:Event):void
{
removeEventListener(Event.ADDED_TO_STAGE, init);
_container =newSprite();
addChild(_container);
addChild(newStats());
var menu:Sprite=newSprite();//新增一個Sprite當做所有Button的容器
menu.x =100;//設定menu座標
menu.y =30;//設定menu座標
_container.addChild(menu);//menu加到場景上
_msgText =newTextField(300,20,"No Button Triggered.","Arial",14,0xFF0000,true);//新增一個TextField來顯示Button的狀態
_msgText.x =100;//設定_msgText座標
_msgText.y =80;//設定_msgText座標
_msgText.hAlign =HAlign.LEFT;//設定_msgText文字靠左對齊
_container.addChild(_msgText);//將_msgText加到場景上
var btnTexture:Texture=Texture.fromBitmap(newBtnBitmap());//從embed圖片產生button平常狀態的Texture
var btnDownTexture:Texture=Texture.fromBitmap(newBtnDownBitmap());//從embed圖片產生button壓下狀態的Texture
var btnTexts:Vector.<String>=newVector.<String>();//用一個Vector先將Button的文字存放起來
btnTexts.push("About");//加入第一個Button文字
btnTexts.push("Works");//加入第二個Button文字
btnTexts.push("Video");//加入第三個Button文字
btnTexts.push("Contact");//加入第四個Button文字
var btnNum:uint= btnTexts.length;//Button個數
var button:Button;//button用來當參照
for(var i:int=0; i < btnNum; i++)//用個迴圈設定四個button
{
button =newButton(btnTexture, btnTexts[i], btnDownTexture);//新增一個Button
button.x = i *150;//設定button座標
button.name ="btn"+ btnTexts[i];//設定button的name
button.alphaWhenDisabled =0.5;//如果button disable時alpha會自動變成0.5
menu.addChild(button);將button加到場景上
}
button.enabled =false;//寫在迴圈外,我們故意將最後一個button disable
menu.addEventListener(Event.TRIGGERED, buttonTriggered);//Event.TRIGGERED會bubble,所以只要對menu監聽就好
}
privatefunction buttonTriggered(e:Event):void
{
_msgText.text =Button(e.target).name +" triggered!";//顯示哪個Button被triggered
}
}
首先embed兩張圖分別當做Button的up state與down state時的Texture。然後先用一個Sprite menu當做容器,再將四個Button建立起來,放到這個容器裡面我們另外在場景上加了一個TextField用來顯示等等哪個Button被triggered的訊息。。Button有很多跟font有關的屬性可以設定文字的字型、字級、粗體等等來設定文字的樣式,如果配合BitmapFont就可以做出更多樣性的Button。關於BitmapFont之後再聊。加完四個Button後,我們故意將最後一個Button的enabled屬性設為false,用來觀察alphaWhenDisabled這個屬性的效果。這是當Button disable時,Button自動會改變自己的alpha值,直到恢復enable時,alpha會自動回到1。最後我們對加上menu加上Event.TRIGGERED監聽,因為這個事件預設是會bubble的,所以對外面的容器監聽就好。而事件發生時就會告訴我們哪個Button被triggered了。Event.TRIGGERED的發生跟MouseEvent.CLICK一樣,要在Button被按下,又在Button裡面放開時才會觸發。Demo如下:

一起來玩鳥 Starling Framework(3)Button!的更多相关文章
- 一起來玩鳥 Starling Framework 簡介
開場 Starling Framework是一套Flash 2D遊戲開發"工具",是使用Flash最新的Stage3D API建構出來的一套Framework.最大優點在於使用GP ...
- 一起來玩鳥 Starling Framework(5)Multi-Touch
這篇來談談Starling的Multi-Touch.前一篇也提到,Multi-Touch一樣是監聽TouchEvent.TOUCH,然後由TouchEvent的e.getTouches()取回多點的資 ...
- 一起來玩鳥 Starling Framework(2)效能測試以及Image與Texture
上一篇我們放了一個Quad與TextField在舞台上慢慢轉.眼尖的可能會發現轉起來邊緣有點鋸齒,這可以透過設定Starling的反鋸齒來解決,在Main.as裡,新增了_starling之後,可以加 ...
- 一起來玩鳥 Starling Framework(1)一定要的Hello World!
雖然已經一堆Hello World的介紹文章跟影片了,但中文資料畢竟是比較少,所以不能免俗的來一篇中文版Hello World.首先開啟一個AS3.0專案,fps不用客氣,設為60,Starling很 ...
- 一起來玩鳥 Starling Framework(6)Juggler、Tween、以及DelayCall
這篇開始來講Starling裡的Animation.Juggle是個簡單的Class,用來控制動畫的進行.他負責管理經由add()加進來的實現IAnimatable介面的物件,然後當Juggler的a ...
- 一起來玩鳥 Starling Framework(7)MovieClip
承上一篇,我們接著來講最後一個IAnimatable類別,MovieClip.Starling的MovieClip跟native的MovieClip不太一樣,它只能接收一個Vector.<Tex ...
- 一起來玩鳥 Starling Framework(4)TouchEvent,Touch,以及TouchPhase
這一篇來介紹一下TouchEvent.我們先來談單點的touch,下一篇再介紹MultiTouch.翻過Starling文件的應該會發現,Starling裡面沒有MouseEvent,而是整合在Tou ...
- 一起來玩鳥 Starling Framework(9)Particle
最後,來看看Starling裡一個很炫的功能:Particle.Particle屬於extension,所以要另外下載檔案:Starling-Extension-Particle-System.下載之 ...
- 一起來玩鳥 Starling Framework(8)BitmapFont
所謂BitmapFont,就是事先將我們會用到的字型,會用到的字,輸出成一張圖片,類似Sprite sheet,以及一個xml格式的Data file,然後我們一次將這文字圖片轉成Texture,up ...
随机推荐
- [转]Native进程的运行过程
Native进程的运行过程 一般程序的启动步骤,可以用下图描述.程序由内核加载分析,使用linker链接需要的共享库,然后从c运行库的入口开始执行. 通常,native进程是由shell或者init启 ...
- 定制一个支持中英文的简单LaTex模板
平常写汇报文档什么的,word排版有时还是比较费劲,遂定制一个简单的LaTex模板,中文默认为宋体,英文为LaTex默认字体,支持彩色高亮展示,有目录书签,有页眉展示,大致如下: LaTex代码如下: ...
- 关于因各种原因,造成LINUX主机不能通过域名访问自己的解决办法
因路由黑洞或其它原因造成自己域名或外网IP的解决办法: vi /etc/hosts 添加一行: 10.28.86.250 www.edusoa.com 保存退出.
- Gitlab,这也就O了???
最简单配置也是一句话搞了... rpm -i gitlab-ce--ce..el7.x86_64.rpm vim /etc/gitlab/gitlab.rb gitlab-ctl reconfigur ...
- Android 网络url设置View背景图
imgstr为url网络图片地址,topllay是要设置背景的控件: 方法1.Android Glide设置View背景图 Glide.with(this).load(imgStr).asBitmap ...
- yii2框架获取刚插入数据库的id (原创)
$insert_id = $UserModel->attributes['id'];
- 使用 gulp 压缩图片
请务必理解如下章节后阅读此章节: 安装 Node 和 gulp 使用 gulp 压缩 JS 压缩 图片文件可降低文件大小,提高图片加载速度. 找到规律转换为 gulp 代码 规律 找到 images/ ...
- 【转】如何只用CSS做到完全居中
英文原版链接:http://codepen.io/shshaw/full/gEiDt 我们都知道 margin:0 auto; 的样式能让元素水平居中,而 margin: auto; 却不能做到垂直居 ...
- 设置iSCSI的发起程序(客户端)(三)
iSCSI 发起程序是一种用于同 iSCSI 目标器认证并访问服务器上共享的LUN的客户端.我们可以在本地挂载的硬盘上部署任何操作系统,只需要安装一个包来与目标器验证. 初始器客户端设置 功能 可以处 ...
- 微信商户现金红包api php
微信开发文档: 现金红包:https://pay.weixin.qq.com/wiki/doc/api/tools/cash_coupon.php?chapter=13_5 裂变红包:https:// ...