人人客戶端有一個(gè)特效還是挺吸引人的,在主界面手指向右滑動(dòng),就可以將菜單展示出來,而主界面會(huì)被隱藏大部分,但是仍有左側(cè)的一小部分同菜單一起展示。 據(jù)說人人客戶端的這個(gè)特效是從facebook客戶端模仿來的,至于facebook是不是又從其它地方模仿來的就不得而知了。好,今天我們就一起來實(shí)現(xiàn)這個(gè)效果,總之我第一次看到這個(gè)特效是在人人客戶端看到的,我也就主觀性地認(rèn)為我是在模仿人人客戶端的特效了。 雖然現(xiàn)在網(wǎng)上類似這種效果的實(shí)現(xiàn)也非常多,可是我發(fā)現(xiàn)實(shí)現(xiàn)方案大都非常復(fù)雜,并不容易理解。但其實(shí)這種效果并不難實(shí)現(xiàn),因此我今天給大家?guī)淼囊彩鞘飞献詈?jiǎn)單的滑動(dòng)菜單實(shí)現(xiàn)方案。 首先還是講一下實(shí)現(xiàn)原理。在一個(gè)Activity的布局中需要有兩部分,一個(gè)是菜單(menu)的布局,一個(gè)是內(nèi)容(content)的布局。兩個(gè)布局橫向排列,菜單布局在左,內(nèi)容布局在右。初始化的時(shí)候?qū)⒉藛尾季窒蜃笃?,以至于能夠完全隱藏,這樣內(nèi)容布局就會(huì)完全顯示在Activity中。然后通過監(jiān)聽手指滑動(dòng)事件,來改變菜單布局的左偏移距離,從而控制菜單布局的顯示和隱藏。原理圖如下: 將菜單布局的左偏移值改成0時(shí),效果圖如下: 好,我們開始用代碼來實(shí)現(xiàn)。首先在Eclipse中新建一個(gè)Android項(xiàng)目,項(xiàng)目名就叫做RenRenSlideMenuDemo。然后寫一下布局文件,創(chuàng)建或打開layout目錄下的activity_main.xml文件,加入如下代碼:
這個(gè)布局文件的最外層布局是一個(gè)LinearLayout,排列方向是水平方向排列。這個(gè)LinearLayout下面嵌套了兩個(gè)子LinearLayout,分別就是菜單的布局和內(nèi)容的布局。這里為了要讓布局盡量簡(jiǎn)單,菜單布局和內(nèi)容布局里面沒有加入任何控件,只是給這兩個(gè)布局各添加了一張背景圖片,這兩張背景圖片是我從人人客戶端上截下來的圖。這樣我們可以把注意力都集中在如何實(shí)現(xiàn)滑動(dòng)菜單的效果上面,不用關(guān)心里面各種復(fù)雜的布局了。
創(chuàng)建或打開MainActivity,這個(gè)類仍然是程序的主Activity,也是這次demo唯一的Activity,在里面加入如下代碼: [java] view plaincopy
全部的代碼都在這里了,我們可以看到,加上注釋總共才兩百多行的代碼就能實(shí)現(xiàn)滑動(dòng)菜單的特效。下面我來對(duì)以上代碼解釋一下,首先初始化的時(shí)候調(diào)用initValues方法,在這里面將內(nèi)容布局的寬度設(shè)定為屏幕的寬度,菜單布局的寬度設(shè)定為屏幕的寬度減去menuPadding值,這樣可以保證在菜單布局展示的時(shí)候,仍有一部分內(nèi)容布局可以看到。如果不在初始化的時(shí)候重定義兩個(gè)布局寬度,就會(huì)按照layout文件里面聲明的一樣,兩個(gè)布局都是fill_parent,這樣就無法實(shí)現(xiàn)滑動(dòng)菜單的效果了。然后將菜單布局的左偏移量設(shè)置為負(fù)的菜單布局的寬度,這樣菜單布局就會(huì)被完全隱藏,只有內(nèi)容布局會(huì)顯示在界面上。 之后給內(nèi)容布局注冊(cè)監(jiān)聽事件,這樣當(dāng)手指在內(nèi)容布局上滑動(dòng)的時(shí)候就會(huì)觸發(fā)onTouch事件。在onTouch事件里面,根據(jù)手指滑動(dòng)的距離會(huì)改變菜單布局的左偏移量,從而控制菜單布局的顯示和隱藏。當(dāng)手指離開屏幕的時(shí)候,會(huì)判斷應(yīng)該滑動(dòng)到菜單布局還是內(nèi)容布局,判斷依據(jù)是根據(jù)手指滑動(dòng)的距離或者滑動(dòng)的速度,細(xì)節(jié)可以看代碼中的注釋。 最后還是給出AndroidManifest.xml的代碼,都是自動(dòng)生成的,非常簡(jiǎn)單: [html] view plaincopy
好了,現(xiàn)在我們運(yùn)行一下,看一下效果吧,首先是程序剛打開的時(shí)候,顯示的是內(nèi)容布局。用手指在界面向右滑動(dòng),可以看到菜單布局出現(xiàn)。
而當(dāng)菜單布局完全展示的時(shí)候,效果如下圖:
|
|