热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

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

这篇文章主要介绍了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; 
 
/** 
 * my msgs list adapter 
 */ 
public class MyMsgAdapter extends BaseAdapter { 
 
  private Activity mContext; 
 
  private LayoutInflater mInflater; 
 
  private List mDatas; 
 
  public MyMsgAdapter(Activity context, List 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 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 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(); 
  } 
 
  /** 
   * 删除某个消息 
   * 
   * @param position 
   */ 
  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(); 
    } 
  } 
 
  /** 
   * 标记已读和未读 
   * 
   * @param position 
   */ 
  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<&#63;> 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开发效率:Clean Code的最佳实践与应用
    在Android开发中,提高代码质量和开发效率是至关重要的。本文介绍了如何通过Clean Code的最佳实践来优化Android应用的开发流程。以SQLite数据库操作为例,详细探讨了如何编写高效、可维护的SQL查询语句,并将其结果封装为Java对象。通过遵循这些最佳实践,开发者可以显著提升代码的可读性和可维护性,从而加快开发速度并减少错误。 ... [详细]
  • 本文探讨了如何有效地构建和优化微信公众平台账号,涵盖了用户信息管理、内容创作与发布、互动策略及数据分析等方面。通过合理设置用户信息字段,如用户名、昵称、密码、真实姓名和性别等,确保账号的安全性和用户体验。同时,文章还介绍了如何利用微信公众平台的各项功能,提升用户参与度和品牌影响力。 ... [详细]
  • 掌握这些技巧,轻松获取超过90%的资源信息
    在数字时代,高效获取所需资源是每个人必备的技能。本文将分享一系列实用技巧,帮助读者轻松获取超过90%的网络资源信息,无论是学术资料、技术文档还是最新资讯,都能迅速找到。通过优化搜索引擎使用、利用专业数据库和社群资源等方法,读者将能够在信息海洋中游刃有余。 ... [详细]
  • CSS3 @font-face 字体应用技术解析与实践
    在Web前端开发中,HTML教程和CSS3的结合使得网页设计更加多样化。长期以来,Web设计师受限于“web-safe”字体的选择。然而,CSS3中的`@font-face`规则允许从服务器端加载自定义字体,极大地丰富了网页的视觉效果。通过这一技术,设计师可以自由选择和使用各种字体,提升用户体验和页面美观度。本文将深入解析`@font-face`的实现原理,并提供实际应用案例,帮助开发者更好地掌握这一强大工具。 ... [详细]
  • 经过短暂的休整,我们再次推出新的小程序功能,进一步提升用户体验。现在,小程序页面不仅支持放置转发按钮,还新增了长按快速转发的功能,让用户能够更加便捷地分享页面内容。这一更新将为开发者提供更多创意空间,同时也大幅提升了用户的互动性和使用便利性。 ... [详细]
  • HTML 页面中调用 JavaScript 函数生成随机数值并自动展示
    在HTML页面中,通过调用JavaScript函数生成随机数值,并将其自动展示在页面上。具体实现包括构建HTML页面结构,定义JavaScript函数以生成随机数,以及在页面加载时自动调用该函数并将结果呈现给用户。 ... [详细]
  • 优化后的标题:利用 jQuery 实现高效树形结构元素选择与操作
    在Web前端开发中,DOM结构本质上是一种树形结构。通过优化后的jQuery选择器,可以高效地选择和操作DOM树中的节点。这些选择器不仅简化了代码编写,还提高了性能和可维护性。本文将详细介绍如何利用jQuery的树形选择器实现高效的元素选择与操作。 ... [详细]
  • 开源实习机会 | Compiler SIG 正式发布实习任务,诚邀您加入申请!
    对编译技术充满兴趣却苦于无从入手?当前疫情形势下,外出实习变得困难重重?现在,Compiler SIG 正式发布了一系列实习任务,为有志之士提供了宝贵的机会。无论你是初学者还是有一定基础的学生,都能在这里找到适合自己的实践项目。我们诚挚邀请您的加入,共同探索编译技术的无限可能! ... [详细]
  • Java 点餐系统源代码附带管理后台(免费提供)
    本项目提供了一套基于 Java 的点餐系统,包括前端小程序和后端管理平台。采用 Spring Boot 和 SSM 框架,结合 MySQL 和 Redis 数据库技术,适用于学习和二次开发。有需要源代码的开发者可以通过私信联系,免费获取下载链接。 ... [详细]
  • TensorFlow Lite在移动设备上的部署实践与优化笔记
    近期在探索如何将服务器端的模型迁移到移动设备上,并记录了一些关键问题和解决方案。本文假设读者具备以下基础知识:了解TensorFlow的计算图(Graph)、图定义(GraphDef)和元图定义(MetaGraphDef)。此外,文中还详细介绍了模型转换、性能优化和资源管理等方面的实践经验,为开发者提供有价值的参考。 ... [详细]
  • 移动搜索格局已定,切勿误解微信搜索的真正实力
    近期,微信新版本的内测界面曝光,新增了朋友圈搜索和附近商户搜索功能。种种迹象显示,微信正不断强化其搜索能力。尽管移动搜索市场格局已基本稳定,但不应低估微信搜索的潜力。微信不仅在聊天工具、移动浏览器和新闻阅读等领域持续发力,还在通过搜索功能进一步巩固其在移动互联网领域的地位。 ... [详细]
  • 大家好,全新的技术专栏《从零开始掌握容器云网络实战》正式上线。该专栏将系统地介绍容器云网络的基础知识、核心技术和实际应用案例,帮助读者全面理解和掌握容器云网络的关键技术与实践方法。 ... [详细]
  • 设计实战 | 10个Kotlin项目深度解析:首页模块开发详解
    设计实战 | 10个Kotlin项目深度解析:首页模块开发详解 ... [详细]
  • 如何高效地将微信收藏夹中的内容导出至外部设备或平台? ... [详细]
  • 本章节在上一章的基础上,深入探讨了如何通过引入机器人实现自动聊天、表情包回应以及Adidas官方账号的自动抽签功能。具体介绍了使用wxpy库进行微信机器人的开发,优化了智能回复系统的性能和用户体验。通过详细的代码示例和实践操作,展示了如何实现这些高级功能,进一步提升了机器人的智能化水平。 ... [详细]
author-avatar
手机用户2602909133
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有