前言
右滑返回這個功能好像在iOS上蠻實(shí)用的,因?yàn)樗姆祷劓I在左上角,右手握持手機(jī)就得穿越整個屏幕去按它,不過對于大屏Android手機(jī)也是蠻實(shí)用的,右下角的返回鍵隨著屏占比的增大按起來的難度也不小,就算有mBack這樣的交互,多一個右滑返回也是極好的是吧?
上代碼 SwipBackDemo
上效果圖

SlidingPaneLayout
這個東西是Support V4中早就存在的,同樣是側(cè)滑,遠(yuǎn)沒有側(cè)滑菜單android.support.v4.widget.DrawerLayout被熟知,這玩意兒13年就有了...那時候我大概還在玩泥巴...
SlidingPaneLayout繼承自GroupView,官方的貌似是作為側(cè)滑菜單推出的,然鵝并沒有多少人使用??但是可以根據(jù)這東西實(shí)現(xiàn)右滑返回。
原理:假設(shè)滑動的時候左側(cè)有側(cè)滑菜單,但是它是全透明的,所以可以看到底部一層的視圖,然后拉出整個假設(shè)的側(cè)滑菜單之后移除當(dāng)前activity,就完成了右滑返回。
所以這個地方要定義的是滑動的anim,以及透明的style.主要是這個style:
<style name="Animation.SlidingBack" parent="@android:style/Animation.Activity"> <item name="android:activityOpenEnterAnimation">@anim/slide_in_right</item> <item name="android:activityOpenExitAnimation">@anim/slide_out_right</item> <item name="android:activityCloseEnterAnimation">@anim/slide_in_right</item> <item name="android:activityCloseExitAnimation">@anim/slide_out_right</item> <item name="android:wallpaperOpenEnterAnimation">@anim/slide_in_right</item> <item name="android:wallpaperOpenExitAnimation">@anim/slide_out_right</item> <item name="android:wallpaperCloseEnterAnimation">@anim/slide_in_right</item> <item name="android:wallpaperCloseExitAnimation">@anim/slide_out_right</item> <item name="android:wallpaperIntraOpenEnterAnimation">@anim/slide_in_right</item> <item name="android:wallpaperIntraOpenExitAnimation">@anim/slide_out_right</item> <item name="android:wallpaperIntraCloseEnterAnimation">@anim/slide_in_right</item> <item name="android:wallpaperIntraCloseExitAnimation">@anim/slide_out_right</item> </style>
代碼思路:實(shí)例化出slidingPaneLayout及相關(guān)屬性設(shè)定,然后給slidingPaneLayout添加透明的側(cè)滑視圖和真實(shí)的內(nèi)容區(qū)域視圖,關(guān)鍵代碼:
SlidingPaneLayout slidingPaneLayout = new SlidingPaneLayout(this); //通過反射改變mOverhangSize的值為0,這個mOverhangSize值為菜單到右邊屏幕的最短距離,默認(rèn)是32dp,現(xiàn)在給它改成0 try { //屬性 Field f_overHang = SlidingPaneLayout.class.getDeclaredField("mOverhangSize"); f_overHang.setAccessible(true); f_overHang.set(slidingPaneLayout, 0); } catch (Exception e) { e.printStackTrace(); } slidingPaneLayout.setPanelSlideListener(this); slidingPaneLayout.setSliderFadeColor(getResources().getColor(android.R.color.transparent)); View leftView = new View(this); leftView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)); slidingPaneLayout.addView(leftView, 0); ViewGroup decor = (ViewGroup) getWindow().getDecorView(); ViewGroup decorChild = (ViewGroup) decor.getChildAt(0); decorChild.setBackgroundColor(getResources().getColor(android.R.color.white)); decor.removeView(decorChild); decor.addView(slidingPaneLayout); slidingPaneLayout.addView(decorChild, 1);可以在一個基類中封裝使用以上方法,然后需要返回的繼承該類就行了。因?yàn)槟承┙缑娌恍枰獋?cè)滑返回,所以提供一個設(shè)置是否支持返回的方法,不需要返回的重寫該方法返回false:
@Override protected boolean isSupportSwipeBack() { return false; }上代碼 SwipBackDemo
最后
這個是全屏滑動,所以我嘗試了一些方法來讓它只在邊緣滑動,但是我失敗了...所以如果有上文這種需求的話可以直接使用,解決跟listview和scrollview的滑動沖突的時候去重新判斷onInterceptTouchEvent方法就行的,但是如果有邊緣滑動的話還是嘗試用SlidingMenu吧...
|
新聞熱點(diǎn)
疑難解答
圖片精選