Android原生应用Dialer--界面和数据库整体分析
2016-09-23 14:13
676 查看
下面的分析内容基于androidM
对于dialer这个应用我们从宏观的角度去观察,其实可以将它认为就是一个拨号盘,因为它的主要作用就是键入字符串,至于这个字符串的作用可以有很多种,比如:拨号、暗码、快速拨号等等,当然dialer还有其它的作用,比如:通话记录、通话相关设置、通话记录搜索等等一些细分的功能,这里我们先从一个宏观的角度去理解它,第一眼把它看简单才能有信心往后面继续分析下去。
data/data/com.android.dialer/databases/dialer.db
上图介绍了dialer里面主要的一些界面,当然还有一些隐藏的或者不太常见的界面没有列出来,大家可以通过AS等IDE工具或者通过AndroidManifest文件去查看其它相关的界面信息。
上图是dialer的主界面DialtactsActivity,图中通过不同颜色的矩形和类名简单的对主界面进行的划分,大家可以通过相同颜色的矩形和类型,将它们一一对应起来。
对于dialer的数据库,我们会重点介绍它的prefix_table、properties、smartdial_table这三张表里面的数据,因为dialer也只关心这三张表的数据。
这个表里最重要的就是prefix和contact_id这两列数据(废话除了id不就只剩下这两列了么。。)
其中prefix列主要包含了联系人的number,以及当我们在dialer里面搜索联系人名字时的快捷查找,查找规则为9键查找(即键盘为9键时候对于数组所代表的拼音),同时也支持数字查找匹配,即也可以通过号码查到对应的联系人。contact_id 列的数据代表这行数据属于哪个contacts,prefix中的数据是通过查找smartdial_table表中的数据得来的。
这个表很简单,只有两列property_key 显示数据库版本字符串,property_value 显示版本号,这个只要版本不升级,一般是不会变的。
这个表包含的信息比较多,但是大部分都可以从名字中得到它的含义,比较重要的几列我都在图片中标识出来了,这个表里面的数据是重contacts2.db数据库中读出来的,具体数据获取的流程如下:
到此dialer就简单介绍完了,单从界面和数据库分析,我们可以知道它其实就是一个很简单的应用,但是如果我们将它和系统其它的应用一起分析,这样就会涉及到一些细节,就会比较复杂一点点。
整体认识
对于dialer这个应用我们从宏观的角度去观察,其实可以将它认为就是一个拨号盘,因为它的主要作用就是键入字符串,至于这个字符串的作用可以有很多种,比如:拨号、暗码、快速拨号等等,当然dialer还有其它的作用,比如:通话记录、通话相关设置、通话记录搜索等等一些细分的功能,这里我们先从一个宏观的角度去理解它,第一眼把它看简单才能有信心往后面继续分析下去。
涉及到的目录:
android/packages/apps/Dialerdata/data/com.android.dialer/databases/dialer.db
整体UI结构
上图介绍了dialer里面主要的一些界面,当然还有一些隐藏的或者不太常见的界面没有列出来,大家可以通过AS等IDE工具或者通过AndroidManifest文件去查看其它相关的界面信息。
主界面展示
上图是dialer的主界面DialtactsActivity,图中通过不同颜色的矩形和类名简单的对主界面进行的划分,大家可以通过相同颜色的矩形和类型,将它们一一对应起来。
数据库分析
整体界面
对于dialer的数据库,我们会重点介绍它的prefix_table、properties、smartdial_table这三张表里面的数据,因为dialer也只关心这三张表的数据。
prefix_table表
这个表里最重要的就是prefix和contact_id这两列数据(废话除了id不就只剩下这两列了么。。)
其中prefix列主要包含了联系人的number,以及当我们在dialer里面搜索联系人名字时的快捷查找,查找规则为9键查找(即键盘为9键时候对于数组所代表的拼音),同时也支持数字查找匹配,即也可以通过号码查到对应的联系人。contact_id 列的数据代表这行数据属于哪个contacts,prefix中的数据是通过查找smartdial_table表中的数据得来的。
相关的代码如下:
public class LatinSmartDialMap implements SmartDialMap { private static final char[] LATIN_LETTERS_TO_DIGITS = { '2', '2', '2', // A,B,C -> 2 '3', '3', '3', // D,E,F -> 3 '4', '4', '4', // G,H,I -> 4 '5', '5', '5', // J,K,L -> 5 '6', '6', '6', // M,N,O -> 6 '7', '7', '7', '7', // P,Q,R,S -> 7 '8', '8', '8', // T,U,V -> 8 '9', '9', '9', '9' // W,X,Y,Z -> 9 };
数据生成的流程大致如下: DialerDatabaseHelper.insertNamePrefixes->SmartDialPrefix.generateNamePrefixes->SmartDialPrefix.parseToIndexTokens
properties表
这个表很简单,只有两列property_key 显示数据库版本字符串,property_value 显示版本号,这个只要版本不升级,一般是不会变的。
smartdial_table表
这个表包含的信息比较多,但是大部分都可以从名字中得到它的含义,比较重要的几列我都在图片中标识出来了,这个表里面的数据是重contacts2.db数据库中读出来的,具体数据获取的流程如下:
DialtactsActivity.onCreate的时候创建了数据库 ->DialtactsActivity.onResume->DialerDatabaseHelper.startSmartDialUpdateThread ->DialerDatabaseHelper.updateSmartDialDatabase 最终将部分数据copy到dialer.db中
到此dialer就简单介绍完了,单从界面和数据库分析,我们可以知道它其实就是一个很简单的应用,但是如果我们将它和系统其它的应用一起分析,这样就会涉及到一些细节,就会比较复杂一点点。
Dialer&Contacts
相关文章推荐
- Android 4.0应用界面设计分析
- Android开发—数据库应用—添加列表活动(ListActivity)--分析记事本程序
- 开启Android 4.3的原生的应用权限配置界面
- android原生browser分析(二)--界面篇
- android 原生应用、Web应用、混合应用优缺点分析
- android 原生应用、Web应用、混合应用优缺点分析
- android原生browser分析(二)--界面篇
- Android 4.0应用界面设计分析
- Android应用启动界面分析(Starting Window)
- Android 应用点击图标到Activity界面显示的过程分析
- android应用开发-从设计到实现 4-6界面的整体布局
- Android 应用点击图标到Activity界面显示的过程分析
- Android原生Contacts——界面和数据库
- 【Android 应用开发】 Application 使用分析
- Android引导界面的实现分析
- Android应用的界面编程
- Android Fragment应用实战(音乐播放器界面)
- Android开发笔记之Intent跳转到系统应用中的拨号界面、联系人界面、短信界面
- Android软键盘弹出,界面整体上移的问题
- Android中实现Activity的启动拦截之----实现360卫士的安装应用界面