中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ListView如何實現顯示和隱藏Toolbar功能

發布時間:2021-06-28 10:17:18 來源:億速云 閱讀:285 作者:小新 欄目:移動開發

小編給大家分享一下ListView如何實現顯示和隱藏Toolbar功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

1.準備Toolbar

先隱藏系統自帶的actionbar,在AndroidManifest.xml文件<application>標簽中:

android:theme="@style/Theme.AppCompat.Light.NoActionBar">

(注意此處的Activity應繼承AppCompatActivity)

再在布局文件中添加Toolbar,activity_main.xml文件中:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:id="@+id/activity_main"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 tools:context="com.example.listview_unit4_1.MainActivity">
 <ListView
  android:id="@+id/list_view"
  android:layout_width="match_parent"
  android:layout_height="match_parent"/>
 <android.support.v7.widget.Toolbar
  android:id="@+id/toolbar"
  android:layout_width="match_parent"
  android:layout_height="?attr/actionBarSize"
  android:background="@color/colorPrimary"/>
</RelativeLayout>

現在布局中就添加了一個Toolbar和一個ListView.

2.Activity

package com.example.listview_unit4_1;
import android.animation.ObjectAnimator;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.Toolbar;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewConfiguration;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
 private ListView listView;
 private List<String> listViewData;//數據源
 private ArrayAdapter<String> adapter;
 private Toolbar toolbar;
 private int mTouchSlop;//系統認為的最小滑動距離
 private float mFirstY;//用戶首次觸摸的Y坐標
 private float mLastY;//用戶滑動結束時Y坐標
 private ObjectAnimator mAnimator;//將控件與動畫聯系起來的類(可以使指定的控件,實現指定的動畫效果)
 private boolean mShow;//toolbar是否顯示
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  toolbar = (Toolbar) findViewById(R.id.toolbar);
  setSupportActionBar(toolbar);
  //初始化數據源
  initData();
  listView = (ListView) findViewById(R.id.list_view);
  //為ListView增加一個HeadView(避免第一個Item被toolbar遮擋)
  //abc_action_bar_default_height_material屬性獲取系統actionBar的高度
  View headView = new View(this);
  headView.setLayoutParams(new ListView.LayoutParams(ListView.LayoutParams.MATCH_PARENT,
    (int)getResources().getDimension(R.dimen.abc_action_bar_default_height_material)));
  listView.addHeaderView(headView);
  //獲取系統定義的最低滑動距離
  mTouchSlop = ViewConfiguration.get(this).getScaledTouchSlop();
  adapter = new ArrayAdapter<String>(this, R.layout.support_simple_spinner_dropdown_item, listViewData);
  listView.setAdapter(adapter);
  //為ListView設置觸摸事件監聽
  listView.setOnTouchListener(new View.OnTouchListener() {
   @Override
   public boolean onTouch(View v, MotionEvent event) {
    switch (event.getAction()){
     case MotionEvent.ACTION_DOWN:
      mFirstY = event.getY();//getY獲取的是相對于View的坐標,getRawY獲取的是相對于屏幕的坐標
      break;
     case MotionEvent.ACTION_MOVE:
      mLastY = event.getY();
      if(mLastY - mFirstY > mTouchSlop){//手指向下滑動,顯示toolbar
       if(!mShow){
        Log.i("tag", "mLastY_手指下滑="+mLastY);
        toolbarAnim(0);//顯示
        mShow = !mShow;
       }
      }else if(mFirstY - mLastY > mTouchSlop){//手指向上滑動,隱藏toolbar
       if(mShow){
        Log.i("tag", "mLastY_手指上滑="+mLastY);
        toolbarAnim(1);//隱藏
        mShow = !mShow;
       }
      }
      break;
     default:break;
    }
    return false;//一般返回false,提交給上級
   }
  });
 }
 public void toolbarAnim(int flag){
  if(mAnimator != null && mAnimator.isRunning()){
   mAnimator.cancel();
  }
  if(flag == 0){
   Log.i("tag", "手指下滑,》》》》》》》顯示");
   mAnimator = ObjectAnimator.ofFloat(toolbar, "translationY", toolbar.getTranslationY(), 0);
  }else if(flag == 1){
   Log.i("tag", "手指上滑,》》》》》》》隱藏");
   mAnimator = ObjectAnimator.ofFloat(toolbar, "translationY", toolbar.getTranslationY(),
     -toolbar.getHeight());
  }
  mAnimator.start();//開始動畫
 }
 /**
  * 初始化ListView的數據源
  */
 public void initData(){
  listViewData = new ArrayList<>();
  String s;
  for(int i = 0; i < 20; i ++){
   s = ""+i;
   listViewData.add(s);
  }
 }
}

(1)為ListView添加了一個HeadView高度與Toolbar高度一致,避免在 RelativeLayout中Toolbar遮擋ListView第一項;

(2)設置ListView的觸摸監聽事件:

當用戶首次按下(MotionEvent.ACTION_DOWN),記錄開始的Y坐標;在用戶滑動的過程中(MotionEvent.ACTION_MOVE),記錄用戶當前的手指的Y坐標;兩者比較可以判斷出用戶手指滑動方向;

(3)使用 ObjectAnimator類控制Toolbar的動畫效果:

實例化mAnimator:

//第一個參數用于指定這個動畫要操作的是哪個控件
//第二個參數用于指定這個動畫要操作這個控件的哪個屬性
//第三個參數是可變長參數,指這個屬性值是從多少變到多少
mAnimator = ObjectAnimator.ofFloat(toolbar, "translationY", toolbar.getTranslationY(), 0);
mAnimator = ObjectAnimator.ofFloat(toolbar, "translationY", toolbar.getTranslationY(),
     -toolbar.getHeight());

(4)使用一個布爾值標識當前Toolbar是否顯示:

如果不是這樣做,那用戶在不斷滑動過程中,會不斷的觸發onTouch方法,不斷地執行toolbarAnim方法,導致滑動效果很不流暢(從Log中可以發現這一點)

實現效果:

ListView如何實現顯示和隱藏Toolbar功能

以上是“ListView如何實現顯示和隱藏Toolbar功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平南县| 凤庆县| 江源县| 山东省| 溧水县| 桂东县| 黄梅县| 临西县| 集贤县| 鹤庆县| 名山县| 富源县| 临桂县| 天镇县| 兰坪| 莲花县| 象州县| 正镶白旗| 定日县| 萨迦县| 尉氏县| 和顺县| 哈密市| 敖汉旗| 闽侯县| 龙南县| 平远县| 临沧市| 中江县| 镇远县| 澄迈县| 河池市| 垣曲县| 安多县| 灌南县| 贵德县| 广水市| 姚安县| 闽侯县| 广南县| 嘉义市|