listview向左滑有删除功能

我当时也是比较迷茫选哪个控件比较好,后面再github上找到一个这个SwipeMenuListView开源项目完成的,使用这个项目非常简单,里面有两个例子,复杂的跟简单的,我当时自己写了个Demos来学习,废话不多说了,直接贴代码。

public class MainActivity extends Activity {

private AppAdapter mAdapter;

private SwipeMenuListView mListView;

ArrayList<String> data=new ArrayList<String>();

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

for (int i = 0; i < 9; i++) {

data.add("position为"+i);

}

mListView = (SwipeMenuListView) findViewById(R.id.listView);

mAdapter = new AppAdapter();

mListView.setAdapter(mAdapter);

SwipeMenuCreator creator = new SwipeMenuCreator() {

@Override

public void create(SwipeMenu menu) {

// create "open" item

SwipeMenuItem openItem = new SwipeMenuItem(

getApplicationContext());

// set item background

openItem.setBackground(new ColorDrawable(Color.rgb(0xC9, 0xC9,

0xCE)));

// set item width

openItem.setWidth(dp2px(90));

// set item title

openItem.setTitle("Open");

// set item title fontsize

openItem.setTitleSize(18);

// set item title font color

openItem.setTitleColor(Color.WHITE);

// add to menu

menu.addMenuItem(openItem);

// create "delete" item

SwipeMenuItem deleteItem = new SwipeMenuItem(

getApplicationContext());

// set item background

deleteItem.setBackground(new ColorDrawable(Color.rgb(0xF9,

0x3F, 0x25)));

// set item width

deleteItem.setWidth(dp2px(90));

// set a icon

deleteItem.setIcon(R.drawable.ic_delete);

// add to menu

menu.addMenuItem(deleteItem);

}

};

mListView.setMenuCreator(creator);

mListView.setOnMenuItemClickListener(new OnMenuItemClickListener() {

@Override

public void onMenuItemClick(int position, SwipeMenu menu, int index) {

//index=0 open index =1 删除

switch (index) {

case 0:

Toast.makeText(MainActivity.this, ""+position, Toast.LENGTH_SHORT).show();

break;

case 1:

// Log.e("position", ""+position);

data.remove(position);

Log.e("onMenuItemClick 1", "position="+position+"##index="+index+"data.tos"+data.toString());

Toast.makeText(MainActivity.this, ""+position+"index="+index, Toast.LENGTH_SHORT).show();

new Handler().postDelayed(new Runnable() {

@Override

public void run() {

// TODO Auto-generated method stub

mAdapter.notifyDataSetChanged();

}

}, 500);

break;

default:

break;

}

}

});

}

class AppAdapter extends BaseAdapter{

@Override

public int getCount() {

// TODO Auto-generated method stub

Log.e("getview", data.toString());

return data.size();

}

@Override

public String getItem(int position) {

// TODO Auto-generated method stub

return data.get(position);

}

@Override

public long getItemId(int position) {

// TODO Auto-generated method stub

return position;

}

@Override

public View getView(int position, View convertView, ViewGroup parent) {

// biao bb = null;

// if(convertView==null){

// convertView = getLayoutInflater().inflate(R.layout.item, null);

// bb = new biao();

// bb.text = (TextView) convertView.findViewById(R.id.textView1);

// convertView.setTag(bb);

// }else{

// bb = (biao) convertView.getTag();

// }

// bb.text.setText(data.get(position));

// Log.e("tv", data.get(position));

if (convertView == null) {

convertView = View.inflate(getApplicationContext(),

R.layout.item, null);

new ViewHolder(convertView);

}

ViewHolder holder = (ViewHolder) convertView.getTag();

holder.tv.setText(data.get(position));

return convertView;

}

class ViewHolder {

TextView tv;

public ViewHolder(View view) {

tv = (TextView) view.findViewById(R.id.textView1);

view.setTag(this);

}

}

}

private int dp2px(int dp) {

return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, dp,

getResources().getDisplayMetrics());

}

}

主XML也是很简单的。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context=".MainActivity" >

<com.baoyz.swipemenulistview.SwipeMenuListView

android:id="@+id/listView"

android:layout_width="match_parent"

android:layout_height="match_parent" />

</RelativeLayout>

时间: 2024-10-13 02:46:12

listview向左滑有删除功能的相关文章

Android 使用NineOldAndroids实现仿微信listview左滑出现删除itembutton

这是一个使用NineOldAndroids实现仿微信listview左滑出现删除itembutton效果.使用的是Jake Wharton的动画开源库NineOldAndroids.在API3.0(Honeycomb), SDK新增了一个android.animation包,里面的类是实现动画效果相关的类,通过Honeycomb API,能够实现非常复杂的动画效果,但是如果开发者想在3.0以下使用这一套API, 则需要使用开源框架Nine Old Androids,在这个库中会根据我们运行的机器

高仿微信实现左滑显示删除按钮功能

在实际项目中删除列表中的某一项是非常常见的功能,传统的做法可以使用长按监听器等,而现在流行的做法是左滑弹出删除按钮,微信,QQ等都是这么做的,下面做一个示例,代码如下: 主页面MainActivity:代码比较简单常规 package com.home.testslideview; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.os.Bundle; im

小程序 开发之向左滑动实现删除功能

为了让用户的体验效果有一个很大的提升,在删除 单行信息 的 时候,我们逐渐从点击删除到向左 滑动实现删除.那么小程序的左滑删除是怎么实现的呢? 效果如图: 第一步:先进行页面的布局: <!-- 自定义单选/多选/全选实现删除功能 --> <view class="item-box"> <view class="items"> <view wx:for="{{list}}" wx:key="{{i

小程序地址左滑默认删除

我们在开发小程序时,总会遇到一些删除功能列表的操作,触屏左滑操作,即显示可操作删除按钮; 首先,我们需要在components里边注册一个组件, 我们在 components中创建一个slide目录,然后在新建Component,命名为slide,这样就自动生成slide组件 我们就在slide.wxml中写入 <!--slide-view/slide-view.wxml--> <movable-area class="container" style="w

ListView自定义按钮实例-标记删除功能

.aspx代码如下: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="test.aspx.cs" Inherits="test" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1

ANDROID仿IOS微信滑动删除_SWIPELISTVIEW左滑删除例子

http://dwtedx.sinaapp.com/itshare_290.html 本例子实现了滑动删除ListView的Itemdemo的效果.大家都知道.这种创意是来源于IOS的.左滑删除的功能.在Android上面实现比较麻烦.本例子中不仅实现了左滑删除功能.还实现了左滑赞.左滑分享.左滑收藏等功能.当然大家也可以根据自己项目的需求来修改功能.QQ和微信也实现了相同的功能.大家可以看看.先上程序运行的效果 怎么样.大家看了这个截图是不是很心动呀.而且在左滑的时候还配有简单的滑动动画呢.非

js高仿QQ消息列表左滑功能

该组件,主要功能类似于QQ消息列表左滑出现删除.标为已读等按钮的功能:现在的版本用的是纯javaScript编写:后续会跟进 angularJs 开发的类似组件以及jquery的; 下面,就让我们来认识下怎么使用该程序: 在该程序里,总共分为四个文件: 1 .css文件夹 2. img 图片文件夹 3. js文件 4. index.html  主页面: 稍后,你可以自行下载,打开运行观看效果: 二.代码讲解 1.此html结构,为不可修改结构 <ul class="list-ul"

左滑删除

成品示例图 额,先上图吧.下面分别是在PC浏览器里和在Mobile浏览器里的效果. PC浏览器 手机浏览器 实现思路 为了说明我的实现思路,做了两个图来辅助说明. 首先,请看图1.在图中,我们设置每一行的宽度超过浏览器的宽度,其超出的部分就是放置按钮的区域.由于超出了浏览器的最大宽度,因此按钮区域此时是不可见的,只能显示左侧的常规信息部分. 图1 普通状态  接下来,我们监听左侧常规信息区域,监听滑动事件(具体如何监听先不考虑).当我们监听到左滑事件时,我们让相应行左偏移,让按钮显示出来,同时左

qq联系人 左滑删除功能

// 局部刷新 NSArray *indexPaths = @[ [NSIndexPath indexPathForRow:0 inSection:0], [NSIndexPath indexPathForRow:1 inSection:0] ]; [self.tableView reloadRowsAtIndexPaths:indexPaths withRowAnimation:UITableViewRowAnimationLeft]; #pragma mark - 按钮的点击 - (IBAc