神奇的listView實現自動顯示隱藏布局Android代碼_Android

來源:互聯網
上載者:User

藉助View的OnTouchListener介面來監聽listView的滑動,通過比較與上次座標的大小,判斷滑動方向,並通過滑動方向來判斷是否需顯示或者隱藏對應的布局,並且帶有動畫效果。

1.自動顯示隱藏Toolbar

首先給listView增加一個HeaderView,避免第一個Item被Toolbar遮擋。 

View header=new View(this); header.setLayoutParams(new AbsListView.LayoutParams(  AbsListView.LayoutParams.MATCH_PARENT,  (int)getResources().getDimension(R.dimen.abc_action_bar_default_height_material))); mListView.addHeaderView(header);

//R.dimen.abc_action_bar_default_height_material為系統ActionBar的高度

定義一個mTouchSlop變數,擷取系統認為的最低滑動距離

複製代碼 代碼如下:
mTouchSlop=ViewConfiguration.get(this).getScaledTouchSlop();//系統認為的最低滑動距離
      

判斷滑動事件

bbsListView.setOnTouchListener(new OnTouchListener() {      @Override   public boolean onTouch(View v, MotionEvent event) {     switch (event.getAction())     {    case MotionEvent.ACTION_DOWN:     mFirstY=event.getY();     break;    case MotionEvent.ACTION_MOVE:     mCurrentY=event.getY();     if(mCurrentY-mFirstY>mTouchSlop)      direction=0; //listView向下滑動     else if(mFirstY-mCurrentY>mTouchSlop)      direction=1; //listView向上滑動     if(direction==1)     {      if(mShow)      {       toolbarAnim(1); //隱藏上方的view       mShow=!mShow;      }     }     else if(direction==0)     {      if(!mShow)      {       toolbarAnim(0); //展示上方的view       mShow=!mShow;      }     }    case MotionEvent.ACTION_UP:     break;    }    return false;   }  }); }

屬性動畫 

protected void toolbarAnim(int flag)  {      if(set!=null && set.isRunning())  {   set.cancel();  }  if(flag==0)  {     mAnimator1=ObjectAnimator.ofFloat(mToolbar,      "translationY", linearView.getTranslationY(),0);   mAnimator2=ObjectAnimator.ofFloat(mToolbar, "alpha", 0f,1f);  }  else if(flag==1)  {        mAnimator1=ObjectAnimator.ofFloat(mToolbar,      "translationY", linearView.getTranslationY(),-linearView.getHeight());   mAnimator2=ObjectAnimator.ofFloat(mToolbar, "alpha", 1f,0f);     }  set=new AnimatorSet();  set.playTogether(mAnimator1,mAnimator2);  set.start();  }

//上面為位移還有透明度屬性動畫 

使用的時候theme要用NoActionBar的,不然會引起衝突。同時引入編譯

dependencies{   compile fileTree(include:['*.jar'],dir:'libs')   compile 'com.android.support:appcompat-v7:21.0.3' } 

2.當要隱藏和顯示的組件不是toolbar,而是我們自訂的布局myView時,需要注意一些點,
(1) 布局要用相對布局,讓我們自訂的布局懸浮在listView上方。
(2)避免第一個Item被myView遮擋,給listView增加一個HeaderView,此時需要測量myView的高度,要用下面這種方法,把任務post到UI線程中,不然執行會出錯。 

final View header=new View(this); //給listView增加一個headView,避免第一個item被遮擋 header.post(new Runnable() { public void run() {     header.setLayoutParams(new AbsListView.LayoutParams(            AbsListView.LayoutParams.MATCH_PARENT, myView.getHeight()));   }  });

其他的與toolbar一樣

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援雲棲社區。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.