Android通讯录开发之删除功能的实现方法

 更新时间:2014年01月16日 16:23:19   作者:  
这篇文章主要介绍了Android通讯录开发之删除功能的实现方法,有需要的朋友可以参考一下

无论是Android开发或者是其他移动平台的开发,ListView肯定是一个大咖,那么对ListView的操作肯定是不会少的,上一篇博客介绍了如何实现全选和反选的功能,本篇博客介绍删除功能,删除列表中的项无谓就是及时刷新列表,这又跟UI线程扯上关系了,还是那句话,数据的更新通知一定要在UI线程上做,不然会出现各种错误,比如出现adapter数据源改变,但没有及时收到通知的情况。在执行遍历删除的时候,最好不要每删一个就直接通知,下面是我的实现方法,将需要删除的contact保存到一个List然后通过handler发生消息,然后再由handler来处理。

这里我顺带提一下菜单的实现
1、定义menu下的xml文件

复制代码 代码如下:

<menu xmlns:android="http://schemas.android.com/apk/res/android" >

    <group android:id="@+id/metting_menu" >
        <item
            android:id="@+id/select_all_item"
            android:icon="@drawable/select_all_not"
            android:title="全选">
        </item>
        <item
            android:id="@+id/delete_item"
            android:icon="@drawable/delete"
            android:title="删除">
        </item>
        <item
            android:id="@+id/sync_item"
            android:icon="@drawable/sync_manage"
            android:title="同步">
        </item>
    </group>

</menu>


icon为菜单图标
title为菜单文本
2. 代码实现
复制代码 代码如下:

/**
  * 创建菜单
  */
 @Override
 public boolean onCreateOptionsMenu(Menu menu) {
  MenuInflater inflater = getMenuInflater();
  inflater.inflate(R.menu.meetting_contact_menu, menu);
  selectAllItem = menu.findItem(R.id.select_all_item);
  return true;
 }

 // 当用户打开菜单的时候触发
 @Override
 public boolean onMenuOpened(int featureId, Menu menu) {
  if (menu != null) {
   refreshSelectAllItemIcon();
  }
  return super.onMenuOpened(featureId, menu);
 }

 /**
  * menu的点击事件
  */
 @Override
 public boolean onOptionsItemSelected(MenuItem item) {
  switch (item.getItemId()) {
  case R.id.select_all_item:
   if (isAllChecked) { // 反选
    item.setIcon(R.drawable.select_all_not);
    invertSelection();
   } else { // 全选
    if (contactList.size() == 0) {
     Toast.makeText(this, "目前没有可选的联系人", Toast.LENGTH_SHORT)
       .show();
     break;
    }
    item.setIcon(R.drawable.select_all);
    selectAllContacts();
   }
   break;
  case R.id.delete_item: // 删除
   if (count == 0) {
    Toast.makeText(this, "您还没有选择任何联系人", Toast.LENGTH_SHORT).show();
    break;
   }
   showDeleteDialog(this, "您确定要删除吗");
   isAllChecked = false;
   selectAllItem.setIcon(R.drawable.select_all_not);
   break;
  case R.id.sync_item:
   Intent fresh_intent = new Intent(this, CloudSyncActivity.class);
   if (flag) {// 如果是会议
    fresh_intent.putExtra("number", meetingNumber);
   }
   startActivityForResult(fresh_intent, CLOUD_SYNC);
   break;
  default:
   break;
  }
  return false;
 }

 // 刷新菜单项全选
 private void refreshSelectAllItemIcon() {
  for (String contactId : map_NumberSelected.keySet()) {
   if (!map_NumberSelected.get(contactId)) {
    isAllChecked = false;
    selectAllItem.setIcon(R.drawable.select_all_not);
    break;
   }
   isAllChecked = true;
   selectAllItem.setIcon(R.drawable.select_all);
  }
 }


提示删除的对话框
复制代码 代码如下:

/** 显示确认删除对话框 **/
 public void showDeleteDialog(Context context, String msg) {
  final Dialog dialog = new Dialog(context, R.style.MyDialog);
  View view = LayoutInflater.from(context).inflate(R.layout.back_dialog,
    null);
  TextView msg_tv = (TextView) view.findViewById(R.id.msg);
  msg_tv.setText(msg);
  Button sure = (Button) view.findViewById(R.id.sure);
  Button cancle = (Button) view.findViewById(R.id.cancle);
  dialog.setContentView(view);
  sure.setOnClickListener(new OnClickListener() {
   @Override
   public void onClick(View v) {
    deleteContacts();
    dialog.dismiss();
   }
  });
  cancle.setOnClickListener(new OnClickListener() {

   @Override
   public void onClick(View v) {
    dialog.dismiss();
   }
  });
  dialog.show();
 }


下面是删除操作:
这里只关注实现删除的脉路,其中有些代码是业务逻辑需要可以稍微看一下就可以了
复制代码 代码如下:

 // 删除选中的联系人
 public void deleteContacts() {
  DialogHelp.getInstance().showHttpDialog(this, R.string.wait_for_while,
    getString(R.string.deleting_contact));
  new Thread() {
   @Override
   public void run() {
    ArrayList<Contact> deleteContacts = new ArrayList<Contact>();
    for (Contact contact : contactList) {
     boolean isselected = map_NumberSelected
       .get(contact.getId());
     if (isselected) {
      for (RawContact rawContact : rawList) {
       if (contact.getUserId() == rawContact.getUserId()) { // 是同一个id
        if (contact.getNumber() == rawContact
          .getPhone1()) {
         rawContact.setPhone1(null);
        } else if (contact.getNumber() == rawContact
          .getPhone2()) {
         rawContact.setPhone2(null);
        } else if (contact.getNumber() == rawContact
          .getTelephone()) {
         rawContact.setTelephone(null);
        }
        if ((rawContact.getPhone1() == null || ""
          .equals(rawContact.getPhone1()))
          && (rawContact.getPhone2() == null || ""
            .equals(rawContact.getPhone2()))
          && (rawContact.getTelephone() == null || ""
            .equals(rawContact
              .getTelephone()))) {
         MyDataBase.deleteContact(
           MeetingContactActivity.this,
           rawContact);
        } else {
         MyDataBase.updateContactById(
           MeetingContactActivity.this,
           rawContact);
        }
        break;
       }
      }
      // 将需要删除的联系人保存下来
      deleteContacts.add(contact);
     }
    }
    Message msg = new Message();
    msg.obj = deleteContacts;
    msg.what = DELETE_COMPLETE;
    handler.sendMessage(msg);
   };
  }.start();

 }


deleteContacts是用来保存需要删除的联系人,把它赋给msg.obj,再通过handler将消息放入消息队列,最终在handler的handleMessage方法进行删除操作。


handler处理代码:
这里把传递过来list在contactList遍历删除,然后在msg.what为DELETE_COMPLETE的分支进行通知列表刷新。

复制代码 代码如下:

private Handler handler = new Handler() {
  @Override
  public void handleMessage(Message msg) {
   if (msg.obj != null) {
    ArrayList<Contact> deleteContacts = (ArrayList<Contact>) msg.obj;
    for (Contact contact : deleteContacts) {
     map_NumberSelected.remove(contact.getId());
     contactList.remove(contact);
    }
   }
   switch (msg.what) {
   case LOAD_CONTACT_FINISHED:
    // 判断是否为空
    if (contactList == null || contactList.size() == 0) {
     syncLayout.setVisibility(View.VISIBLE);
     bottomLayout.setVisibility(View.GONE);
     listView.setVisibility(View.GONE);
    } else {
     syncLayout.setVisibility(View.GONE);
     bottomLayout.setVisibility(View.VISIBLE);
     listView.setVisibility(View.VISIBLE);
    }
    adapter.setContactList(contactList);
    refreshList();
    DialogHelp.getInstance().dismissDialog();
    break;
   case CLOUD_SYNC: // 同步
    initContacts();
    refreshList();
    break;
   case SEARCH_FINISH:
    refreshList();
    break;
   case DELETE_COMPLETE: // 删除完毕
    DialogHelp.getInstance().dismissDialog();
    // 重新初始化
    refreshList();
    break;
   }
  }
 };

以上就是删除功能的全部实现了,关于通讯录模块开发博客可能会暂停更新,比如想字母索引,联系人分组等功能我还没去实现,以后有机会会继续分享。

相关文章

  • Android文件读写的几种方式

    Android文件读写的几种方式

    文件读写作为Android四大数据存储方式之一,又分为内部存储和外部存储两种,下面这篇文章主要给大家介绍了关于Android文件读写的几种方式,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-06-06
  • Android获取设备CPU核数、时钟频率以及内存大小的方法

    Android获取设备CPU核数、时钟频率以及内存大小的方法

    这篇文章主要介绍了Android获取设备CPU核数、时钟频率以及内存大小的方法,涉及Android针对系统硬件相关操作技巧,需要的朋友可以参考下
    2016-07-07
  • flutter 路由跳转的实现示例

    flutter 路由跳转的实现示例

    这篇文章主要介绍了flutter 路由跳转的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Android自定义View实现波浪动画

    Android自定义View实现波浪动画

    这篇文章主要为大家详细介绍了Android自定义View实现波浪动画,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • Android实现页面滑动切换动画

    Android实现页面滑动切换动画

    这篇文章主要为大家详细介绍了Android实现页面滑动切换动画,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • Android基于Pull方式解析xml的方法详解

    Android基于Pull方式解析xml的方法详解

    这篇文章主要介绍了Android基于Pull方式解析xml的方法,结合实例形式详细分析了Pull方式解析xml的原理、操作步骤与相关技巧,需要的朋友可以参考下
    2016-07-07
  • Android开启新线程播放背景音乐

    Android开启新线程播放背景音乐

    这篇文章主要为大家详细介绍了Android开启新线程播放背景音乐,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • android layout 按比例布局的代码

    android layout 按比例布局的代码

    android layout 按比例布局的代码,需要的朋友可以参考一下
    2013-03-03
  • Android后端服务器的搭建方法

    Android后端服务器的搭建方法

    本篇文章主要介绍了Android后端服务器的搭建方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • Android简易电话拨号器实例详解

    Android简易电话拨号器实例详解

    这篇文章主要为大家详细介绍了Android简易电话拨号器实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07

最新评论