您的位置:首页 > 移动开发 > Android开发

Android原生应用Dialer--界面和数据库整体分析

2016-09-23 14:13 676 查看
下面的分析内容基于androidM

整体认识



对于dialer这个应用我们从宏观的角度去观察,其实可以将它认为就是一个拨号盘,因为它的主要作用就是键入字符串,至于这个字符串的作用可以有很多种,比如:拨号、暗码、快速拨号等等,当然dialer还有其它的作用,比如:通话记录、通话相关设置、通话记录搜索等等一些细分的功能,这里我们先从一个宏观的角度去理解它,第一眼把它看简单才能有信心往后面继续分析下去。

涉及到的目录:

android/packages/apps/Dialer

data/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

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: