Phaser3 ES6+ 入門教程(3)——輸入系統(tǒng)(2)

前面一小節(jié),我們講了鍵盤輸入俊戳,這里補充一下關(guān)于鼠標的揖赴。
鍵盤事件是通過Phaser.Scene.input.keyboard.on()方法添加事件監(jiān)聽器的,但是鼠標事件和部分其它事件抑胎,則是通過Phaser.Scene.input.on()方法來添加事件監(jiān)聽器的燥滑。
在鼠標事件中,雖然本教程中稱為鼠標事件阿逃,但是具體指的是點擊事件铭拧,在PC端就是使用鼠標點擊,在移動端就是用手指點擊盆昙。因此,在Phaser中焊虏,該事件不稱為mouse淡喜,而是pointer。例如pointerdown就是按下鼠標的事件诵闭。

局部事件

通過Phaser.Scene.input來添加的事件都是全局事件炼团,也就是說無論點擊哪一個GameObject或者點外面,都會觸發(fā)該事件疏尿。而局部事件是指只有操作特定GameObject才會觸發(fā)的事件瘟芝。
每一個GameObject對象,都有setInteractive()方法褥琐,局部輸入默認不啟用锌俱,該方法用于啟用局部輸入系統(tǒng),它可以傳入一個配置參數(shù)敌呈,也可以不傳入贸宏。
每一個GameObject都有on()方法和once()方法造寝,用于添加局部事件監(jiān)聽器,它們有三個參數(shù)吭练,第一個參數(shù)是事件诫龙,如果是點擊事件,那么第二鲫咽、三個參數(shù)是點擊位置的坐標签赃。
在輸入系統(tǒng)中,on()方法是指添加每次事件發(fā)生時都會運行的函數(shù)分尸,而once()方法中傳入的函數(shù)只會在事件第一次被觸發(fā)時運行锦聊。

切換場景

可以通過Phaser.Scene.scene.start()方法切換場景。
一個例子

class S1 extends Phaser.Scene{
  constructor(){
    super({active:true});
  }
  create(){
    this.add.text(0,0,"The First Scene");
    this.input.on("pointerdown",(e)=>this.scene.start("S2"));
 }
}
class S2 extends Phaser.Scene{
  constructor(){
    super();
  }
  create(){
    this.add.text(0,0,"The Second Scene");
  }
}
class Game extends Phaser.Game{
  constructor(){
super({type:Phaser.AUTO,width:window.innerWidth,height:window.innerHeight,physics:{default:"arcade"}});
        let s1=new S1();
        let s2=new S2();
        this.scene.add("S1",s1);
        this.scene.add("S2",s2);
  }
}

運行上述代碼后寓落,顯示所有激活的場景(這里需要對前面的文章指正一下括丁,默認是運行所有激活的場景,而不是第一個被添加的場景伶选,因此史飞,這里S2類的構(gòu)造方法中,在調(diào)用基類構(gòu)造方法時沒有傳入?yún)?shù)仰税,那么默認該場景是沒有激活的)构资。在S1類的輸入處理中,我們調(diào)用了start()方法激活一個場景陨簇,因此點擊S1場景中的任意一處吐绵,就會切換到S2場景了。
start()方法中河绽,第一個參數(shù)為場景的鍵己单。該方法會禁用當(dāng)前場景,然后激活新場景耙饰。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末纹笼,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子苟跪,更是在濱河造成了極大的恐慌廷痘,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件件已,死亡現(xiàn)場離奇詭異笋额,居然都是意外死亡,警方通過查閱死者的電腦和手機篷扩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進店門兄猩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事厦滤≡遥” “怎么了?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵掏导,是天一觀的道長享怀。 經(jīng)常有香客問我,道長趟咆,這世上最難降的妖魔是什么添瓷? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮值纱,結(jié)果婚禮上鳞贷,老公的妹妹穿的比我還像新娘。我一直安慰自己虐唠,他們只是感情好搀愧,可當(dāng)我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著疆偿,像睡著了一般咱筛。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上杆故,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天迅箩,我揣著相機與錄音,去河邊找鬼处铛。 笑死饲趋,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的撤蟆。 我是一名探鬼主播奕塑,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼家肯!你這毒婦竟也來了龄砰?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤息楔,失蹤者是張志新(化名)和其女友劉穎寝贡,沒想到半個月后扒披,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體值依,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年碟案,在試婚紗的時候發(fā)現(xiàn)自己被綠了愿险。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖辆亏,靈堂內(nèi)的尸體忽然破棺而出风秤,到底是詐尸還是另有隱情,我是刑警寧澤扮叨,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布缤弦,位于F島的核電站,受9級特大地震影響彻磁,放射性物質(zhì)發(fā)生泄漏碍沐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一衷蜓、第九天 我趴在偏房一處隱蔽的房頂上張望累提。 院中可真熱鬧,春花似錦磁浇、人聲如沸斋陪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽无虚。三九已至,卻和暖如春交洗,著一層夾襖步出監(jiān)牢的瞬間骑科,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工构拳, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留咆爽,地道東北人。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓置森,卻偏偏與公主長得像斗埂,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子凫海,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,033評論 2 355

推薦閱讀更多精彩內(nèi)容