Android提高之多方向抽屜實(shí)現(xiàn)方法
說起在android上要實(shí)現(xiàn)類似Launch的抽屜效果,大家一定首先會(huì)想起SlidingDrawer。SlidingDrawer是android官方控件之一,但是本文的主角并不是它,而是民間的控件工具集合:android-misc-widgets。android-misc-widgets里面包含幾個(gè)widget:Panel、SmoothButton、Switcher、VirtualKeyboard,還有一些動(dòng)畫特效,本文主要介紹抽屜容器Panel的用法。android-misc-widgets的google工程地址:-widgets/http://code.google.com/p/android-misc。
工程代碼中Panel的演示效果如下所示:

這個(gè)Panel控件可以輕易實(shí)現(xiàn)不同方向的抽屜效果,比SlidingDrawer有更強(qiáng)的擴(kuò)展性!
在多次使用Panel的過程中,發(fā)現(xiàn)Panel有個(gè)bug,會(huì)間斷性出現(xiàn)“閃爍”,也就是在onTouchListener里面的觸發(fā)ACTION_DOWN后,抽屜瞬間彈出然后瞬間回收(版本日期為Feb 3, 2009)。把原Panel的OnTouchListener加以替換,即以下代碼:
OnTouchListener touchListener = new OnTouchListener() {
int initX;
int initY;
boolean setInitialPosition;
public boolean onTouch(View v, MotionEvent event) {
if (mState == State.ANIMATING) {
// we are animating
return false;
}
// Log.d(TAG, "state: " + mState + " x: " + event.getX() + " y: " + event.getY());
int action = event.getAction();
if (action == MotionEvent.ACTION_DOWN) {
if (mBringToFront) {
bringToFront();
}
initX = 0;
initY = 0;
if (mContent.getVisibility() == GONE) {
// since we may not know content dimensions we use factors here
if (mOrientation == VERTICAL) {
initY = mPosition == TOP? -1 : 1;
} else {
initX = mPosition == LEFT? -1 : 1;
}
}
setInitialPosition = true;
} else {
if (setInitialPosition) {
// now we know content dimensions, so we multiply factors...
initX *= mContentWidth;
initY *= mContentHeight;
// ... and set initial panel's position
mGestureListener.setScroll(initX, initY);
setInitialPosition = false;
// for offsetLocation we have to invert values
initX = -initX;
initY = -initY;
}
// offset every ACTION_MOVE & ACTION_UP event
event.offsetLocation(initX, initY);
}
if (!mGestureDetector.onTouchEvent(event)) {
if (action == MotionEvent.ACTION_UP) {
// tup up after scrolling
post(startAnimation);
}
}
return false;
}
};
替換為:
OnTouchListener touchListener = new OnTouchListener() {
float touchX, touchY;
public boolean onTouch(View v, MotionEvent event) {
if (mState == State.ANIMATING) {
// we are animating
return false;
}
int action = event.getAction();
if (action == MotionEvent.ACTION_DOWN) {
if (mBringToFront) {
bringToFront();
}
touchX = event.getX();
touchY = event.getY();
}
if (!mGestureDetector.onTouchEvent(event)) {
if (action == MotionEvent.ACTION_UP) {
// tup up after scrolling
int size = (int) (Math.abs(touchX - event.getX()) + Math
.abs(touchY - event.getY()));
if (size == mContentWidth || size == mContentHeight) {
mState = State.ABOUT_TO_ANIMATE;
//Log.e("size", String.valueOf(size));
//Log.e(String.valueOf(mContentWidth),String.valueOf(mContentHeight));
}
post(startAnimation);
}
}
return false;
}
};
即可修復(fù)這個(gè)bug,并且也同樣實(shí)現(xiàn)了OnClickListener的功能,可以把原Panel的OnClickListener給刪掉了!
希望本文所述實(shí)例對于大家進(jìn)行Android項(xiàng)目開發(fā)能有所幫助。
- Android 自定義View實(shí)現(xiàn)抽屜效果
- Android自定義控件仿QQ抽屜效果
- Android DrawerLayout實(shí)現(xiàn)抽屜效果實(shí)例代碼
- Android 抽屜效果的導(dǎo)航菜單實(shí)現(xiàn)代碼實(shí)例
- Android實(shí)現(xiàn)自定義滑動(dòng)式抽屜菜單效果
- Android App中DrawerLayout抽屜效果的菜單編寫實(shí)例
- Android SlidingDrawer 抽屜效果的實(shí)現(xiàn)
- Android實(shí)現(xiàn)3種側(cè)滑效果(仿qq側(cè)滑、抽屜側(cè)滑、普通側(cè)滑)
- Android實(shí)現(xiàn)右邊抽屜Drawerlayout效果
- Android抽屜導(dǎo)航Navigation Drawer實(shí)例解析
- Android組件之DrawerLayout實(shí)現(xiàn)抽屜菜單
- Android編程實(shí)現(xiàn)抽屜效果的方法詳解
相關(guān)文章
Android使用AIDL方式實(shí)現(xiàn)播放音樂案例
這篇文章主要介紹了Android使用AIDL方式實(shí)現(xiàn)播放音樂案例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
JetpackCompose Navigation導(dǎo)航實(shí)現(xiàn)流程
Navigation是Jetpack用于Android導(dǎo)航的組件,作用是處理頁面跳轉(zhuǎn),以及頁面跳轉(zhuǎn)過程中的交互。使用Navigation,你就需要為每個(gè)頁面設(shè)定一條唯一路徑,它是一個(gè)String常量,形式是DeepLink的樣子,從一個(gè)頁面跳轉(zhuǎn)到另一個(gè)頁面,它通過輸入目的地的路徑進(jìn)行轉(zhuǎn)跳2023-01-01
Android中實(shí)現(xiàn)EditText圓角的方法
Android中實(shí)現(xiàn)EditText圓角的方法,需要的朋友可以參考一下2013-03-03
Android之在linux終端執(zhí)行shell腳本直接打印當(dāng)前運(yùn)行app的日志的實(shí)現(xiàn)方法
今天小編就為大家分享一篇關(guān)于Android之在linux終端執(zhí)行shell腳本直接打印當(dāng)前運(yùn)行app的日志的實(shí)現(xiàn)方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-02-02
android自定義View實(shí)現(xiàn)圓環(huán)顏色選擇器
這篇文章主要介紹了android自定義View實(shí)現(xiàn)圓環(huán)顏色選擇器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-06-06
Android編程使用WebView實(shí)現(xiàn)文件下載功能的兩種方法
這篇文章主要介紹了Android編程使用WebView實(shí)現(xiàn)文件下載功能的兩種方法,涉及Android基于WebView的相關(guān)文件傳輸與線程操作技巧,需要的朋友可以參考下2018-02-02

