<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                本文來自[http://blog.csdn.net/hellogv/](http://blog.csdn.net/hellogv/) ,歡迎轉摘,引用必須注明出處!?????? ?????? 上次介紹了[基礎篇](http://blog.csdn.net/hellogv/article/details/6789698),講解了自定義抽屜控件的基礎實現,這次就在基礎篇的基礎上加入拖拉功能。拖拉功能基于GestureDetector,GestureDetector的基本使用方式不是本文介紹的重點,有興趣的童鞋可以上網查詢相關的教程。 ?????? 本文的抽屜控件相對于基礎篇的抽屜控件多了以下功能: > 1.支持手勢拖拉 > 2.拖拉到一半時,可以自動展開或者收縮。 具體如下圖: > ![](https://box.kancloud.cn/2016-06-24_576cb0a84c3f1.gif) > ? > > ? 本文的源碼可以到這里下載:[http://download.csdn.net/detail/hellogv/3642418](http://download.csdn.net/detail/hellogv/3642418) 只貼出抽屜組件的源碼,其他源文件與基礎篇的一樣: ~~~ public class Panel extends LinearLayout implements GestureDetector.OnGestureListener{ public interface PanelClosedEvent { void onPanelClosed(View panel); } public interface PanelOpenedEvent { void onPanelOpened(View panel); } private final static int HANDLE_WIDTH=30; private final static int MOVE_WIDTH=20; private Button btnHandler; private LinearLayout panelContainer; private int mRightMargin=0; private Context mContext; private GestureDetector mGestureDetector; private boolean mIsScrolling=false; private float mScrollX; private PanelClosedEvent panelClosedEvent=null; private PanelOpenedEvent panelOpenedEvent=null; public Panel(Context context,View otherView,int width,int height) { super(context); this.mContext=context; //定義手勢識別 mGestureDetector = new GestureDetector(mContext,this); mGestureDetector.setIsLongpressEnabled(false); //改變Panel附近組件的屬性 LayoutParams otherLP=(LayoutParams) otherView.getLayoutParams(); otherLP.weight=1; otherView.setLayoutParams(otherLP); //設置Panel本身的屬性 LayoutParams lp=new LayoutParams(width, height); lp.rightMargin=-lp.width+HANDLE_WIDTH; mRightMargin=Math.abs(lp.rightMargin); this.setLayoutParams(lp); this.setOrientation(LinearLayout.HORIZONTAL); //設置Handler的屬性 btnHandler=new Button(context); btnHandler.setLayoutParams(new LayoutParams(HANDLE_WIDTH,height)); //btnHandler.setOnClickListener(handlerClickEvent); btnHandler.setOnTouchListener(handlerTouchEvent); this.addView(btnHandler); //設置Container的屬性 panelContainer=new LinearLayout(context); panelContainer.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT)); this.addView(panelContainer); } private View.OnTouchListener handlerTouchEvent=new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { if(event.getAction()==MotionEvent.ACTION_UP && //onScroll時的ACTION_UP mIsScrolling==true) { LayoutParams lp=(LayoutParams) Panel.this.getLayoutParams(); if (lp.rightMargin >= (-mRightMargin/2)) {//往左超過一半 new AsynMove().execute(new Integer[] { MOVE_WIDTH });// 正數展開 } else if (lp.rightMargin < (-mRightMargin/2)) {//往右拖拉 new AsynMove().execute(new Integer[] { -MOVE_WIDTH });// 負數收縮 } } return mGestureDetector.onTouchEvent(event); } }; /** * 定義收縮時的回調函數 * @param event */ public void setPanelClosedEvent(PanelClosedEvent event) { this.panelClosedEvent=event; } /** * 定義展開時的回調函數 * @param event */ public void setPanelOpenedEvent(PanelOpenedEvent event) { this.panelOpenedEvent=event; } /** * 把View放在Panel的Container * @param v */ public void fillPanelContainer(View v) { panelContainer.addView(v); } /** * 異步移動Panel * @author hellogv */ class AsynMove extends AsyncTask<Integer, Integer, Void> { @Override protected Void doInBackground(Integer... params) { int times; if (mRightMargin % Math.abs(params[0]) == 0)// 整除 times = mRightMargin / Math.abs(params[0]); else // 有余數 times = mRightMargin / Math.abs(params[0]) + 1; for (int i = 0; i < times; i++) { publishProgress(params); try { Thread.sleep(Math.abs(params[0])); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } return null; } @Override protected void onProgressUpdate(Integer... params) { LayoutParams lp = (LayoutParams) Panel.this.getLayoutParams(); if (params[0] < 0) lp.rightMargin = Math.max(lp.rightMargin + params[0], (-mRightMargin)); else lp.rightMargin = Math.min(lp.rightMargin + params[0], 0); if(lp.rightMargin==0 && panelOpenedEvent!=null){//展開之后 panelOpenedEvent.onPanelOpened(Panel.this);//調用OPEN回調函數 } else if(lp.rightMargin==-(mRightMargin) && panelClosedEvent!=null){//收縮之后 panelClosedEvent.onPanelClosed(Panel.this);//調用CLOSE回調函數 } Panel.this.setLayoutParams(lp); } } @Override public boolean onDown(MotionEvent e) { mScrollX=0; mIsScrolling=false; return false; } @Override public boolean onSingleTapUp(MotionEvent e) { LayoutParams lp = (LayoutParams) Panel.this.getLayoutParams(); if (lp.rightMargin < 0)// CLOSE的狀態 new AsynMove().execute(new Integer[] { MOVE_WIDTH });// 正數展開 else if (lp.rightMargin >= 0)// OPEN的狀態 new AsynMove().execute(new Integer[] { -MOVE_WIDTH });// 負數收縮 return false; } @Override public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { mIsScrolling=true; mScrollX+=distanceX; LayoutParams lp=(LayoutParams) Panel.this.getLayoutParams(); if (lp.rightMargin < -1 && mScrollX > 0) {//往左拖拉 lp.rightMargin = Math.min((lp.rightMargin + (int) mScrollX),0); Panel.this.setLayoutParams(lp); Log.e("onScroll",lp.rightMargin+""); } else if (lp.rightMargin > -(mRightMargin) && mScrollX < 0) {//往右拖拉 lp.rightMargin = Math.max((lp.rightMargin + (int) mScrollX),-mRightMargin); Panel.this.setLayoutParams(lp); } if(lp.rightMargin==0 && panelOpenedEvent!=null){//展開之后 panelOpenedEvent.onPanelOpened(Panel.this);//調用OPEN回調函數 } else if(lp.rightMargin==-(mRightMargin) && panelClosedEvent!=null){//收縮之后 panelClosedEvent.onPanelClosed(Panel.this);//調用CLOSE回調函數 } Log.e("onScroll",lp.rightMargin+""); return false; } @Override public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {return false;} @Override public void onLongPress(MotionEvent e) {} @Override public void onShowPress(MotionEvent e) {} } ~~~ ? ?
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看