Android使用Item Swipemenulistview实现仿QQ侧滑删除功能

大家都用过QQ,肯定有人好奇QQ滑动删除Item的效果是怎样实现的,其实我们使用Swipemenulistview就可以简单的实现。先看看我们项目中的效果:

使用的时候可以把Swipemenulistview作为一个library,也可以把Swipemenulistview的源码拷贝到我们的项目中来,使用步骤大致可以分为三步:1.在布局中配置;2.在Java代码中初始化配置;3.按钮点击事件的处理

1.在布局中配置

xml布局文件中只需要简单使用这个自定义的ListView就行了,需要注意的是必须使用类的全名。

<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"> <com.baoyz.swipemenulistview.SwipeMenuListView android:id="@+id/listView" android:layout_width="match_parent" android:layout_height="match_parent" /> </RelativeLayout>

2.在java代码中初始化菜单配置

SwipeMenuCreator creator = new SwipeMenuCreator(){ <span style="white-space:pre"> </span>@Override public void create(SwipeMenu menu) { //创建一个"打开"功能菜单 SwipeMenuItem openItem = new SwipeMenuItem(context); // 设置菜单的背景 openItem.setBackground(new ColorDrawable(Color.rgb(0xC9, 0xC9,0xCE))); // 宽度:菜单的宽度是一定要有的,否则不会显示 openItem.setWidth(180); // 菜单标题 openItem.setTitle("打开"); // 标题文字大小 openItem.setTitleSize(16); // 标题的颜色 openItem.setTitleColor(Color.WHITE); // 添加到menu menu.addMenuItem(openItem); //创建一个"打开"功能菜单 SwipeMenuItem deleteItem = new SwipeMenuItem(context); // 设置菜单的背景 deleteItem.setBackground(new ColorDrawable(Color.rgb(0xF9,0x3F, 0x25))); // 宽度:菜单的宽度是一定要有的,否则不会显示 deleteItem.setWidth(180); // 菜单标题 deleteItem.setTitle("删除"); // 标题文字大小 deleteItem.setTitleSize(16); // 标题的颜色 deleteItem.setTitleColor(Color.WHITE); // 给菜单设置一个图标 //deleteItem.setIcon(R.drawable.ic_delete); // 添加到menu menu.addMenuItem(deleteItem); } }; // 不要忘记了 mListView.setMenuCreator(creator);

这里是添加了两个菜单按钮,一个“打开”,一个“删除”。

3.菜单按钮点击事件的处理

mListView.setOnMenuItemClickListener(new OnMenuItemClickListener() { @Override public void onMenuItemClick(int position, SwipeMenu menu, int index) { switch (index) { case 0: Toast.makeText(context, "打开第" + mArrayList.get(position) + "个条目", 0).show(); break; case 1: Toast.makeText(context, "删除第" + mArrayList.get(position) + "个条目", 0).show(); mArrayList.remove(position); mAdapter.notifyDataSetChanged(); break; } } });

最后的效果图如下:

以上所述是小编给大家介绍的Android使用Item Swipemenulistview实现仿QQ侧滑删除功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

时间: 2024-07-29 15:00:01

Android使用Item Swipemenulistview实现仿QQ侧滑删除功能的相关文章

使用RecylerView完成拖动排序高仿qq侧滑删除功能_Android

 最近使用到Recylerview完成拖动排序,侧滑删除,在此记录一下. 需要使用到:ItemTouchHelper.Callback这个类. 效果图: 在有RecylerView的Activity中,除了设置Adapter还需要做的事情有: MyItemTouchHelperCallback callback = new MyItemTouchHelperCallback(adapter); //此类继承ItemTouchHelper.Callback,这是帮助处理RecylerView拖动侧

使用RecylerView完成拖动排序高仿qq侧滑删除功能

最近使用到Recylerview完成拖动排序,侧滑删除,在此记录一下. 需要使用到:ItemTouchHelper.Callback这个类. 效果图: 在有RecylerView的Activity中,除了设置Adapter还需要做的事情有: MyItemTouchHelperCallback callback = new MyItemTouchHelperCallback(adapter); //此类继承ItemTouchHelper.Callback,这是帮助处理RecylerView拖动侧滑

Android自定义View 仿QQ侧滑菜单的实现代码

先看看QQ的侧滑效果 分析一下 先上原理图(不知道能否表达的清楚 ==) -首先这里使用了 Android 的HorizontalScrollView 水平滑动布局作为容器,当然我们需要继承它自定义一个侧滑视图 - 这个容器里面有一个父布局(一般用LinerLayout,本demo用的是),这个父布局里面有且只有两个子控件(布局),初始状态菜单页的位置在Y轴上存在偏移这样可以就可以形成主页叠在菜单页的上方的视觉效果:然后在滑动的过程程中 逐渐修正偏移,最后菜单页和主页并排排列.原理搞清了实现起来

Android自定义view系列之99.99%实现QQ侧滑删除效果实例代码详解

首先声明本文是基于GitHub上"baoyongzhang"的SwipeMenuListView修改而来,该项目地址: https://github.com/baoyongzhang/SwipeMenuListView 可以说这个侧滑删除效果是我见过效果最好且比较灵活的项目,没有之一!!! 但是在使用它之前需要给大家提两点注意事项: 1,该项目支持Gradle dependence,但是目前作者提供的依赖地址对应的项目不是最新的项目,依赖过后的代码与demo中使用的不一致,会提示没有B

Android 模仿QQ侧滑删除ListView功能示例

需求: 1.listView可以侧滑item,展示删除按钮,点击删除按钮,删除当前的item 2.在删除按钮展示时,点击隐藏删除按钮,不响应item的点击事件 3.在删除按钮隐藏时,点击item响应点击事件 根据以上需求在网络上查找响应的例子,也有仿QQ侧滑代码,但不能满足2和3的要求,因此修改了一把,代码如下,共大家拍砖 第一步:重写ListView public class SwipeListView extends ListView { private final static Strin

Android插件化的思考——仿QQ一键换肤,思考比实现更重要!

Android插件化的思考--仿QQ一键换肤,思考比实现更重要! 今天群友希望写一个关于插件的Blog,思来想去,插件也不是很懂,只是用大致的思路看看能不能模拟一个,思路还是比较重要的,如果你有兴趣的话,也可以加群:555974449,你也可以说出你想看的Blog哦,嘿嘿!好的,不多说,我们进入正题: 关于QQ的换肤,他们的实现思路我不是很清楚,但是你可以看一下这张换肤的截图 我们想使用哪个主题就直接下载就好了,这一实现的过程我们大致的可以猜想: 首选是下载到本地指定文件夹,然后通过插件加载到我

Android_UI 仿QQ侧滑菜单效果的实现

相信大家对QQ侧滑菜单的效果已经不陌生了吧,侧滑进入个人头像一侧,进行对头像的更改,我的收藏,QQ钱包,我的文件等一系列的操作,今天呢,主要是实现进入侧滑菜单的这一效果原理进行分析. 主要思路分析 1.首先写一个SlideMenu 继承一个帧布局FrameLayout ,因为如果继承自ViewGroup的话,需要我们自己来实现onMeasure方法,而该方法的实现一般比较麻烦且没有必要,所以选择继承系统的已有的控件FrameLayout,不用其他控件是因为FrameLayout最轻量级 2.在布

Android recyclerview实现拖拽排序和侧滑删除

Recyclerview现在基本已经替代Listview了,RecyclerView也越来越好用了  当我们有实现条目的拖拽排序和侧滑删除时  可以直接时候Recyclerview提供的API就可以直接实现了 先贴上主要代码 private void initveiw() { ArrayList<String> items = new ArrayList<>(Arrays.asList("itme1", "item2", "itme

listview-ListView 现在下拉刷新用的ZrcListView,还想加一下侧滑删除功能

问题描述 ListView 现在下拉刷新用的ZrcListView,还想加一下侧滑删除功能 请问ZrcListView有侧滑功能么,没有的话我两个功能都想要的话是不是只能手动合成,有没有什么推荐的LIstView可以实现所有功能.还有就是ZrcListView的文档怎么找,网上的资料写的都太简单了,谢谢