好文档 - 专业文书写作范文服务资料分享网站

Android开发实验 - 通讯录 - 图文

天下 分享 时间: 加入收藏 我要投稿 点赞

实验报告

通讯录

姓名: 学号: 课程名称: 所在学院: 专业班级: 任课教师:

移动应用开发 信息科学与工程学院

计算机

实验项目名称 通讯录 一、实验目的与要求: 目的:练习掌握 Android 软件开发基本编程技术、Android 系统 SQLite 数据库的使用、通话、短信的使用等,设计制作一 Android 通讯录软件。 要求: (1)每位同学独立设计软件功能、完成软件的开发与测试。 (2)软件完成后由任课教师检查、提问软件功能、软件的设计和开发的代码。(3)每位同学独立完成实验报告(包括学号、姓名,实验目的、实验内容、软件功能、设计思想、实验总结等),并将实验报告和开发软件的工程文件压缩包提交任课教师。 二、实验设备及软件: 一台电脑,Androidstudio2.3.3软件 三、实验方法(原理、流程图) 实现的通讯录功能和界面可在实验开发中由每位同学自己设计,但必须使用 SQLite 数据库保存通讯录信息。 以下功能和软件界面供参考:仿照一般手机通讯录的使用界面和功能,主要功能可包括: (1)可以添加、删减联系人 (2)联系人的信息包括:姓名、手机号码、工作单位、群组、电子邮件、手机铃声 (3)选择联系人后,可以快速进行操作,如:拨打电话发送短信、查看详细、移出群组、移动分组、删除联系人等。查看详细时显示手机号码、群组、和设定的手机铃声以及同该联系人的通话记录。 (4)在联系人界面,可以查看各群组。点击群组,跳出对应联系人。 (5)有拨号键盘,点击数字将号码显示出来,并可以对手机号码进行删减 (6)可以发送信息,显示信息记录 (7)发送信息时,可以快速选择现有联系人。 四、实验过程、步骤及内容 通讯录界面要求布局合理简约,颜色舒,控制按钮简单明了,让用户一眼就能看出各个按钮的作用及操方法。能实要求的功能,但又不重复。要考到不同手机屏幕大小可能不一样,应尽兼容大多数手机屏幕尺寸,使之显示无障碍。 实现思路与简单设计 1. 关于通讯录获取联系人信息以及联系人信息的存储结构的分析。 2. 解决添加联系人的表中添加数据以及读取已保存的数据 3. 实现通讯录的基本功能的具体实现。 4. 对通讯录界面的具体设计,给人一种方便的操作通道。 5. 灵活应用各种系统库函数实现完整的通讯录。 开发流程图: 主要功能分析: 1、 增加、删除、编联系人 点击通信录界面中的增加按钮,入增加联系人面。输入联系人的基本信息,并可根据用户需求增加个性化信息如头像、姓名、手机号码、办室电话、家庭电话、职务职称、单位名称、地址、邮政编码、Email、其他联系方式、备注这些信息,击确认返回主界面。点击通信录中一个已存在的联系人,进入联系人编辑界面,可修改系人的资料或进行删除联系人操作,完成后退回到主界面。对列表中联系人的标记,点mnu键弹出功能界面上的删除按键也可进行删除。还可以在菜单上选择删除全部联系人清空通讯录。在删除联系人的过程中,系统将提示用户是否继续操作,若放弃操作,则系人信息将继续保存。 2、查找联系人 用户点击menu键打开底部菜单框,底部菜单框为查询系人提供入口,进入通讯录的缺省页面为联系人列表,在列表中看到所有联系人的姓名、电话息排列,用户点击查找按键输入联系人基本信息,,通讯录显所有符合查询条件的联系人列表,用户选择一个联系人进入联系人基本信息页面进行其他操作;查询完成,用户按返回键返回主界面。 3、通功能 用户在通录选择联系人进入联系详细信息界面,这时点击menu键打开通信功能框,选择打电话、发信息的功能进行操作。 4、菜单能 通过对menu按的点击,显示底部菜框,包含有增加查找、除、菜单、返回功能,菜单按键则包含显示所有、删除所有等实用功能。 增加联系人: 这个功能由ContactAdder类完成,具体实现不是比较麻烦,保存动作由ContentResolver类解决,但实现方式有所不同,可分为一次性批量增加与挨个增加。 由于界面设置繁琐,代码页过多,所以挑出其中的一部分进行说明 首先是DB数据库建库过程: package com.xample.hivian.my_contact_manager.models.db; import android.content.ContentValues; import android.database.Cursor; import android.database.sqlite.SQLiteOpenHelper; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import com.example.hivian.my_contact_manager.models.Contact; import com.example.hivian.my_contact_manager.models.Sms; import java.util.ArrayList; import java.util.List; public class DBHandlerextends SQLiteOpenHelper {// Database Version private static final intDB_VERSION = 1;// Database Name private static final String DB_NAME = \;// Contacts table name private static final String CONTACTS_TABLE = \;//通讯录

private static final String SMS_TABLE = \;// Shops Table Columns names private static final String KEY_ID = \;

private static final String KEY_IMAGE = \;//图片 private static final String KEY_NAME = \;//姓名 private static final String KEY_PHONE = \;//电话号码 private static final String KEY_EMAIL = \;//邮箱

private static final String KEY_ADDRESS = \;//联系人地址 private static final String KEY_SMS_HEADER = \; private static final String KEY_SMS_CONTENT = \; private static final String KEY_CONTACT_ID = \; private static final String KEY_SMS_TYPE = \; private static final String CONTACTS_TABLE_CREATE =

\+ CONTACTS_TABLE + \+ KEY_ID + \+

KEY_IMAGE + \+ KEY_NAME + \+ KEY_PHONE + \+ KEY_EMAIL + \+ KEY_ADDRESS + \;

private static final String SMS_TABLE_CREATE =

\+ SMS_TABLE + \+ KEY_ID + \+

KEY_SMS_HEADER + \+ KEY_SMS_CONTENT + \+ KEY_CONTACT_ID + \+ KEY_SMS_TYPE + \;

private static DBHandlerdbInstance= null;

public static DBHandlergetInstance(Context context) { if (dbInstance== null) {

dbInstance= new DBHandler(context, DB_NAME, DB_VERSION);

}

return dbInstance; }

DBHandler(Context context, String dbName, intdbVersion) { super(context, dbName, null, dbVersion); } @Override

public void onCreate(SQLiteDatabasedb) { db.execSQL(CONTACTS_TABLE_CREATE); db.execSQL(SMS_TABLE_CREATE); }

@Override

public void onUpgrade(SQLiteDatabasedb, intoldVersion, intnewVersion) {

// Drop older table if existed db.execSQL(\+ CONTACTS_TABLE);

db.execSQL(\+ SMS_TABLE);

// 重新创建表 onCreate(db); }

//新增联系人 public void addContact(Contact contact) { SQLiteDatabasedb = this.getWritableDatabase(); ContentValues values = new ContentValues();

values.put(KEY_IMAGE, contact.getImage()); values.put(KEY_NAME, contact.getName()); values.put(KEY_PHONE, contact.getPhone()); values.put(KEY_EMAIL, contact.getEmail()); values.put(KEY_ADDRESS, contact.getAddress()); db.insert(CONTACTS_TABLE, null, values); }

// Adding new sms public void addSms(Smssms) {

SQLiteDatabasedb = this.getWritableDatabase(); ContentValues values = new ContentValues();

values.put(KEY_SMS_HEADER, sms.getHeader()); values.put(KEY_SMS_CONTENT, sms.getContent()); values.put(KEY_CONTACT_ID, sms.getContactId()); values.put(KEY_SMS_TYPE, sms.getType()); db.insert(SMS_TABLE, null, values); }

// Getting one contact public Contact getContact(intid) {

SQLiteDatabasedb = this.getReadableDatabase();

Cursor cursor = db.query(CONTACTS_TABLE, new String[]

{ KEY_ID, KEY_IMAGE, KEY_NAME, KEY_PHONE, KEY_EMAIL, KEY_ADDRESS },

KEY_ID + \, new String[] { String.valueOf(id) }, null, null, null, null);

if (cursor != null) cursor.moveToFirst();

Contact contact = new Contact(cursor.getBlob(1), cursor.getString(2), cursor.getString(3), cursor.getString(4), cursor.getString(5)); contact.setId(cursor.getInt(0)); cursor.close(); return contact; }

// Getting one contact by name public Contact getContactByName(String name) { SQLiteDatabasedb = this.getReadableDatabase();

Android开发实验 - 通讯录 - 图文

实验报告通讯录姓名:学号:课程名称:所在学院:专业班级:任课教师:移动应用开发信息科学与工程学院计算机实验项目名称通讯录一、实验目的与要求:目的:练习掌握Android软件开发基本编程技术
推荐度:
点击下载文档文档为doc格式
3rmqm4a8jr5dq8n1sig30fluh9boav00uiv
领取福利

微信扫码领取福利

微信扫码分享