目錄
- 一、簡介
- 二、效果圖
- 三、代碼實現
一、簡介
在Android開發的過程中有的時候我們需要手動計算ListView的高度,比如說,ScrollView中嵌套ListView的時候,我們就需要手動精確計算ListView的高度了。
如果ListView的Item高度是固定的話還好計算一些,我們可以直接使用Item的條數 * Item的固定高度來計算,但是如果Item的高度隨著內容的變化而變化,那么該如何計算呢?
下面我們就開始說說如何精確計算ListView的高度吧。
二、效果圖
先看下界面效果:
從效果圖中我們可以看到:
紅色背景的是Item,藍色背景的是ListView的dividerHeight的高度,同時我們也設置了ListView的paddingTop和paddingBottom值。
三、代碼實現
下面我們就直接上代碼:
1、Item的布局文件list_item.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical"android:layout_width="match_parent"android:layout_height="match_parent"><TextViewandroid:layout_width="match_parent"android:layout_height="wrap_content"android:id="@+id/txt_item_info"android:gravity="center"android:textColor="#ffffff"android:padding="20dp"android:textSize="18sp"android:lineSpacingExtra="10dp"android:text="測試一"android:background="@color/colorAccent"/></LinearLayout>
Item布局文件中就定義了一個TextView,TextView的高度隨著內容的變化而變化。
2、ListView界面的布局文件activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context=".MainActivity"><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:gravity="center"android:background="#30B8E3"android:textColor="#ffffff"android:textSize="18sp"android:text="動態計算ListView高度"/><Buttonandroid:layout_width="match_parent"android:layout_height="50dp"android:id="@+id/btn_add"android:text="添加Item"/><ScrollViewandroid:layout_width="match_parent"android:layout_height="match_parent"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="vertical"><ListViewandroid:layout_width="match_parent"android:layout_height="wrap_content"android:id="@+id/listview"android:divider="@color/colorPrimaryDark"android:dividerHeight="10dp"android:paddingTop="10dp"android:paddingBottom="10dp"android:cacheColorHint="#00000000"android:listSelector="#00000000"android:background="#ffffff"android:orientation="vertical"></ListView><TextViewandroid:layout_width="match_parent"android:layout_height="50dp"android:background="#30B8E3"android:textColor="#ffffff"android:gravity="center"android:text="檢測ListView高度是否精確"/></LinearLayout></ScrollView></LinearLayout>
這里我們設置了ListView的dividerHeight、paddingTop、paddingBottom。
3、ListView高度計算
布局文件準備好后,我們就來看下最關鍵的地方,動態計算ListView的高度,這里我們只貼出計算ListView高度的代碼:
public void setListViewHeight(ListView listview){ListAdapter adapter = listview.getAdapter();if(adapter == null){return;}int totalHeight = 0;// 計算ListView的寬度int listViewWidth = ((Activity)mContext).getWindowManager().getDefaultDisplay().getWidth();int widthSpec = View.MeasureSpec.makeMeasureSpec(listViewWidth, View.MeasureSpec.AT_MOST);for(int i=0;i<adapter.getCount();i++){View view = adapter.getView(i, null, listview);// 這里的第一個參數必須使用widthSpec,// 如果使用0的話,無法計算出隨內容變化而變化的Item的真正高度值view.measure(widthSpec, 0);totalHeight += view.getMeasuredHeight();}int dividerHeight = listview.getDividerHeight() * (adapter.getCount() - 1);totalHeight += dividerHeight;Log.i("ListViewHeight", "ListView DividerHeight : " + dividerHeight);int paddingHeight = listview.getPaddingTop() + listview.getPaddingBottom();totalHeight += paddingHeight;Log.i("ListViewHeight", "ListView PaddingHeight : " + paddingHeight);Log.i("ListViewHeight", "ListView TotalHeight : " + totalHeight);ViewGroup.LayoutParams layoutParams = listview.getLayoutParams();layoutParams.height = totalHeight;listview.setLayoutParams(layoutParams);this.refresh();}
其中,最關鍵的地方就是下面這幾行代碼:
// 計算ListView的寬度int listViewWidth = ((Activity)mContext).getWindowManager().getDefaultDisplay().getWidth();int widthSpec = View.MeasureSpec.makeMeasureSpec(listViewWidth, View.MeasureSpec.AT_MOST);// 這里的第一個參數必須使用widthSpec,// 如果使用0的話,無法計算出隨內容變化而變化的Item的真正高度值view.measure(widthSpec, 0);
完整代碼已上傳至Github:動態計算ListView高度