Android实训案例(五)——四大组件之一ContentProvider的使用,通讯录的实现以及ListView的优化
Android实训案例(五)——四大组件之一ContentProvider的使用,通讯录的实现
Android四大组件是啥这里就不用多说了,看图吧,他们之间通过intent通讯
我们后续也会一一的为大家讲解,今天就使用内容提供者ContentProvider查询系统的数据库来获取联系人,我们用listview装载
我们新建一个项目就叫MyPhone吧
并且添加权限
<uses-permission android:name="android.permission.READ_CONTACTS"/>
一,获取联系人
我们可以新建一个Class——GetPhone,这样吧,我们先在手机里创建两个联系人
GetPhone
package com.lgl.myphone;
import android.content.Context;
import android.database.Cursor;
import android.provider.ContactsContract;
import android.util.Log;
/**
* 获取手机联系人
* Created by LGL on 2016/1/24.
*/
public class GetPhone {
//获取通讯录的方法
public static String getPhone(Context context) {
/**
* 1.系统给了我们一个接口访问
* 2.3.4.5也是查询条件,这我们并不需要
* 并且返回一个Cursor类型的参数
*/
Cursor query = context.getContentResolver().query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, null, null, null);
//创建一个对象进行储存
String name; //联系人
String phone; //电话号码
//我们获取到这些信息之后遍历出来
while (query.moveToNext()) {
//获取名字就需要Phone.DISPLAY_NAME
name = query.getString(query.getColumnIndex(ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME));
//获取num字段需要Phone.NUMBER
phone = query.getString(query.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
Log.i("字段", name + ":" + phone);
}
return null;
}
}
然后我们只要在MainActivity中调用就可以了
//调用查询
GetPhone.getPhone(this);
运行一下
也是成功的打印出来了
二,数据存储
我们既然要用到这些读取出来的数据,就需要先把这些数据给存储起来,我们新建一个Class类——Bean,声明一个name和一个phone,并且生成他们的set和get方法
package com.lgl.myphone;
/**
* 数据存储
* Created by LGL on 2016/1/24.
*/
public class Bean {
private String name;
private String phone;
public Bean(String name, String phone) {
setName(name);
setPhone(phone);
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
}
这样的话我们就可以去封装了,这里封装也是很简单,直接在GetPhone这个类里面声明一个list集合
public static List<Bean>list = new ArrayList<Bean>();
然后我们可以将这个写数据装载起来
Bean bean = new Bean(name,phone);
list.add(bean);
三,实现自定义Adapter
考虑到这个项目的扩展性,我们的adapter一般都是自己实现继承BaseAdapter,今天,我们也来实现以下,并且放几张头像上去
ListAdapter
package com.lgl.myphone;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.RelativeLayout;
import android.widget.TextView;
import java.util.List;
/**
* Created by LGL on 2016/1/24.
*/
public class ListAdapter extends BaseAdapter {
private List<Bean> list;
//承接上下文
private Context context;
private RelativeLayout layout;
//构造方法
public ListAdapter(List<Bean> list, Context context) {
this.list = list;
this.context = context;
}
//返回的是集合的数量,大小
@Override
public int getCount() {
return list.size();
}
//返回当前这条数据
@Override
public Object getItem(int position) {
return list.get(position);
}
//获取当前的ID
@Override
public long getItemId(int position) {
//id和position是相等的
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
/**
* 我们要获取当前视图的View并且加载到视图当中
*/
LayoutInflater inflater = LayoutInflater.from(context);
layout = (RelativeLayout) inflater.inflate(R.layout.list_item, null);
TextView tv_name = (TextView) layout.findViewById(R.id.tv_name);
TextView tv_phone = (TextView) layout.findViewById(R.id.tv_phone);
//添加内容
tv_name.setText(list.get(position).getName());
tv_phone.setText(list.get(position).getPhone());
return layout;
}
}
接着我们使用就可以了,在MainActivity中
//初始化listview
listview = (ListView) findViewById(R.id.listview);
listAdapter = new ListAdapter(GetPhone.list,this);
listview.setAdapter(listAdapter);
运行一下,就知道效果了
四,ListView的优化ViewHolder
事实上,listview的优化已经见怪不怪了,当我们的通讯录需要加载几千条数据的时候,我们就有必要的进行一些优化了,那就是使用viewholder
package com.lgl.myphone;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.RelativeLayout;
import android.widget.TextView;
import java.util.List;
/**
* Created by LGL on 2016/1/24.
*/
public class ListAdapter extends BaseAdapter {
private List<Bean> list;
//承接上下文
private Context context;
private RelativeLayout layout;
//构造方法
public ListAdapter(List<Bean> list, Context context) {
this.list = list;
this.context = context;
}
//返回的是集合的数量,大小
@Override
public int getCount() {
return list.size();
}
//返回当前这条数据
@Override
public Object getItem(int position) {
return list.get(position);
}
//获取当前的ID
@Override
public long getItemId(int position) {
//id和position是相等的
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
/**
* 我们要获取当前视图的View并且加载到视图当中
*/
// LayoutInflater inflater = LayoutInflater.from(context);
// layout = (RelativeLayout) inflater.inflate(R.layout.list_item, null);
//
// TextView tv_name = (TextView) layout.findViewById(R.id.tv_name);
// TextView tv_phone = (TextView) layout.findViewById(R.id.tv_phone);
//
// //添加内容
// tv_name.setText(list.get(position).getName());
// tv_phone.setText(list.get(position).getPhone());
ViewHolder holder;
//==null代表并没有记载view
if (convertView == null) {
convertView = LayoutInflater.from(context).inflate(R.layout.list_item, null);
holder = new ViewHolder();
holder.tv_name = (TextView) convertView.findViewById(R.id.tv_name);
holder.tv_phone = (TextView) convertView.findViewById(R.id.tv_phone);
//加载内容
holder.tv_name.setText(list.get(position).getName());
holder.tv_phone.setText(list.get(position).getPhone());
//第一次加载完毕后标签储存
convertView.setTag(holder);
} else {
//代表加载过了
holder = (ViewHolder) convertView.getTag();
//加载内容
holder.tv_name.setText(list.get(position).getName());
holder.tv_phone.setText(list.get(position).getPhone());
}
return convertView;
}
private static class ViewHolder {
TextView tv_name;
TextView tv_phone;
}
}
这样子就可以数据量再大也不会出现卡顿的现象了
弱弱的说一句:今天的深圳真冷啊
Demo下载地址:http://download.csdn.net/detail/qq_26787115/9416163
Android实训案例(五)——四大组件之一ContentProvider的使用,通讯录的实现以及ListView的优化的更多相关文章
- Android实训案例(六)——四大组件之一BroadcastReceiver的基本使用,拨号,短信,SD卡,开机,应用安装卸载监听
Android实训案例(六)--四大组件之一BroadcastReceiver的基本使用,拨号,短信,SD卡,开机,应用安装卸载监听 Android中四大组件的使用时重中之重,我这个阶段也不奢望能把他 ...
- Android实训案例(八)——单机五子棋游戏,自定义棋盘,线条,棋子,游戏逻辑,游戏状态存储,再来一局
Android实训案例(八)--单机五子棋游戏,自定义棋盘,线条,棋子,游戏逻辑,游戏状态存储,再来一局 阿法狗让围棋突然就被热议了,鸿洋大神也顺势出了篇五子棋单机游戏的视频,我看到了就像膜拜膜拜,就 ...
- Android实训案例(四)——关于Game,2048方块的设计,逻辑,实现,编写,加上色彩,分数等深度剖析开发过程!
Android实训案例(四)--关于Game,2048方块的设计,逻辑,实现,编写,加上色彩,分数等深度剖析开发过程! 关于2048,我看到很多大神,比如医生,郭神,所以我也研究了一段时间,还好是研究 ...
- Android实训案例(九)——答题系统的思绪,自己设计一个题库的体验,一个思路清晰的答题软件制作过程
Android实训案例(九)--答题系统的思绪,自己设计一个题库的体验,一个思路清晰的答题软件制作过程 项目也是偷师的,决心研究一下数据库.所以写的还是很详细的,各位看官,耐着性子看完,实现结果不重要 ...
- Android实训案例(三)——实现时间轴效果的ListView,加入本地存储,实现恋爱日记的效果!
Android实训案例(三)--实现时间轴效果的ListView,加入本地存储,实现恋爱日记的效果! 感叹离春节将至,也同时感叹时间不等人,一年又一年,可是我依然是android道路上的小菜鸟,这篇讲 ...
- Android实训案例(二)——Android下的CMD命令之关机重启以及重启recovery
Android实训案例(二)--Android下的CMD命令之关机重启以及重启recovery Android刚兴起的时候,着实让一些小众软件火了一把,切水果,Tom猫,吹裙子就是其中的代表,当然还有 ...
- Android实训案例(一)——计算器的运算逻辑
Android实训案例(一)--计算器的运算逻辑 应一个朋友的邀请,叫我写一个计算器,开始觉得,就一个计算器嘛,很简单的,但是写着写着发现自己写出来的逻辑真不严谨,于是搜索了一下,看到mk(没有打广告 ...
- Android实训案例(七)——四大组件之一Service初步了解,实现通话录音功能,抽调接口
Service Service的神奇之处,在于他不需要界面,一切的操作都在后台操作,所以很多全局性(手机助手,语音助手)之类的应用很长需要这个,我们今天也来玩玩 我们新建一个工程--ServiceDe ...
- Android实训案例(七)——四大组件之中的一个Service初步了解,实现通话录音功能,抽调接口
Service Service的奇妙之处.在于他不须要界面,一切的操作都在后台操作,所以非常多全局性(手机助手,语音助手)之类的应用非常长须要这个.我们今天也来玩玩 我们新建一个project--Se ...
随机推荐
- [python]mysql数据缓存到redis中 取出时候编码问题
描述: 一个web服务,原先的业务逻辑是把mysql查询的结果缓存在redis中一个小时,加快请求的响应. 现在有个问题就是根据请求的指定的编码返回对应编码的response. 首先是要修改响应的bo ...
- 通过JNDI从服务器容器中获取资源_Spring JNDI+Mysql+Tomcat
通过JNDI从服务器容器中获取DataSource资源 (由容器管理,不要关闭它,容器自己会处理)上一篇我们使用的是dbcp,这里使用JNDI: 使用JNDI连接数据: 在Spring可以注释 < ...
- DBoW2应用
图像对应的bag-of-words向量\(v_t\) 假设词典总共有\(W\)个单词,那么每一幅图像能够用一个\(W\)维的向量表示 \((t_1, t_2, t_3, ..., t_W)\)其中 \ ...
- UNIX环境高级编程——初始化一个守护进程
#include <stdio.h> #include <stdlib.h> #include <signal.h> #include <unistd.h&g ...
- 在javascript里 string 和 int 类型转换
string 转换为int 类型 (1)tostring()方法 var x=10 a = x.toString() //输出为string类型 alert(typeof(a)); ...
- Cocos2D实现RPG队伍菜单任意调整角色顺序的效果
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 前一篇我们实现了队伍实现拖尾效果,但是在实际游戏中我们往往需要 ...
- Redis简介以及数据类型存储
由于我们在大型互联网项目当中,用户访问量比较大,比较多,会产生并发问题,对于此,我们该如何解决呢,Redis横空出世,首先,我们来简单的认识一下Redis,详细介绍如下所示: Redis是一个开源的, ...
- 【OpenGL】理解一些基本问题
写在前面 啦啦啦,搞了很久的Unity Shaders,越学越觉得基础知识很重要.学Unity Shader的时候,总会想,shader到底是什么呢?shader的pipeline是什么呢?它们是怎么 ...
- 如何判断webview是不是滑到底部
getScrollY()方法返回的是当前可见区域的顶端距整个页面顶端的距离,也就是当前内容滚动的距离. getHeight()或者getBottom()方法都返回当前webview这个容器的高度 ge ...
- Dubbo粗浅记录
这篇博客只是我自己的学习记录,对各位高手怕是没有什么太大的帮助,望高手不吝赐教. 项目的截图如下: 我们使用的主要就是红框里面的. 这里我主要分析两个xml /DubboTest/src/main/r ...