Android更多條目收縮展開控件ExpandView的示例代碼
在Android開發(fā)中,我們經(jīng)常使用列表控件,而有時候列表控件條目中又會是多條目數(shù)據(jù),這時候,我們無法確定每個條目的數(shù)據(jù)多少,而為了美觀,我們就希望條目統(tǒng)一高度,多數(shù)據(jù)的條目能夠進行折疊、展開。今天,就為大家介紹一個這樣的自定義控件 ExpandView 。
效果演示圖

演示圖

Android Studio集成方式
dependencies{
compile 'com.wkp:ExpandView:1.0.4'
//Android Studio3.0+可用以下方式
//implementation 'com.wkp:ExpandView:1.0.4'
}
使用詳解
1.屬性講解
<!--每行字段數(shù)-->
<attr name="wkp_column" format="integer"/>
<!--最少顯示行數(shù)-->
<attr name="wkp_rowMin" format="integer"/>
<!--條目間距-->
<attr name="wkp_space" format="dimension"/>
<!--條目動畫時長,0為無動畫-->
<attr name="wkp_itemDuration" format="integer"/>
<!--條目高度-->
<attr name="wkp_itemHeight" format="dimension"/>
<!--“更多”按鈕圖片-->
<attr name="wkp_moreButtonImg" format="reference"/>
<!--“更多”按鈕文本-->
<attr name="wkp_moreButtonText" format="string"/>
<!--顯示文本模式時的條目背景色-->
<attr name="wkp_textBgColor" format="color"/>
<!--顯示文本模式時的條目文本顏色-->
<attr name="wkp_textColor" format="color"/>
<!--顯示文本模式時的文本大小-->
<attr name="wkp_textSize" format="dimension"/>
<!--顯示文本模式時的條目背景圖-->
<attr name="wkp_textBgRes" format="reference"/>
2.布局示例
圖1布局
<com.wkp.expandview_lib.view.ExpandView
app:wkp_textSize="@dimen/size_16sp"
app:wkp_column="3"
app:wkp_rowMin="3"
app:wkp_itemHeight="120dp"
app:wkp_textBgRes="@drawable/text_bg"
android:id="@+id/ev"
android:layout_width="match_parent"
android:layout_height="wrap_content">
</com.wkp.expandview_lib.view.ExpandView>
圖2布局
<com.wkp.expandview_lib.view.ExpandView
app:wkp_textSize="@dimen/size_16sp"
app:wkp_column="4"
app:wkp_rowMin="2"
app:wkp_itemHeight="120dp"
app:wkp_textBgRes="@drawable/text_bg"
android:id="@+id/ev"
android:layout_width="match_parent"
android:layout_height="wrap_content">
</com.wkp.expandview_lib.view.ExpandView>
3.代碼示例
public class MainActivity extends AppCompatActivity {
private static final String[] items = {"雨水滴在我的外套", "已找到", "每分每秒", "來啊,互相傷害啊", "等你到天涯海角", "遇見了你才知道你對我多重要",
"123", "456", "789", "abc", "def", "收起"};
private static final String[] items1 = {"雨水滴在我的外套1", "已找到1", "每分每秒1", "來啊,互相傷害啊1", "等你到天涯海角1", "遇見了你才知道你對我多重要1",
"123", "456", "789", "abc1", "def1", "收起1"};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final ExpandView expandView = (ExpandView) findViewById(R.id.ev);
//設(shè)置數(shù)據(jù)
expandView.setTextItems(items);
//測試當(dāng)在ListView中條目復(fù)用問題
expandView.setTextItems(items1);
//測試未展開下調(diào)用收起的效果
expandView.packUpItems();
//條目點擊監(jiān)聽
expandView.setOnItemClickListener(new ExpandView.OnItemClickListener() {
@Override
public void onItemClick(View view, ViewGroup parent, int position) {
if (position == items.length - 1) {
//收起隱藏條目
expandView.packUpItems();
}
}
});
}
}
結(jié)語
控件支持直接代碼創(chuàng)建,還有更多API請觀看 ExpandView.java 內(nèi)的注釋說明。
github地址:https://github.com/wkp111/ExpandView
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android RecyclerView實現(xiàn)點擊條目刪除
- Android自定義SwipeLayout仿QQ側(cè)滑條目
- Android仿京東分類模塊左側(cè)分類條目效果
- Android ListView自動生成列表條目的實例
- Android XRecyclerView實現(xiàn)多條目加載
- Android條目拖拽刪除功能實例代碼
- Android ListView 條目多樣式展示實例詳解
- android RecyclerView實現(xiàn)條目Item拖拽排序與滑動刪除
- Android中l(wèi)istview和imageview實現(xiàn)條目單選效果
- Android編程實現(xiàn)canvas繪制餅狀統(tǒng)計圖功能示例【自動適應(yīng)條目數(shù)量與大小】
- Android中RecyclerView上拉下拉,分割線,多條目的實例代碼
- Android 中 SwipeLayout一個展示條目底層菜單的側(cè)滑控件源碼解析
- 詳解Android中實現(xiàn)ListView左右滑動刪除條目的方法
- Android實現(xiàn)下拉展示條目效果
相關(guān)文章
21天學(xué)習(xí)android開發(fā)教程之SurfaceView與多線程的混搭
21天學(xué)習(xí)android開發(fā)教程之SurfaceView與多線程的混搭,感興趣的小伙伴們可以參考一下2016-02-02
Android TreeView效果實現(xiàn)方法(附demo源碼下載)
這篇文章主要介紹了Android TreeView效果實現(xiàn)方法,結(jié)合實例形式分析了Android TreeView效果的實現(xiàn)原理與具體技巧,并附帶demo源碼供讀者下載,需要的朋友可以參考下2016-02-02
AndroidStudio升級到3.0的新特性和注意事項小結(jié)
這篇文章主要介紹了AndroidStudio升級到3.0的新特性和注意事項,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-11-11
Android使用ViewFlipper實現(xiàn)圖片切換功能
這篇文章主要為大家詳細(xì)介紹了Android使用ViewFlipper實現(xiàn)圖片切換功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
Android實現(xiàn)實時滑動ViewPager的2種方式
這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)實時滑動ViewPager的2種方式,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10

