我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android仿QQ滑动弹出菜单标记已读、未读消息

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android仿QQ滑动弹出菜单标记已读、未读消息

在上一篇《Android仿微信滑动弹出编辑、删除菜单效果、增加下拉刷新功能》里,已经带着大家学习如何使用SwipeMenuListView这一开源库实现滑动列表弹出菜单,接下来,将进一步学习,如何为不同的list item呈现不同的菜单,此处我们做一个实例:Android 高仿QQ滑动弹出菜单标记已读、未读消息,看下效果图:


1. 创建项目,并导入SwipeMenuListView类库

2. 创建消息实体bean:


public class Msg { 
  public int id; 
  public String title; 
  public String desc; 
  // false是未读;true是已读 
  public boolean isRead; 
  @Override 
  public String toString() { 
    return "Msg{" + 
        "id=" + id + 
        ", title='" + title + '\'' + 
        ", desc='" + desc + '\'' + 
        ", isRead=" + isRead + 
        '}'; 
  } 
} 

注: 通过isRead字段,我们区分菜单显示“设为已读”“设为未读”;

3. 创建列表显示的Adapter,重写其中的getItemViewType方法:


import android.app.Activity; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.BaseAdapter; 
import android.widget.ImageView; 
import android.widget.TextView; 
import java.util.List; 
 
public class MyMsgAdapter extends BaseAdapter { 
  private Activity mContext; 
  private LayoutInflater mInflater; 
  private List<Msg> mDatas; 
  public MyMsgAdapter(Activity context, List<Msg> datas) { 
    mContext = context; 
    mInflater = LayoutInflater.from(mContext); 
    mDatas = datas; 
  } 
  @Override 
  public int getCount() { 
    return (mDatas != null ? mDatas.size() : 0); 
  } 
  @Override 
  public Object getItem(int position) { 
    return (mDatas != null ? mDatas.get(position) : null); 
  } 
  @Override 
  public long getItemId(int position) { 
    return position; 
  } 
  @Override 
  public int getViewTypeCount() { 
    return 2; 
  } 
  @Override 
  public int getItemViewType(int position) { 
    Msg myMsg = mDatas.get(position); 
    boolean isRead = myMsg.isRead; 
    if (isRead) { 
      return 0; 
    } else { 
      return 1; 
    } 
  } 
  @Override 
  public View getView(final int position, View convertView, ViewGroup parent) { 
    ViewHolder holder = null; 
    if (convertView == null) { 
      // 下拉项布局 
      convertView = mInflater.inflate(R.layout.list_item_my_msg, null); 
      holder = new ViewHolder(); 
      holder.img_msg = (ImageView) convertView.findViewById(R.id.img_msg); 
      holder.text_msg_user_name = (TextView) convertView.findViewById(R.id.text_msg_user_name); 
      holder.text_msg_infos = (TextView) convertView.findViewById(R.id.text_msg_infos); 
      convertView.setTag(holder); 
    } else { 
      holder = (ViewHolder) convertView.getTag(); 
    } 
    final Msg myMsg = mDatas.get(position); 
    if (myMsg != null) { 
      if (myMsg.isRead) {//未读 
        holder.img_msg.setImageResource(R.mipmap.readed_msg_img); 
      } else { 
        holder.img_msg.setImageResource(R.mipmap.unread_msg_img); 
      } 
      holder.text_msg_user_name.setText(myMsg.title); 
      holder.text_msg_infos.setText(myMsg.desc); 
    } 
    return convertView; 
  } 
  class ViewHolder { 
    ImageView img_msg; 
    TextView text_msg_user_name; 
    TextView text_msg_infos; 
  } 
} 

注: 此处重写了父类中的getItemViewType方法,该方法中,我们根据Msg的isRead字段来判断返回值的是0还是1; 之后,我们将根据该返回值,来判断list item的菜单是何种类型!

4. 根据ItemViewType,创建滑动菜单:


import android.graphics.Color; 
import android.graphics.drawable.ColorDrawable; 
import android.os.Bundle; 
import android.support.v7.app.AppCompatActivity; 
import android.util.TypedValue; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.Toast; 
import com.apkfuns.logutils.LogUtils; 
import com.baoyz.swipemenulistview.SwipeMenu; 
import com.baoyz.swipemenulistview.SwipeMenuCreator; 
import com.baoyz.swipemenulistview.SwipeMenuItem; 
import com.baoyz.swipemenulistview.SwipeMenuListView; 
import java.util.ArrayList; 
import java.util.List; 
import butterknife.Bind; 
import butterknife.ButterKnife; 
import butterknife.OnItemClick; 
public class MainActivity extends AppCompatActivity { 
  // 方案列表 
  @Bind(R.id.listViewMyMsgs) 
  public SwipeMenuListView listViewMyMsgs; 
  private MyMsgAdapter msgAdapter; 
  // 消息集合 
  private List<Msg> msgs; 
  // 要删除的数据 
  private Msg dMsg; 
  // 要修改的数据 
  private int oPos; 
  private Msg oMyMsg; 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    ButterKnife.bind(this); 
    msgs = new ArrayList<Msg>(); 
    Msg msg1 = new Msg(); 
    msg1.id = 1; 
    msg1.title = "上邪"; 
    msg1.desc = "我欲与君相知,长命无绝衰"; 
    msg1.isRead = false; 
    Msg msg2 = new Msg(); 
    msg2.id = 2; 
    msg2.title = "爱在记忆中找你"; 
    msg2.desc = "如果可以恨你,全力痛恨你,连遇上亦要躲避"; 
    msg2.isRead = true; 
    msgs.add(msg1); 
    msgs.add(msg2); 
    msgAdapter = new MyMsgAdapter(this, msgs); 
    listViewMyMsgs.setAdapter(msgAdapter); 
    createMenu(); 
  } 
   
  private void deleteMsg(int position) { 
    // DoDeleteMsgRequest(String id,Handler mHandler, int reqCode) 
    dMsg = msgs.get(position); 
    if (dMsg != null) { 
      Toast.makeText(MainActivity.this, "删除 : " + dMsg, Toast.LENGTH_SHORT).show(); 
      msgs.remove(dMsg); 
      msgAdapter.notifyDataSetChanged(); 
    } 
  } 
   
  private void readMsg(int position) { 
    //DoReadMsgRequest(String id, String isRead, Handler mHandler, int reqCode) 
    oPos = position; 
    oMyMsg = msgs.get(position); 
    if (oMyMsg != null) { 
      msgs.get(position).isRead = !msgs.get(position).isRead; 
      msgAdapter.notifyDataSetChanged(); 
    } 
  } 
  private void createMenu() { 
    // step 1. create a MenuCreator 
    SwipeMenuCreator creator = new SwipeMenuCreator() { 
      @Override 
      public void create(SwipeMenu menu) { 
        switch (menu.getViewType()) { 
          case 0:// 未读 
            createMenu1(menu); 
            break; 
          case 1:// 已读 
            createMenu2(menu); 
            break; 
        } 
      } 
      private void createMenu1(SwipeMenu menu) { 
        SwipeMenuItem unreadItem = new SwipeMenuItem( 
            getApplicationContext()); 
        unreadItem.setId(1); 
        unreadItem.setBackground(new ColorDrawable(Color.parseColor("#555555"))); 
        unreadItem.setWidth(dp2px(90)); 
        unreadItem.setTitle("标为已读"); 
        unreadItem.setTitleSize(16); 
        unreadItem.setTitleColor(Color.parseColor("#FFFFFF")); 
        menu.addMenuItem(unreadItem); 
        SwipeMenuItem deleteItem = new SwipeMenuItem( 
            getApplicationContext()); 
        deleteItem.setId(0); 
        deleteItem.setBackground(new ColorDrawable(Color.parseColor("#EF4B3A"))); 
        deleteItem.setWidth(dp2px(90)); 
        deleteItem.setTitle("删除"); 
        deleteItem.setTitleSize(16); 
        deleteItem.setTitleColor(Color.parseColor("#FFFFFF")); 
        menu.addMenuItem(deleteItem); 
      } 
      private void createMenu2(SwipeMenu menu) { 
        SwipeMenuItem readedItem = new SwipeMenuItem( 
            getApplicationContext()); 
        readedItem.setId(2); 
        readedItem.setBackground(new ColorDrawable(Color.parseColor("#555555"))); 
        readedItem.setWidth(dp2px(90)); 
        readedItem.setTitle("标记未读"); 
        readedItem.setTitleSize(16); 
        readedItem.setTitleColor(Color.parseColor("#FFFFFF")); 
        menu.addMenuItem(readedItem); 
        SwipeMenuItem deleteItem = new SwipeMenuItem( 
            getApplicationContext()); 
        deleteItem.setId(0); 
        deleteItem.setBackground(new ColorDrawable(Color.parseColor("#EF4B3A"))); 
        deleteItem.setWidth(dp2px(90)); 
        deleteItem.setTitle("删除"); 
        deleteItem.setTitleSize(16); 
        deleteItem.setTitleColor(Color.parseColor("#FFFFFF")); 
        menu.addMenuItem(deleteItem); 
      } 
    }; 
    // set creator 
    listViewMyMsgs.setMenuCreator(creator); 
    // step 2. listener item click event 
    listViewMyMsgs.setOnMenuItemClickListener(new SwipeMenuListView.OnMenuItemClickListener() { 
      @Override 
      public boolean onMenuItemClick(int position, SwipeMenu menu, int index) { 
        SwipeMenuItem menuItem = menu.getMenuItem(index); 
        int id = menuItem.getId(); 
        switch (id) { 
          case 0: 
            LogUtils.e("删除 :" + position); 
            deleteMsg(position); 
            break; 
          case 1: 
            LogUtils.e("标记未读 :" + position); 
            readMsg(position); 
            break; 
          case 2: 
            LogUtils.e("标为已读 :" + position); 
            readMsg(position); 
            break; 
        } 
        return false; 
      } 
    }); 
  } 
  @OnItemClick(R.id.listViewMyMsgs) 
  public void onItemClick(AdapterView<?> parent, View view, int position, 
              long id) { 
    Msg myMsg = (Msg) parent.getAdapter().getItem( 
        position); 
    if (myMsg != null) { 
      if (myMsg.isRead) { // 如果是未读,需要标记为已读 
        readMsg(position); 
      } 
    } 
  } 
  private int dp2px(int dp) { 
    return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, dp, 
        getResources().getDisplayMetrics()); 
  } 
} 

注:着重看下SwipeMenuCreator接口中的public void create(SwipeMenu menu)方法,通过menu.getViewType()方法,我们可以得到该list item的viewType,而这个viewType,使我们刚刚在Adapter自己定义的,所以此时,只需要判断自己所定义的viewType值,并根据viewType来创建菜单即可!

如此这般,便可实现类似QQ滑动弹出菜单标记已读、未读消息功能啦,希望大家喜欢。

您可能感兴趣的文章:Android实现顶部导航菜单左右滑动效果Android滑动优化高仿QQ6.0侧滑菜单(滑动优化)Android仿微信滑动弹出编辑、删除菜单效果、增加下拉刷新功能Android实现自定义滑动式抽屉效果菜单android RecyclerView侧滑菜单,滑动删除,长按拖拽,下拉刷新上拉加载Android程序开发之使用Design包实现QQ动画侧滑效果和滑动菜单导航Android模仿美团顶部的滑动菜单实例代码Android侧滑菜单和轮播图之滑动冲突问题Android解决viewpager嵌套滑动冲突并保留侧滑菜单功能Android实现上下菜单双向滑动效果


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android仿QQ滑动弹出菜单标记已读、未读消息

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android仿QQ滑动弹出菜单标记已读、未读消息

在上一篇《Android仿微信滑动弹出编辑、删除菜单效果、增加下拉刷新功能》里,已经带着大家学习如何使用SwipeMenuListView这一开源库实现滑动列表弹出菜单,接下来,将进一步学习,如何为不同的list item呈现不同的菜单,此
2022-06-06

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录