Android中如何使用SlidingMenu控件,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
我們提供的服務(wù)有:做網(wǎng)站、成都網(wǎng)站設(shè)計、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、連山ssl等。為上千多家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的連山網(wǎng)站制作公司
java代碼:(重寫onTouchEvent方法 處理側(cè)滑菜單處的事件分發(fā)機(jī)制)
public class SlidingMenu extends ViewGroup implements OnClickListener { private View menu; private View main; private int menuWidth; private int downX; private Scroller mScroller; private ImageView iv_back; // 加載階段,先加載自身,然后再加載孩子 public SlidingMenu(Context context, AttributeSet attrs) { super(context, attrs); mScroller=new Scroller(context);//聲明Scroller進(jìn)行滾動 } // 結(jié)束加載的回調(diào) @Override protected void onFinishInflate() { super.onFinishInflate(); menu = getChildAt(0); main = getChildAt(1); menuWidth = menu.getLayoutParams().width; Log.i("test", "menuWidth:" + menuWidth); iv_back = (ImageView) findViewById(R.id.iv_back); iv_back.setOnClickListener(this); } // 默認(rèn)ViewGroup只測量自身,并不測量自身的孩子 @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); // 將onMeasure中的兩個參數(shù)直接傳給兩個孩子 menu.measure(widthMeasureSpec, heightMeasureSpec); main.measure(widthMeasureSpec, heightMeasureSpec); } // 布局 // 參數(shù)1,2,3,4:左上右下 @Override protected void onLayout(boolean changed, int l, int t, int r, int b) { menu.layout(-menuWidth, t, 0, b); main.layout(l, t, r, b); } @Override public boolean onTouchEvent(MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: downX = (int) event.getX(); break; case MotionEvent.ACTION_MOVE: int moveX = (int) event.getX(); int dX = moveX - downX; // scrollTo(x, y);//絕對移動 // scrollBy(x, y);//相對移動 // 獲取滾動的坐標(biāo) int scrollX = getScrollX(); Log.i("test", "scrollX:" + scrollX); if (scrollX - dX >= -200 && scrollX - dX <= 0) { scrollBy(-dX, 0); } downX = moveX; break; case MotionEvent.ACTION_UP: int upScrollX = getScrollX(); Log.i("test", "upScrollX:"+upScrollX); int dScrollX; if(upScrollX>-menuWidth/2){ //收回去 dScrollX=-upScrollX; isOpen=false; }else{ //展開 dScrollX=-menuWidth-upScrollX; isOpen=true; } Log.i("test", "dScrollX:"+dScrollX); mScroller.startScroll(upScrollX, 0, dScrollX, 0,20*dScrollX); //滾動后,要讓界面重繪 invalidate(); break; default: break; } return true; } @Override public void computeScroll() { super.computeScroll(); //調(diào)用這個方法來獲取期望的滾動點,如果返回true,表示動畫還沒有執(zhí)行完成 if(mScroller.computeScrollOffset()){ //用Scroller滾動,獲取下一個期望的滾動點,滾動過去 //獲取期望點的滾動坐標(biāo) int currX = mScroller.getCurrX(); scrollTo(currX, 0); invalidate(); } } private boolean isOpen; @Override public void onClick(View v) { switch (v.getId()) { case R.id.iv_back: int startX; int dx; if(!isOpen){ startX=0; dx=-menuWidth; }else{ startX=-menuWidth; dx=menuWidth; } isOpen=!isOpen; mScroller.startScroll(startX, 0, dx, 0, 2000); invalidate(); break; default: break; } } }
activity布局文件:
主界面的布局文件:
看完上述內(nèi)容,你們掌握Android中如何使用SlidingMenu控件的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!