Android編程實現(xiàn)帶有圖標(biāo)的ListView并帶有長按菜單效果示例
本文實例講述了Android編程實現(xiàn)帶有圖標(biāo)的ListView并帶有長按菜單效果。分享給大家供大家參考,具體如下:
MainActivity.Java
package com.zxl;
import java.util.ArrayList;
import java.util.List;
import org.w3c.dom.ls.LSException;
import android.app.Activity;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.AdapterContextMenuInfo;
import android.widget.ListView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.Toast;
public class MainActivity extends Activity implements OnItemClickListener {
/** Called when the activity is first created. */
ListView lv;
List<ListViewItem> items;
CustomListViewAdapter adapter;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
lv=(ListView)findViewById(R.id.listView1);
items=new ArrayList<MainActivity.ListViewItem>();
items.add(new ListViewItem(){{
ThumbnailResource=R.drawable.ic_launcher;
title="Item1";
SubTitle="Item1 Description";
}});
items.add(new ListViewItem(){{
ThumbnailResource=R.drawable.ic_launcher;
title="Item2";
SubTitle="Item2 Description";
}});
items.add(new ListViewItem(){{
ThumbnailResource=R.drawable.ic_launcher;
title="Item3";
SubTitle="Item3 Description";
}});
items.add(new ListViewItem(){{
ThumbnailResource=R.drawable.ic_launcher;
title="Item4";
SubTitle="Item4 Description";
}});
adapter=new CustomListViewAdapter(this, items);
lv.setAdapter(adapter);
registerForContextMenu(lv);
lv.setOnItemClickListener(this);
}
class ListViewItem{
public int ThumbnailResource;
public String title;
public String SubTitle;
}
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
// TODO Auto-generated method stub
/* ListViewItem item=items.get(position); //刪除
items.remove(item);
adapter=new CustomListViewAdapter(this, items);
lv.setAdapter(adapter);*/
ListViewItem item=items.get(position);
Toast.makeText(MainActivity.this, "this is :"+item, Toast.LENGTH_LONG).show();
}
@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {
// TODO Auto-generated method stub
super.onCreateContextMenu(menu, v, menuInfo);
menu.add("add");
menu.add("update");
menu.add("delete");
}
@Override
public boolean onContextItemSelected(MenuItem item) {
// TODO Auto-generated method stub
super.onContextItemSelected(item);
if(item.getTitle()=="add"){
Toast.makeText(MainActivity.this, "add", Toast.LENGTH_LONG).show();
items.add(new ListViewItem(){{
ThumbnailResource=R.drawable.ic_launcher;
title="Item new";
SubTitle="Item new Description";
}});
adapter=new CustomListViewAdapter(this, items);
lv.setAdapter(adapter);
}
else if(item.getTitle()=="update"){
//do somthing
}
else if(item.getTitle()=="delete"){
ContextMenuInfo info = item.getMenuInfo();
AdapterView.AdapterContextMenuInfo contextMenuInfo = (AdapterContextMenuInfo) info;
// 獲取選中行位置
int position = contextMenuInfo.position;
ListViewItem itema=items.get(position);
items.remove(itema);
adapter=new CustomListViewAdapter(this, items);
lv.setAdapter(adapter);
}
return true;
}
}
CustomListViewAdapter.java
package com.zxl;
import java.util.List;
import com.zxl.MainActivity.ListViewItem;
import android.app.Activity;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
public class CustomListViewAdapter extends BaseAdapter
{
LayoutInflater inflater;
List<ListViewItem> items;
public CustomListViewAdapter(Activity context, List<ListViewItem> items) {
super();
this.items = items;
this.inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}
public int getCount() {
// TODO Auto-generated method stub
return items.size();
}
public Object getItem(int position) {
// TODO Auto-generated method stub
return null;
}
public long getItemId(int position) {
// TODO Auto-generated method stub
return 0;
}
public View getView(final int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
//items
ListViewItem item=items.get(position);
View vi=convertView;
if(convertView==null)
vi = inflater.inflate(R.layout.item_row, null);
ImageView imgThumbnail=(ImageView) vi.findViewById(R.id.imgThumbnail);
TextView txtTitle =(TextView) vi.findViewById(R.id.txtTitle);
TextView txtSubTitle=(TextView) vi.findViewById(R.id.txtSubTitle);
imgThumbnail.setImageResource(item.ThumbnailResource);
txtTitle.setText(item.title);
txtSubTitle.setText(item.SubTitle);
return vi;
}
}
main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TextView
android:id="@+id/textView1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello" />
<ListView
android:id="@+id/listView1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textView1"
android:layout_alignParentTop="true" >
</ListView>
</RelativeLayout>
item_row.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
android:id="@+id/relativeLayout1"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
xmlns:android="http://schemas.android.com/apk/res/android"
android:padding="5dip">
<ImageView
android:layout_width="78dip"
android:layout_height="78dip"
android:id="@+id/imgThumbnail"
android:layout_alignParentLeft="true"
android:layout_centerInParent="true"
android:layout_marginLeft="-3dip"
android:scaleType="centerInside">
</ImageView>
<TextView
android:textAppearance="?android:attr/textAppearanceLarge"
android:layout_height="wrap_content"
android:text="TextView"
android:layout_width="wrap_content"
android:id="@+id/txtTitle"
android:layout_toRightOf="@+id/imgThumbnail"
android:layout_marginTop="6dip"
android:layout_marginLeft="6dip">
</TextView>
<TextView
android:layout_height="wrap_content"
android:text="TextView"
android:layout_width="wrap_content"
android:id="@+id/txtSubTitle"
android:layout_toRightOf="@+id/imgThumbnail"
android:layout_below="@+id/txtTitle"
android:layout_marginTop="3dip"
android:layout_marginLeft="6dip">
</TextView>
</RelativeLayout>
文件結(jié)構(gòu):


更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android開發(fā)入門與進(jìn)階教程》、《Android布局layout技巧總結(jié)》、《Android視圖View技巧總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android操作json格式數(shù)據(jù)技巧總結(jié)》、《Android資源操作技巧匯總》及《Android控件用法總結(jié)》
希望本文所述對大家Android程序設(shè)計有所幫助。
- Android使用ExpandableListView實現(xiàn)三層嵌套折疊菜單
- Android ExpandableListView雙層嵌套實現(xiàn)三級樹形菜單
- Android編程實現(xiàn)為ListView創(chuàng)建上下文菜單(ContextMenu)的方法
- Android UI設(shè)計系列之自定義ListView仿QQ空間阻尼下拉刷新和漸變菜單欄效果(8)
- Android ListView長按彈出菜單二種實現(xiàn)方式示例
- Android左右滑出菜單實例分析
- android popwindow實現(xiàn)左側(cè)彈出菜單層及PopupWindow主要方法介紹
- android底部菜單欄實現(xiàn)原理與代碼
- Android滾動菜單ListView實例詳解
相關(guān)文章
Android實現(xiàn)圖片轉(zhuǎn)高斯模糊以及高斯模糊布局
這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)圖片轉(zhuǎn)高斯模糊的方法,以及高斯模糊布局,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08
Android 實現(xiàn)閃屏頁和右上角的倒計時跳轉(zhuǎn)實例代碼
本文給大家分享一段實例代碼給大家介紹android實現(xiàn)閃屏頁和右上角的倒計時跳轉(zhuǎn)實例代碼,閃屏頁用到了handler和CountDownTimer類,還需配置一下Activity的主題,感興趣的朋友參考下吧2016-02-02
Android自定義viewGroup實現(xiàn)點擊動畫效果
這篇文章主要介紹了Android自定義viewGroup實現(xiàn)點擊動畫效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12
Android App內(nèi)監(jiān)聽截圖加二維碼功能代碼
Android截屏功能是一個常用的功能,可以方便的用來分享或者發(fā)送給好友,本文介紹了如何實現(xiàn)app內(nèi)截屏監(jiān)控功能,需要的朋友可以參考下2017-08-08
Android使用動畫動態(tài)添加商品進(jìn)購物車
這篇文章主要為大家詳細(xì)介紹了Android使用動畫動態(tài)添加商品進(jìn)購物車,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06
Android設(shè)備與外接U盤實現(xiàn)數(shù)據(jù)讀取操作的示例
本篇文章主要介紹了Android設(shè)備與外接U盤實現(xiàn)數(shù)據(jù)讀取操作的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11

