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<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();
  } 

  /**
   * 删除某个消息
   *
   * @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<?> 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滑动弹出菜单标记已读、未读消息功能啦,希望大家喜欢。

(0)

相关推荐

  • Android实现类似于PC中的右键弹出菜单效果

    Android系统中的ContextMenu(上下文菜单)类似于PC中的右键弹出菜单,当一个视图注册到一个上下文菜单时,执行一个在该对象上的"长按"动作,将出现一个提供相关功能的浮动菜单.上下文菜单可以被注册到任何视图对象中,不过,最常见的是用于列表视图ListView的item,在按中列表项时,会转换其背景色而提示将呈现上下文菜单.  注意:上下文菜单不支持图标和快捷键. 为了创建一个上下文菜单,你必须重写这个活动的上下文菜单回调函数:onCreateContextMenu() 和

  • android自定义popupwindow仿微信右上角弹出菜单效果

    微信右上角的操作菜单看起来很好用,就照着仿了一下,不过是旧版微信的,手里刚好有一些旧版微信的资源图标,给大家分享一下. 不知道微信是用什么实现的,我使用popupwindow来实现,主要分为几块内容: 1.窗口布局文件:popwin_share.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com

  • Android ListView长按弹出菜单二种实现方式示例

    复制代码 代码如下: /** * 知识点1:ListView item:两种长按弹出菜单方式* 知识点2:ListView SimpleAdapter的使用* 知识点 3:在java代码中创建一个ListView*/ public class ListOnLongClickActivity extends Activity {         private LinearLayout myListViewlayout;         private ListView mListView;   

  • Android中微信小程序开发之弹出菜单

    先给大家展示下效果图,具体效果图如下所示: 具体代码如下所示: 1.index.js //index.js //获取应用实例 var app = getApp() Page({ data: { isPopping: false,//是否已经弹出 animationPlus: {},//旋转动画 animationcollect: {},//item位移,透明度 animationTranspond: {},//item位移,透明度 animationInput: {},//item位移,透明度

  • Android之用PopupWindow实现弹出菜单的方法详解

    在使用UC-WebBrowser时,你会发现它的弹出菜单跟系统自带的菜单不一样.它实现更多菜单选项的显示和分栏.其实,它的本身是PopupWindow或者是AlertDialog对话框,在里面添加两个GridView控件,一个是菜单标题栏,一个是菜单选项.菜单选项视图的切换可以通过适配器的变换,轻松地实现.点击下载该实例:一.运行截图:           二.实现要点:(1)屏蔽系统弹出的菜单:1.首先创建至少一个系统的菜单选项 复制代码 代码如下: @Override public bool

  • Android使用Activity实现从底部弹出菜单或窗口的方法

    本文实例讲述了Android使用Activity实现从底部弹出菜单或窗口的方法.分享给大家供大家参考,具体如下: 这里使用activity实现弹出滑动窗口或菜单,主要是使用了一些设置activity的样式来实现弹出窗口和滑动效果,实现如下: 第一步:设计要弹出窗口的xml布局: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://sche

  • Android实现底部弹出按钮菜单升级版

    本文实例为大家分享了Android实现底部弹出按钮菜单的具体代码,在Android实现底部缓慢弹出菜单的升级,供大家参考,具体内容如下 只贴出关键代码 case R.id.myself_share: //我的分享 getShareMune(); getShareMune() private void getShareMune() { final Dialog mdialog = new Dialog(getActivity(), R.style.photo_dialog); mdialog.se

  • Android PopupWindow实现右侧、左侧和底部弹出菜单

    本教程为大家分享了Android PopupWindow弹出菜单的具体代码,供大家参考,具体内容如下 项目代码:http://xiazai.jb51.net/201611/yuanma/PopupLeftMenu(jb51.net).rar 项目SDK是5.1,建议将代码拷到自己的工程中去 代码如下: MainActivity类: package com.example.popupleftmenu; import android.app.Activity; import android.cont

  • android popwindow实现左侧弹出菜单层及PopupWindow主要方法介绍

    PopupWindow可以实现浮层效果,主要方法有:可以自定义view,通过LayoutInflator方法:可以出现和退出时显示动画:可以指定显示位置等. 为了将PopupWindow的多个功能展现并力求用简单的代码实现,编写了一个点击按钮左侧弹出菜单的功能,实现出现和退出时显示动画效果并点击其他区域时弹出层自动消失,效果图如下: 源码: 1.PopwindowOnLeftActivity.java 复制代码 代码如下: package com.pop.main; import android

  • 简单实现Android弹出菜单效果

    本文实例为大家分享了Android弹出菜单效果的具体代码,供大家参考,具体内容如下 功能描述:用户单击按钮弹出菜单.当用户选择一个菜单项,会触发MenuItemClick事件并让弹出的菜单消失:如果用户在菜单外单击,则直接消失弹出的菜单.当菜单消失时,会引发DismissEvent事件(利用此事件可在菜单消失时做一些后续处理). 1.运行效果 2.添加菜单项 在Resources文件夹下添加一个menu子文件夹,然后在此子文件夹下添加一个名为demo07_popup_menu.xml的文件: <

随机推荐