ListView之點擊展開菜單

来源:http://www.cnblogs.com/snser/archive/2016/06/27/5539746.html
-Advertisement-
Play Games

一、概述 ListView點擊item顯示菜單是要實現這樣的效果: 需要實現的邏輯如下: 1)點擊一個普通item,展開當前菜單,同時關閉其他菜單 2)點擊一個已展開的菜單,隱藏當前菜單 3)將展開菜單滑到listview之外,再滑動回來,展開菜單狀態不變 4)點擊菜單中的按鈕,能夠根據不同item ...


一、概述

ListView點擊item顯示菜單是要實現這樣的效果:

需要實現的邏輯如下:

1)點擊一個普通item,展開當前菜單,同時關閉其他菜單

2)點擊一個已展開的菜單,隱藏當前菜單

3)將展開菜單滑到listview之外,再滑動回來,展開菜單狀態不變

4)點擊菜單中的按鈕,能夠根據不同item進行不同的處理

 

二、實現思路

1、UI佈局上,對於這種每個listitem都包含動態顯示菜單的場景,可以直接在listitem的xml佈局里就包含兩部分元素:item本身以及展開菜單

點擊item的時候,動態控制展開菜單這部分元素的Visibility就可以了

2、邏輯控制上,需要額外記錄當前展開菜單的item是誰,這樣可以方便高效的實現概述中描述的邏輯

  [轉載請保留本文地址:http://www.cnblogs.com/snser/p/5539746.html] 

三、開始幹活

實現的代碼結構不複雜,這裡直接貼代碼了:

listview_menu.xml:

 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:layout_width="match_parent"
 4     android:layout_height="match_parent"
 5     android:background="#EEEEEE"
 6     android:orientation="vertical"
 7     tools:context="${relativePackage}.${activityClass}" >
 8     
 9     <ListView
10         android:id="@+id/listview_menu_list"
11         android:layout_width="match_parent"
12         android:layout_height="match_parent"
13         android:divider="@null" />
14 
15 </LinearLayout>
View Code

listview_menu_item.xml:

 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:layout_width="match_parent"
 4     android:layout_height="wrap_content"
 5     android:background="@android:color/background_light"
 6     android:orientation="vertical"
 7     android:descendantFocusability="blocksDescendants" >
 8 
 9     <TextView
10         android:id="@+id/listview_menu_item_txt"
11         android:layout_width="match_parent"
12         android:layout_height="50dp"
13         android:textStyle="bold"
14         android:textSize="20sp"
15         android:textColor="@android:color/black"
16         android:text="123" />
17     
18     <LinearLayout
19         android:id="@+id/listview_menu_item_menu"
20         android:layout_width="match_parent"
21         android:layout_height="50dp"
22         android:visibility="visible"
23         android:orientation="horizontal" >
24         <Button
25             android:id="@+id/listview_menu_item_menu_toast"
26             android:layout_width="0dp"
27             android:layout_height="match_parent"
28             android:layout_weight="1"
29             android:background="#8080FF"
30             android:textColor="@android:color/black"
31             android:textSize="15sp"
32             android:text="提示" />
33         <Button
34             android:id="@+id/listview_menu_item_menu_collapse"
35             android:layout_width="0dp"
36             android:layout_height="match_parent"
37             android:layout_weight="1"
38             android:background="#80FF80"
39             android:textColor="@android:color/black"
40             android:textSize="15sp"
41             android:text="收起" />
42     </LinearLayout>
43 
44 </LinearLayout>

ListViewMenuActivity.java:

  1 public class ListViewMenuActivity extends Activity {
  2     private int mExpandedMenuPos = -1;
  3     private ListViewAdapter mAdapter;
  4     
  5     @Override
  6     protected void onCreate(Bundle savedInstanceState) {
  7         super.onCreate(savedInstanceState);
  8         setContentView(R.layout.listview_menu);
  9         
 10         ArrayList<Integer> data = new ArrayList<Integer>();
 11         for (int index = 0; index != 40; ++index) {
 12             data.add(index);
 13         }
 14         
 15         ListView list = (ListView)findViewById(R.id.listview_menu_list);
 16         list.setAdapter(mAdapter = new ListViewAdapter(this, data));
 17         list.setOnItemClickListener(new OnListItemClickListenser());
 18     }
 19     
 20     private class ListViewAdapter extends BaseAdapter {
 21         private LayoutInflater mLayoutInflater;
 22         private ArrayList<Integer> mListData;
 23         
 24         private OnMenuClickListenser mOnMenuClickListenser = new OnMenuClickListenser();
 25         
 26         private class ViewHolder {
 27             public ViewHolder (View viewRoot) {
 28                 root = viewRoot;
 29                 txt = (TextView)viewRoot.findViewById(R.id.listview_menu_item_txt);
 30                 menu = viewRoot.findViewById(R.id.listview_menu_item_menu);
 31                 btnToast = (Button)viewRoot.findViewById(R.id.listview_menu_item_menu_toast);
 32                 btnCollapse = (Button)viewRoot.findViewById(R.id.listview_menu_item_menu_collapse);
 33             }
 34             public View root;
 35             public TextView txt;
 36             public View menu;
 37             public Button btnToast;
 38             public Button btnCollapse;
 39         }
 40         
 41         public ListViewAdapter(Context context, ArrayList<Integer> data) {
 42             mLayoutInflater = LayoutInflater.from(context);
 43             mListData = data;
 44         }
 45         
 46         @Override
 47         public int getCount() {
 48             return mListData == null ? 0 : mListData.size();
 49         }
 50 
 51         @Override
 52         public Object getItem(int position) {
 53             return mListData == null ? 0 : mListData.get(position);
 54         }
 55 
 56         @Override
 57         public long getItemId(int position) {
 58             return position;
 59         }
 60 
 61         @Override
 62         public View getView(final int position, View convertView, ViewGroup parent) {
 63             if (convertView == null) {
 64                 convertView = mLayoutInflater.inflate(R.layout.listview_menu_item, parent, false);
 65                 convertView.setTag(new ViewHolder(convertView));
 66             }
 67             if (convertView != null && convertView.getTag() instanceof ViewHolder) {
 68                 final ViewHolder holder = (ViewHolder)convertView.getTag();
 69                 holder.txt.setText(String.valueOf(getItem(position)));
 70                 if (position % 2 == 0) {
 71                     holder.root.setBackgroundColor(0xFFC9EEFE);
 72                 } else {
 73                     holder.root.setBackgroundColor(0xFFFFFFFF);
 74                 }
 75                 holder.menu.setVisibility(position == mExpandedMenuPos ? View.VISIBLE : View.GONE);
 76                 holder.btnToast.setText("提示" + position);
 77                 holder.btnCollapse.setText("收起" + position);
 78                 holder.btnToast.setOnClickListener(mOnMenuClickListenser);
 79                 holder.btnCollapse.setOnClickListener(mOnMenuClickListenser);
 80             }
 81             return convertView;
 82         }
 83         
 84         private class OnMenuClickListenser implements View.OnClickListener {
 85             @Override
 86             public void onClick(View v) {
 87                 final int id = v.getId();
 88                 if (id == R.id.listview_menu_item_menu_toast) {
 89                     Toast.makeText(ListViewMenuActivity.this, "提示" + mExpandedMenuPos, Toast.LENGTH_SHORT).show();
 90                 } else if (id == R.id.listview_menu_item_menu_collapse) {
 91                     mExpandedMenuPos = -1;
 92                     notifyDataSetChanged();
 93                 }
 94             }
 95         }
 96     }
 97     
 98     private class OnListItemClickListenser implements OnItemClickListener {
 99         @Override
100         public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
101             if (position == mExpandedMenuPos) {
102                 mExpandedMenuPos = -1;
103             } else {
104                 mExpandedMenuPos = position;
105             }
106             mAdapter.notifyDataSetChanged();
107         }
108     }
109     
110 }

 [轉載請保留本文地址:http://www.cnblogs.com/snser/p/5539746.html] 

四、demo視頻

 [轉載請保留本文地址:http://www.cnblogs.com/snser/p/5539746.html] 

五、demo工程

保存下麵的圖片,擴展名改成 .zip 即可

 

[轉載請保留本文地址:http://www.cnblogs.com/snser/p/5539746.html] 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在談原型鏈之前,我們首先要瞭解自定義函數與 Function 之間是什麼關係,而構造函數、原型和實例之間又存在什麼千絲萬縷的關係呢?其實,所有的函數都是 Function 的實例。在構造函數上都有一個原型屬性 prototype,該屬性也是一個對象;那麼在原型對象上有一個 constructor 屬 ...
  • 一,效果圖。 二,工程圖。 三,代碼。 RootViewController.h #import <UIKit/UIKit.h> @interface RootViewController : UIViewController <UITextFieldDelegate> @end RootViewC ...
  • 1. 新建個位移動畫的xml文件 Activity中開啟動畫 使用AnimationUtils類載入動畫資源文件 left_to_right.xml 2. 淡入淡出動畫 當前淡出界面和執行時間 淡出過程中,淡入界面處於等待狀態 第二個界面淡入和他的執行時間 第一個界面執行完成後,要刪除掉 ...
  • 最近用swift做一個公司的小項目,遇到一個問題,就是通過api獲取的html文本中的標簽都已經被轉義了, 直接調用webview.loadHTMLString(content!, baseURL: nil) 會在webview中下麵圖中的樣子 最後萬能的github上找到了一個String的擴展 ...
  • ButterKnife 是這兩年比較流行的開源庫,是一個View註入框架,其主要功能是代替findViewByid()方法。同時還能夠快速的添加監聽事件,能夠更容易的實現MVVM模式,是非常實用的工具之一。 剛開始使用ButterKnife的時候很多人可能會遇到NullPointerExceptio ...
  • 根據效果圖拆分界面 View ==> ViewGroup ==> RelativeLayout,主體部分使用RelativeLayout作為占位 View和ViewGroup的區別:ViewGroup有特有的addView()和removeView()方法,RelativeLayout添加進來Vie ...
  • 接著處理《Android 網路圖片查看器》中出現的問題 使用添加子線程,修改原程式: 運行項目後報錯: 06-27 19:27:59.613: W/System.err(2471): android.view.ViewRootImpl$CalledFromWrongThreadException: ...
  • 最近在學習圖片載入框架Glide的時候,被他精簡的寫法震驚了。一句話,就可以搞定。 同時在年初的時候,學習RXJava的時候,用鏈式編程很優雅。 今天就來學習一下,建造者模式在Android中簡單應用 。 Builder 的好處 代碼可讀性好,只需要寫一句代碼,鏈式編程很優雅 方便。通過不同的組合就 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...