安卓开发课程设计报告.docx

上传人:b****8 文档编号:29342456 上传时间:2023-07-22 格式:DOCX 页数:25 大小:186.31KB
下载 相关 举报
安卓开发课程设计报告.docx_第1页
第1页 / 共25页
安卓开发课程设计报告.docx_第2页
第2页 / 共25页
安卓开发课程设计报告.docx_第3页
第3页 / 共25页
安卓开发课程设计报告.docx_第4页
第4页 / 共25页
安卓开发课程设计报告.docx_第5页
第5页 / 共25页
点击查看更多>>
下载资源
资源描述

安卓开发课程设计报告.docx

《安卓开发课程设计报告.docx》由会员分享,可在线阅读,更多相关《安卓开发课程设计报告.docx(25页珍藏版)》请在冰豆网上搜索。

安卓开发课程设计报告.docx

安卓开发课程设计报告

武汉理工大学华夏学院

课程报告

课程名称:

智能手机软件开发

题目:

基于Android的手机通

讯录的设计与实现

指导教师

信息工程系

2015年3月23日至2015年6月12日

智能手机软件开发大作业

根据所学的Android手机开发的知识,采旺clipse、JAVA开发一个基于Android平台的手机通讯录软件,具体要求如下:

1.要发该软件能够在Android4.0以上的平台上运行。

2.要求软件界面美观,操作方便,符合日常使用规范。

3.能够通过该手机通讯录来添加新的联系人,用来存放联系人的姓名、单位、电话、QQ地址等信息。

4.能够通过该手机通讯录来编辑联系人信息,来修改联系人的个人信息。

5.能够通过该手机通讯录来调用系统的通信接口,直接给用户发短信,打电话。

6.在手机通讯录中,添加合适的菜单,来操作手机通讯录。

7.将开发的过程写成报告,要求内容完整,格式规范,条理清晰。

1设计目的

随着手机通讯录功能的不断加强与完善,手机通讯录对于人们的意义,已不仅仅像记事簿一样显示通讯地址,而是向着个性化、人性化的方向发展移动终端的应用软件和需要的服务将会有很大的发展空间。

根据这个特点,设计一个基于Android平台的通讯录系统,能根据手机的特点,存储,管理,修改联系人信息,并且能够根据选定的联系人,对其拨打电话,发送短信等。

手机通讯录作为手机的基本功能之一,每天我们都在频繁地使用着。

根据手机功能使用调查显示,通讯录从无到有,从英文到中文,经过了十几年的发展历程,今后的发展趋势就是从通讯录发展为名片夹,也就是在一个人名下,可以存储座机、手机、单位、地址、电子邮件等内容。

所以手机通讯录功能越来越齐全,满足了人们的需求。

2开发环境

由于该android通讯录是一个基于Java语言开发软件,所以选择了Eclipse3.4作为开发平台,作为插件,它能够安装AndroidSDK从而可以安装使用Android虚拟机,使得程序得以开发,亦更为方便。

本通讯录系统就是在Eclipse3.4+Android平台环境下编写设计而成的。

3需求分析

该系统针对的主要用户是Android手机用户。

Android手机通信管理系统包括以下主要内容:

(1)用户通过联系人功能可以保存联系人的详细信息,可以对联系人进行编辑、删除、拨打电话、发送短信可以根据索引条件搜索联系人。

(2)用户通过短信记录功能可以发送短信,删除短信记录。

(3)用户通过SD卡所储存信息向通讯录批量导入联系人信息。

(4)用户通过个人中心可以设置自己的详细信息,这样方便其他人了解自己,也可以将具有相同名字的联系人合并。

要设计一个良好的手机通讯录,就必须首先明确该应用环境对系统的要求。

Android手机通讯录应用背景:

方便用户快捷通讯。

(1)类似于传统手机通讯录的联系人的添加、修改、查找、删除功能。

(2)指定联系人后,录音并发送给该联系人的留言功能。

(3)通过通讯录访问联系人的微博以实现与联系人互动的功能。

(4)接收短信、电话、语音留言和微博留言的信息并提醒用户。

(5)保存用户自身的个人信息以用于与他人联系时显示身份。

4概要设计

下面数据流图是对于Android手机通讯管理软件主要功能模块包括的简单结构图:

联系人查看、联系人编辑、联系人添加、联系人删除、呼叫、发送短信、搜索,如图所示:

图4.1Android手机通讯管理软件主要功能模块

联系人列表界面主菜单中包括添加联系人、搜索联系人、关于及查看系统版本号、退出菜单项。

点击添加联系人,则进入联系人添加界面,添加成功后返回列表界面。

点击搜索菜单,则进入联系人搜索界面,输入联系人的全名或一个字,即可查找相关联系人,点击联系人会进入联系人查看界面,可以对联系人进行编辑、删除、拨打电话、发送短信。

如下图所示的Android手机通讯管理软件业务流程图•

图4.2Android手机通讯管理软件业务流程图

5数据库设计

5.1SQLite数据库简介

SQLite,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。

它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如Tel、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。

SQLite第一个Alpha版本诞生于2000年5月.至今已经有10个年头,SQLite也迎来了一个版本SQLite3已经发布。

本系统采用的是Android系统自带的SQLite轻型数据库数据库。

因此占用资源非常小。

5.2数据库表结构

首先创建数据库,在数据库中创建表用来存储联系人数据,其中包括联系人姓名、手机号、QQ地址等联系方式。

6详细设计与实现

6.1联系人浏览模块

6.1.1进入首界面,显示联系人列表。

点击某个联系人会进入查看联系人界面,可以查看联系人的详细信息,对联系人进行编辑、删除、拨打电话发送短信等。

截图所示:

<1

图6.1.1通讯录联系人列表模块界面

6.1.2点击菜单按钮时,就会显示添加、查找、关于和退出功能。

如果点击退出菜单,则会退出该软件。

如图所示:

图6.1.2通讯录主菜单项模块

6.1.3长按菜单显示Android手机通讯截图如图所示:

图6.1.3通讯录联系人界面菜单模块

6.2查看联系人模块6.2.1在联系人界面点中击某个联系人,则会跳转到该界面。

该软件实现了给联系人拨打电话和发送短信的功能。

查看联系人界面截图如图所示:

图6.2手机通讯查看联系人模块界面

6.3编辑联系人模块

6.3.1联系人编辑界面设置了返回列表菜单和删除联系人菜单。

点击返回列表菜单,会返回到联系人浏览界面。

编辑联系人界面如图所示:

12平;

 

图6.3手机通讯录编辑联系人界面模块

6.4查找联系人模块

查找到所有包含该部分的联系人,并在ListView中显示出来所有的联系人的姓

名和手机号码,截图如图所示:

 

图6.4通讯录查找联系人模块界面

7总结

这学期的智能手机开发课程的学习,让我了解到手机开发端应用的广泛性,以及对自己所学知识的总结,做手机通讯录,让我了解到手机已经成为日常生活中不可分割的一部分,所以手机上的功能满足人们的需求,才是手机通讯录开的重要性。

对于这次的课程设计,使我发现了自己所掌握的知识是真正如此的缺乏,自己综合应用所学的专业知识能力是如此的不足通过这次开发项目,我们学会了如何在一个项目中集成多种技术,如何合理的耦合各种小功能,如何解决各种开发中出现的问题。

同时在这次开发中出现的问题也暴露出了我们对java程序设

计的一些问题,以及自己的动手能力还需要提高,而且做一个项目首先要明白这个项目的中心思想,这样才有目的去设计。

通过课程设计,使我深深体会到,干任何事都必须耐心,细致,课程设计过程中,许多迷惑有时不免令我感到有些心烦意乱,有几次因为不小心而出错,只能毫不情意地重来。

但一想起老师对我们耐心的教导,认真对待的良好习惯•这

次课程设计使我在工作作风上得到了一次难得的磨练,一个人的性格很大程度上决定一件事情的进展以及对工作的态度和生活的态度,所以养成好的习惯能够帮助我克服各种苦难,能够帮助我在今后的学习中脚踏实地的工作。

通过这次手机开发通讯录课程设计,我能够更加深刻的了解到手机通讯录开发的前景以及所需的知识,总之在今后的学习中自己应该了解如今社会上开发手机通讯录所需的最新的技术,不能一成不变,只看书本上的知识,养成自我学习的良好习惯。

参考文献

[1]罗伟•基于Android平台的即时通讯系统的研究与实现[D].湖南师范大学,2009

[2]李刚,《疯狂Java讲义》电子工业出版社,2008

[3]程峰,《JAVA核心技术》,机械工业出版社,2007

[4]王鹏,《JAVA语言程序设计》,大连理工出版社,2005

9附录源代码

publicclassDBHelper

{

/*

*操作数据库和各个表

*/

publicstaticfinalStringDATABASE_NAME="CONTACT_DB";

publicstaticfinalStringTABLE_CONTACTER="contact_person";

publicstaticfinalStringTABLE_MOBLIEPHONE="phone_number";

publicstaticfinalStringTABLE_GROUP="mygroup";

publicstaticfinalStringTABLE_EMAIL="email";

publicstaticfinalStringTABLE_QQ="qq";

publicstaticfinalStringTABLE_HOMEPHONE="home_phone_number";

publicstaticfinalStringTABLE_ADDRESS="address";

publicstaticfinalStringTABLE_FAX="fax";

//创建表的SQL语句

publicstaticString[]CreateTabelSQL;

privatestaticSQLiteDatabasedbInstance;

publicstaticfinalintVERSION=4;

privateMyDBHelpermyDBHelper;

privateContextcontext;

publicDBHelper(Contextcontext,String[]createtablesql)

{this.context=context;this.CreateTabelSQL=createtablesql;

}

publicDBHelper(Contextcontext)

{this.context=context;

}

/**

*打开数据库

*/

publicvoidopenDatabase()

{

if(dbInstance==null)

{

//创建数据库

VERSION);

myDBHelper=newMyDBHelper(context,DATABASE_NAME,dbInstance=myDBHelper.getWritableDatabase();

}

/**

*返回所有联系人

*/

publicArrayList>getAllContacter(Stringcondition){

ArrayList>contaclist=newArrayList();Cursorcursor;

if(condition==null||condition.trim().equals(""))cursor=dbInstance.query(TABLE_CONTACTER,newString[]{"id","name","headImage"},null,null,null,null,null);

else{

StringBuffersqlBuffer=newStringBuffer();sqlBuffer.append("selectid,name,headImagefrom").append(TABLE_CONTACTER).append("wherenamelike'%").append(condition).append("%'");

cursor=dbInstance.rawQuery(sqlBuffer.toString(),null);}

cursor.moveToFirst();while(!

cursor.isAfterLast())

{

HashMapitem=newHashMap();item.put("contacter_id",cursor.getInt(cursor.getColumnIndex("id")));item.put("name",cursor.getString(cursor.getColumnIndex("name")));item.put("headimage",cursor.getString(cursor.getColumnIndex("headImage")));//返回第一个手机电话号码

CursorphoneCursor=dbInstance.query(TABLE_MOBLIEPHONE,

newString[]{"phone_number"},"id=?

",new

String[]{String.valueOf(cursor.getInt(cursor.getColumnIndex("id")))},

null,null,null);phoneCursor.moveToFirst();

item.put("phonenumber",

phoneCursor.getString(phoneCursor.getColumnIndex("phone_number")));

contaclist.add(item);

cursor.moveToNext();

}

returncontaclist;

}

/**

*根据编号返回一个联系人

*/

publicContactergetContacter(intid)

{

Contactercontacter=newContacter();

CursorcontacterCursor=dbInstance.query(TABLE_CONTACTER,

new

String[]{"id","group_name","name","nick_name","birthday","workingunits","headImage"},

"id=?

",

newString[]{String.valueOf(id)},null,null,null);

contacter.id=id;

contacterCursor.moveToFirst();

contacter.name=contacterCursor.getString(contacterCursor.getColumnIndex("name"));contacter.nickname=contacterCursor.getString(contacterCursor.getColumnIndex("nick_name"));contacter.workingunits=contacterCursor.getString(contacterCursor.getColumnIndex("workingunits"));

if(contacterCursor.getString(contacterCursor.getColumnIndex("birthday")).trim()!

=null

&&!

contacterCursor.getString(contacterCursor.getColumnIndex("birthday")).trim().equals(""))

{

Stringstring=contacterCursor.getString(contacterCursor.getColumnIndex("birthday")).trim();

contacter.birthday=Date.valueOf(contacterCursor.getString(contacterCursor.getColumnIndex("birthday")));

}

contacter.headimage=contacterCursor.getInt(contacterCursor.getColumnIndex("headImage"));

//联系人的手机号码

CursorphoneCursor=dbInstance.query(TABLE_MOBLIEPHONE,

newString[]{"phone_number"},

"id=?

",

newString[]{String.valueOf(id)},null,null,null);

phoneCursor.moveToFirst();

contacter.mobilephone=newString[phoneCursor.getCount()];

for(inti=0;i

{

contacter.mobilephone[i]=phoneCursor.getString(phoneCursor.getColumnIndex("phone_number"));

phoneCursor.moveToNext();

}

//联系人的座机号码

CursorhomephoneCursor=dbInstance.query(TABLE_HOMEPHONE,

newString[]{"home_number"},

"id=?

",

newString[]{String.valueOf(id)},null,null,null);

homephoneCursor.moveToFirst();

contacter.homephonenumber=newString[homephoneCursor.getCount()];for(inti=0;i

{

contacter.homephonenumber[i]=homephoneCursor.getString(homephoneCursor.getColumnIndex("home_number"));

homephoneCursor.moveToNext();

}

//联系人的email

CursoremailCursor=dbInstance.query(TABLE_EMAIL,

newString[]{"email"},

"id=?

",newString[]{String.valueOf(id)},null,null,null);

emailCursor.moveToFirst();

contacter.email=newString[emailCursor.getCount()];for(inti=0;i

{contacter.email[i]=emailCursor.getString(emailCursor.getColumnIndex("email"));emailCursor.moveToNext();

}

//联系人的传真号码

CursorfaxCursor=dbInstance.query(TABLE_FAX,newString[]{"fax_number"},

"id=?

",

newString[]{String.valueOf(id)},null,null,null);contacter.faxnumber=newString[emailCursor.getCount()];faxCursor.moveToFirst();

for(inti=0;i

{

contacter.faxnumber[i]=faxCursor.getString(faxCursor.getColumnIndex("fax_number"));faxCursor.moveToNext();

}

//联系人的地址

CursoraddressCursor=dbInstance.query(TABLE_ADDRESS,

newString[]{"add_code","province","city","street","zip_code","country"},

"id=?

",

newString[]{String.valueOf(id)},null,null,null);

addressCursor.moveToFirst();contacter.addresses=newaddress[addressCursor.getCount()];

for(inti=0;i

{contacter.addresses[i]=newaddress();

contacter.addresses[i].add_code=addressCursor.getInt(addressCursor.getColumnIndex("add_code"));

contacter.addresses[i].province=addressCursor.getString(addressCursor.getColumnIndex("province"));

contacter.addresses[i].city=addressCursor.getString(addressCursor.getColumnIndex("city"));

contacter.addresses[i].street=addressCursor.getString(addressCursor.getColumnIndex("street"));

contacter.addresses[i].zip_code=addressCursor.getString(addressCursor.getColumnIndex("zip_code"));

contacter.addresses[i].coutry=addressCursor.getString(addressCursor.getColumnIndex("country"));

addressCursor.moveToNext();

}

returncontacter;

}

/*

*自动生成联系人编码

*/

publicintgenerateContacterID()

{

Cursorcursor=dbInstance.query(TABLE_CONTACTER,

newString[]{"id"},null,null,null,null,null);cursor.moveToFirst();

inti=0;if(curso

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 解决方案 > 工作计划

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1