简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

这篇具有很好参考价值的文章主要介绍了简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

提示:本篇文章将会尽量保持精简,同时请诸位敲写代码时保持耐心,三连是最大的支持!

文章目录

前言

一、项目介绍

二、使用步骤

1.创建程序

2.添加 recyclerview-v7 库

3.放置界面控件

4.搭建界面布局

5.封装实体类

6.编写数据适配器

7.实现显示界面数据功能

8.去掉默认标题栏,添加读取系统通讯录权限

9.运行程序

总结


前言

本篇文章将会介绍如何使用 Android studio 内容提供者 实现 “读取手机通讯录” 的项目,文章是经由本人实际编写过后得出,同时项目中的名称等如有冲突可自行更改。文章尽量保持精简,也请诸位保持耐心,且会加以图文解释,方便读者能够更佳观看。

配置:Android studio 2021.1.1.21 windows  简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人


一、项目介绍

本项目通过显示一个通讯录的界面,以列表的形式来显示 Android 设备通讯录中暴露的数据, 而 Android 便提供了一个组件 ContentProvider(内容提供者) 来充当一个 “中介” 的角色。具体有关 ContentProvider(内容提供者) 的细节在这就不再赘述。

二、使用步骤

1.创建程序

打开 Android studio,在 Android studio 创建一个新的应用程序,命名为 Contact ,指定包名为 com.itcast.contacts 。

2.添加 recyclerview-v7 库

因为我们通讯录界面将要使用到 RecyclerView 控件,以列表的形式展示,所以需要将拥有  RecyclerView 控件的 recyclerview-v7 库添加进程序。但是由于版本和补丁的更新,我们只需要在 Android 的 Gradle Scripts 下的 build.gradle(Module:Contact.app) 中填入一下代码

代码如下:

dependencies {
// 。。。。。
implementation 'androidx.recyclerview:recyclerview:1.0.0'
}

更为详细的说明可以移步到:简单步骤:解决 Android studio 2021.1.1 出现添加 “ recyclerview-v7 库 ”报错_蛇形刁手的博客-CSDN博客

3.放置界面控件

在 res/layout 文件夹的 activity_contact.xml 下放置一个 TextView控件 和 RecyclerView 控件来以列表的形式显示通讯录和其中联系人的信息。 

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

  代码如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#eaeaea"
    android:orientation="vertical">
    <TextView
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:background="#4889f4"
        android:gravity="center"
        android:text="通讯录"
        android:textColor="@android:color/white"
        android:textSize="20sp" />
    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/rv_contact"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_margin="5dp" />
</LinearLayout>

4.搭建界面布局

<1> 在 res/layout 文件夹下,创建布局文件 contact_item.xml , 编写界面控件。

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

 代码如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="5dp"
    android:background="@drawable/item_bg"
    android:orientation="horizontal"
    android:padding="8dp">
    <ImageView
        android:id="@+id/iv_photo"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:src="@drawable/contact_photo" />
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="60dp"
        android:layout_marginLeft="8dp"
        android:gravity="center_vertical"
        android:orientation="vertical">
        <TextView
            android:id="@+id/tv_name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textColor="@android:color/black"
            android:textSize="16sp" />
        <TextView
            android:id="@+id/tv_phone"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="6dp"
            android:textColor="@android:color/darker_gray"
            android:textSize="14sp" />
    </LinearLayout>
</LinearLayout>

<2> 导入图片

将通讯录界面所需要的图片 contact_photo.png 导入到 res/drewable 文件夹中。(如果文章会自动生成水印,那么推荐使用自己的图片)

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

图片如下:

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

<3> 创建条目界面的背景文件

在res/drewable 文件夹中创建 item_bg.xml文件设置条目背景。

代码如下:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="#ffffff" />
    <corners android:radius="8dp" />
</shape>

 5.封装实体类

在程序的 java/com.itcast.contacts 包下创建一个 ContactInfo 类,用来创建联系人信息的属性。

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

 代码如下:

package com.itcast.contacts;
public class ContactInfo {
    private String contactName;   //联系人名称
    private String phoneNumber;   //电话号码
    public String getContactName() {
        return contactName;
    }
    public void setContactName(String contactName) {
        this.contactName = contactName;
    }
    public String getPhoneNumber() {
        return phoneNumber;
    }
    public void setPhoneNumber(String phoneNumber) {
        this.phoneNumber = phoneNumber;
    }
}

6.编写数据适配器

在程序的 java/com.itcast.contacts 包下创建一个 ContactAdapter 类,由于我们使用了 RecyclerView 控件,所以就需要创建一个数据适配器,来对 RecyclerView 控件进行数据适配。

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

 代码如下:

package com.itcast.contacts;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;

import androidx.recyclerview.widget.RecyclerView;

import java.util.List;

public class ContactAdapter extends RecyclerView.Adapter<ContactAdapter
        .MyViewHolder>  {
    private Context mContext;
    private List<ContactInfo> contactInfoList;
    public ContactAdapter(Context context, List<ContactInfo> contactInfoList){
        this.mContext=context;
        this.contactInfoList=contactInfoList;
    }
    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        MyViewHolder holder = new MyViewHolder(
                LayoutInflater.from(mContext).inflate(
                        R.layout.contact_item, parent, false));
        return holder;
    }
    @Override
    public void onBindViewHolder(MyViewHolder holder, int position) {
        holder.tv_name.setText(contactInfoList.get(position).getContactName());
        holder.tv_phone.setText(contactInfoList.get(position).getPhoneNumber());
    }
    @Override
    public int getItemCount() {
        return contactInfoList.size();
    }
    class MyViewHolder extends RecyclerView.ViewHolder {
        TextView tv_name,tv_phone;
        ImageView iv_photo;
        public MyViewHolder(View view) {
            super(view);
            tv_name = view.findViewById(R.id.tv_name);
            tv_phone = view.findViewById(R.id.tv_phone);
            iv_photo = view.findViewById(R.id.iv_photo);
        }
    }
}

7.实现显示界面数据功能

在程序的 java/com.itcast.contacts 包下创建一个 ContactActivity 类, 来申请读取手机通讯录的权限,同时重写 onRequestPermissionsResult () 方法获取通讯录权限是否申请成功。

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

 代码如下:

package com.itcast.contacts;

import android.annotation.SuppressLint;
import android.content.pm.PackageManager;
import android.database.Cursor;
import android.os.Build;
import android.os.Bundle;
import android.provider.ContactsContract;
import android.widget.Toast;

import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;

import java.util.ArrayList;
import java.util.List;

public class ContactActivity extends AppCompatActivity {
    private ContactAdapter adapter;
    private RecyclerView rv_contact;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_contact);
        init();
    }
    private void setData(){
        List<ContactInfo> contactInfos=getContacts();
        adapter=new ContactAdapter(ContactActivity.this,contactInfos);
        rv_contact.setAdapter(adapter);
    }
    public List<ContactInfo> getContacts() {
        List<ContactInfo> contactInfos = new ArrayList<>();
        Cursor cursor = getContentResolver().query(ContactsContract.
                Contacts.CONTENT_URI, null, null, null, null);
        if (contactInfos!=null)contactInfos.clear();//清除集合中的数据
        while (cursor.moveToNext()) {
            @SuppressLint("Range") String id = cursor.getString(
                    cursor.getColumnIndex(ContactsContract.Contacts._ID));
            @SuppressLint("Range") String name = cursor.getString (cursor.getColumnIndex(ContactsContract.
                    Contacts.DISPLAY_NAME));
            @SuppressLint("Range") int isHas = Integer.parseInt(cursor.getString(cursor.getColumnIndex(
                    ContactsContract.Contacts.HAS_PHONE_NUMBER)));
            if (isHas > 0) {
                Cursor c = getContentResolver().query(ContactsContract.
                                CommonDataKinds.Phone.CONTENT_URI, null,
                        ContactsContract.CommonDataKinds.Phone.CONTACT_ID +
                                " = " + id, null, null);
                while (c.moveToNext()) {
                    ContactInfo info = new ContactInfo();
                    info.setContactName(name);
                    @SuppressLint("Range") String number = c.getString(c.getColumnIndex(ContactsContract.
                            CommonDataKinds.Phone.NUMBER)).trim();
                    number = number.replace(" ", "");
                    number = number.replace("-", "");
                    info.setPhoneNumber(number);
                    contactInfos.add(info);
                }
                c.close();
            }
        }
        cursor.close();
        return contactInfos;
    }
    private void init(){
        rv_contact=findViewById(R.id.rv_contact);
        rv_contact.setLayoutManager(new LinearLayoutManager(this));
        getPermissions();
    }
    String[] permissionList;
    public void getPermissions() {
        if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            permissionList = new String[]{"android.permission.READ_CONTACTS"};
            ArrayList<String> list = new ArrayList<String>();
            // 循环判断所需权限中有哪个尚未被授权
            for (int i = 0; i < permissionList.length; i++) {
                if (ActivityCompat.checkSelfPermission(this, permissionList[i])
                        != PackageManager.PERMISSION_GRANTED)
                    list.add(permissionList[i]);
            }
            if (list.size() > 0) {
                ActivityCompat.requestPermissions(this,
                        list.toArray(new String[list.size()]), 1);
            } else {
                setData();//后续创建该方法
            }
        } else {
            setData();  //后续创建该方法
        }
    }
    @Override
    public void onRequestPermissionsResult(int requestCode, String[] permissions,
                                           int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if (requestCode == 1) {
            for (int i = 0; i < permissions.length; i++) {
                if(permissions[i].equals("android.permission.READ_CONTACTS")
                        && grantResults[i] == PackageManager.PERMISSION_GRANTED){
                    Toast.makeText(this, "读取通讯录权限申请成功",
                            Toast.LENGTH_SHORT).show();
                    setData();//后续创建该方法
                }else{
                    Toast.makeText(this,"读取通讯录权限申请失败",
                            Toast.LENGTH_SHORT).show();
                }
            }
        }
    }

}

8.去掉默认标题栏,添加读取系统通讯录权限

<1> 在 AndroidManifest.xml 文件的 <application> 标签下修改标题栏,使标题栏更加美观。

<2> 因为我们需要使用到系统的通讯录,所以还要在 AndroidManifest.xml 文件中添加读取系统通讯录权限

<3> 同时解决可能会出现虚拟器运行后“ xxx has stopped"的错误,详细内容可以移步到:简单步骤:解决 Android studio 出现 “ xxx(项目名) has stopped ” 的错误_蛇形刁手的博客-CSDN博客

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

 代码如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="com.itcast.contacts">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/Theme.AppCompat.NoActionBar">
        <activity
            android:name=".ContactActivity"
            android:exported="true"
            tools:ignore="MissingClass">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
    <uses-permission android:name="android.permission.READ_CONTACTS" />
</manifest>

9.运行程序

第一次运行时,会弹出一个 “ Allow Contacts to access your contacts?” 窗口,有两个选项: “ ALLOW ” 表示允许读取 和 “ DENY ” 拒绝读取,我们点击允许读取。当第一次运行时,我们的通讯录界面是一片空白,需要我们在系统的通讯录输入联系人信息予以提供。重新切换到我们的通讯录界面后便会出现信息。

图文解释如下:

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人

简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人


总结

以上就是 Android studio 内容提供者 - 实现读取手机通讯录的具体操作,由于每个人的配置、编写习惯等等多种原因,如果在实际操作中出现问题,或者发现文章中的错误,也可以在评论区中发表出来,尽能所答,欢迎指点与建议。

如果感到有帮助!!!

编写不易,关注、三连是最大的支持!!!

欢迎建议,感谢支持!!!文章来源地址https://www.toymoban.com/news/detail-483200.html

到了这里,关于简单步骤:Android studio 内容提供者 - 实现建立手机通讯录界面,读取系统联系人的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • RpcProvider(rpc服务提供者)实现思路

    上一节说到,如何将一个本地服务发布成远程服务,但没有说明一个rpc框架怎么进行调用的,看看上节代码 现在实现的发布服务方,那么显然Login方法是rpc框架帮我们调用的,什么时候调用?当rpc客户端通过网络发送rpc调用请求之后,这边接收到rpc请求,解析请求然后调用发

    2024年02月14日
    浏览(29)
  • SpringCloud Eureka注册服务提供者(七)

    这里我们在原来的服务提供者项目 microservice-student-provider-1001  上面直接修改: dependency     groupIdorg.springframework.cloud/groupId     artifactIdspring-cloud-starter-eureka/artifactId /dependency dependency     groupIdorg.springframework.cloud/groupId     artifactIdspring-cloud-starter-config/artifactId /dependency eurek

    2024年02月09日
    浏览(31)
  • 【spring cloud学习】4、创建服务提供者

    注册中心Eureka Server创建并启动之后,接下来介绍如何创建一个Provider并且注册到Eureka Server中,再提供一个REST接口给其他服务调用。 首先一个Provider至少需要两个组件包依赖:Spring Boot Web服务组件和Eureka Client组件。如下所示: Spring Boot Web服务组件用于提供REST接口服务,Eure

    2024年02月11日
    浏览(29)
  • 服务提供者 Eureka + 服务消费者(Rest + Ribbon)实战

    Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负载均衡算法,将Netflix的中间层服务连接在一起。Ribbon客户端组件提供一系列完善的配置项如连接超时,重试等。简单来说,就是在配置文件中列出Load Balancer(简称LB)后面所有的机器,Ribbon会自动的帮助你基于某

    2024年02月04日
    浏览(27)
  • 记一次dubbo消费者注册失败找不到服务提供者问题

    项目分多套环境,其中一套环境重新部署时,频繁出现消费者找不到服务提供者的错误 经过多次重启后才有可能恢复正常,而其他环境并没有发现此问题 怀疑点: 1.消费者和服务提供者dubbo版本对不上 2.服务提供者没有注册上服务 3.注册中心有问题 逐一排查: 1.消费者和服

    2023年04月18日
    浏览(28)
  • SpringCloud学习笔记(三)_服务提供者集群与服务发现Discovery

    既然SpringCloud的是微服务结构,那么对于同一种服务,当然不可能只有一个节点,需要部署多个节点 架构图如下: 由上可以看出存在多个同一种服务提供者(Service Provider) 搭建服务提供者集群 1、参考:SpringCloud 快速入门搭建单机版的:Eureka Server、Service Provider、Service Con

    2024年02月11日
    浏览(29)
  • dubbo启动报错 java.lang.reflect.InvocationTargetException null 没有提供者没有消费者

    启动dubbo时,控制台报错信息如下。 打开dubbo的服务注册中心发现 在网上查找了一番,网上的说发众说飞云,有人说要保证提供者和消费者的包名一致,也有人说是ip的问题要在host里面配置, 后来经过一番仔细查找发现不对的地方了 服务提供者的主类上没有配置注解,这个

    2024年02月13日
    浏览(34)
  • CSDN博客批量查询质量分https://yma16.inscode.cc/请求超时问题(设置postman超时时间)(接口提供者设置了nginx超时时间)

    https://yma16.inscode.cc/ 查询别人的一下子就返回了,查询我自己的,1分钟还不返回,然后就显示超时了。。 一开始我还以为是这个开源项目本身的问题,设置了请求超时时间,我还给它改了超时时间,后来发现不是的。。。 本来是100000的,我给改成1000000了,我对js代码不熟,

    2024年02月12日
    浏览(34)
  • Android Studio 实现天气预报App (简单方便展示内容超多)

    🍅 文章末尾有获取完整项目源码方式 🍅 目录 前言 一、任务介绍 1.1 背景 1.2目的和意义 二、 实现介绍 视频演示 2.1 启动页实现 2.2注册页面实现 2.3 登陆页面实现 2.4 首页实现 2.5 城市管理列表页面实现                三、获取源码         在使用Android Studio开发

    2024年04月24日
    浏览(36)
  • Android Studio汉化教程/编辑器界面转换为中文(简单步骤)

    此方法很简单,只需要下载插件引入即可 前往下方链接,然后点击GET,Download对应版本(建议不要下载太新版本,不然会不兼容,可以下载Android Studio适应的版本) https://plugins.jetbrains.com/plugin/13710-chinese-simplified-language-pack---- 这里有适用的版本 然后解压刚刚下载的zip 打开设置

    2024年02月12日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包