仿QQ侧滑删除Item:Swipemenulistview的简单实现

原文地址:http://blog.csdn.net/xiaoli100861/article/details/50888079

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


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

1.在布局中配置

xml布局文件中只需要简单使用这个自定义的ListView就行了,需要注意的是必须使用类的全名。
[html]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. <RelativeLayout 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.   
  6.     <com.baoyz.swipemenulistview.SwipeMenuListView  
  7.         android:id="@+id/listView"  
  8.         android:layout_width="match_parent"  
  9.         android:layout_height="match_parent" />  
  10.   
  11. </RelativeLayout>  

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

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. SwipeMenuCreator creator = new SwipeMenuCreator(){  
  2.   
  3. <span style="white-space:pre">    </span>@Override  
  4.     public void create(SwipeMenu menu) {  
  5.                   
  6.         //创建一个"打开"功能菜单  
  7.         SwipeMenuItem openItem = new SwipeMenuItem(context);  
  8.         // 设置菜单的背景  
  9.         openItem.setBackground(new ColorDrawable(Color.rgb(0xC90xC9,0xCE)));  
  10.         // 宽度:菜单的宽度是一定要有的,否则不会显示  
  11.         openItem.setWidth(180);  
  12.         // 菜单标题  
  13.         openItem.setTitle("打开");  
  14.         // 标题文字大小  
  15.         openItem.setTitleSize(16);  
  16.         // 标题的颜色  
  17.         openItem.setTitleColor(Color.WHITE);  
  18.         // 添加到menu  
  19.         menu.addMenuItem(openItem);  
  20.                   
  21.         //创建一个"打开"功能菜单  
  22.         SwipeMenuItem deleteItem = new SwipeMenuItem(context);  
  23.         // 设置菜单的背景  
  24.         deleteItem.setBackground(new ColorDrawable(Color.rgb(0xF9,0x3F0x25)));  
  25.         // 宽度:菜单的宽度是一定要有的,否则不会显示  
  26.         deleteItem.setWidth(180);  
  27.         // 菜单标题  
  28.         deleteItem.setTitle("删除");  
  29.         // 标题文字大小  
  30.         deleteItem.setTitleSize(16);  
  31.         // 标题的颜色  
  32.         deleteItem.setTitleColor(Color.WHITE);  
  33.         // 给菜单设置一个图标  
  34.         //deleteItem.setIcon(R.drawable.ic_delete);  
  35.         // 添加到menu  
  36.         menu.addMenuItem(deleteItem);  
  37.     }  
  38. };  
  39. // 不要忘记了  
  40. mListView.setMenuCreator(creator);  
这里是添加了两个菜单按钮,一个“打开”,一个“删除”。

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

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. mListView.setOnMenuItemClickListener(new OnMenuItemClickListener() {  
  2.     @Override  
  3.     public void onMenuItemClick(int position, SwipeMenu menu, int index) {  
  4.         switch (index) {  
  5.         case 0:  
  6.             Toast.makeText(context, "打开第" + mArrayList.get(position) + "个条目"0).show();  
  7.             break;  
  8.         case 1:  
  9.             Toast.makeText(context, "删除第" + mArrayList.get(position) + "个条目"0).show();  
  10.             mArrayList.remove(position);  
  11.             mAdapter.notifyDataSetChanged();  
  12.                       
  13.             break;  
  14.         }  
  15.     }  
  16. });  
最后的效果图如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现Android侧菜单有多种方式,其中一种比较常见的实现方式是使用DrawerLayout和NavigationView。 步骤如下: 1. 在XML布局文件中添加DrawerLayout和NavigationView,其中NavigationView中可以添加菜单项。 ``` <android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <!-- 主界面内容 --> <FrameLayout android:id="@+id/content_frame" android:layout_width="match_parent" android:layout_height="match_parent" /> <!-- 侧菜单 --> <android.support.design.widget.NavigationView android:id="@+id/navigation_view" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_gravity="start" android:fitsSystemWindows="true" app:headerLayout="@layout/nav_header" app:menu="@menu/nav_menu" /> </android.support.v4.widget.DrawerLayout> ``` 2. 在Activity中设置DrawerLayout和NavigationView的监听器,并在onOptionsItemSelected方法中处理菜单项点击事件。 ``` public class MainActivity extends AppCompatActivity { private DrawerLayout mDrawerLayout; private NavigationView mNavigationView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mDrawerLayout = findViewById(R.id.drawer_layout); mNavigationView = findViewById(R.id.navigation_view); mNavigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() { @Override public boolean onNavigationItemSelected(@NonNull MenuItem item) { // 处理菜单项点击事件 return false; } }); ActionBarDrawerToggle toggle = new ActionBarDrawerToggle( this, mDrawerLayout, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close); mDrawerLayout.addDrawerListener(toggle); toggle.syncState(); } @Override public boolean onOptionsItemSelected(MenuItem item) { int id = item.getItemId(); if (id == android.R.id.home) { mDrawerLayout.openDrawer(GravityCompat.START); return true; } return super.onOptionsItemSelected(item); } } ``` 3. 在NavigationView中添加菜单项,并为菜单项设置图标和标题。 ``` <menu xmlns:android="http://schemas.android.com/apk/res/android"> <group android:checkableBehavior="single"> <item android:id="@+id/nav_home" android:icon="@drawable/ic_home" android:title="Home" /> <item android:id="@+id/nav_gallery" android:icon="@drawable/ic_gallery" android:title="Gallery" /> <item android:id="@+id/nav_slideshow" android:icon="@drawable/ic_slideshow" android:title="Slideshow" /> </group> </menu> ``` 至此,实现了一个简单的Android侧菜单。如果要实现仿QQ删除功能,可以在ListView或RecyclerView中添加删除的功能,并在删除时更新侧菜单中的未读消息数等信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值