第一次实验Android界面设计一.实验目的及实验环境1.实验目的1)掌握SQLiteOpenHelper类结构2)掌握基于SQLite数据库的应用开发过程3)掌握ContentProvider发布数据的方法4)掌握ContentResolver获取数据的方法2.实验环境系统开发平AndroidStudio3.0系统开发平台:Android7.1运行平台:Windows10x64运行环境:Microsoft.NETFrameworkSDK2.0二.实验教材、组织方式、实验内容1.实验教材:Andorid开发与应用2.组织方式:个人独立完成2.实验内容:实现基于SQLite数据库的通信录应用,通过单击增加图标打开添加通信录界面,通过单击通信录中的各条信息可删除选中项。三.方案设计Android系统中集成了SQLite数据库,并且为数据库的操作提供了相关的类和方法,便于没有数据库开发经验的开发者编写程序。另外,Android平台中利用ContentProvider机制来实现跨应用程序数据共享。一个应用程序可以通过ContentProvider来发布自己的数据,其他的应用程序可以通过ContentResolver来获取共享数据。四.运行结果五.总结通过这次实验掌握了SQLiteOpenHelper类结构,掌握了基于SQLite数据库的应用开发过程以及ContentProvider发布数据的方法和掌握ContentResolver获取数据的方法。六.附录:源代码主布局文件activity_main.xml:LinearLayoutxmlns:android=:id=@+id/titleandroid:layout_width=wrap_contentandroid:layout_height=wrap_contentandroid:text=通信录/ListViewandroid:id=@+id/listViewandroid:layout_width=wrap_contentandroid:layout_height=wrap_content/ListViewButtonandroid:layout_width=wrap_contentandroid:layout_height=wrap_contentandroid:onClick=add//LinearLayout添加联系人布局文件addrelation.xml:?xmlversion=1.0encoding=utf-8?LinearLayoutxmlns:android=:layout_width=match_parentandroid:layout_height=match_parentandroid:orientation=verticalTextViewandroid:layout_width=wrap_contentandroid:layout_height=wrap_contentandroid:text=姓名/EditTextandroid:id=@+id/addNameandroid:layout_width=wrap_contentandroid:layout_height=wrap_content/TextViewandroid:layout_width=wrap_contentandroid:layout_height=wrap_contentandroid:text=电话/EditTextandroid:id=@+id/addTelandroid:layout_width=wrap_contentandroid:layout_height=wrap_content/TextViewandroid:layout_width=wrap_contentandroid:layout_height=wrap_contentandroid:text=所属组/Spinnerandroid:id=@+id/addGroupandroid:layout_width=wrap_contentandroid:layout_height=wrap_contentandroid:entries=@array/test/SpinnerButtonandroid:id=@+id/saveandroid:layout_width=wrap_contentandroid:layout_height=wrap_contentandroid:layout_gravity=centerandroid:text=保存//LinearLayout主Activity文件MainActivity.java:importandroid.support.v7.app.ActionBarActivity;importandroid.app.AlertDialog;importandroid.app.Application;importandroid.content.DialogInterface;importandroid.content.Intent;importandroid.database.Cursor;importandroid.os.Bundle;importandroid.view.Menu;importandroid.view.MenuItem;importandroid.view.View;importandroid.widget.AdapterView;importandroid.widget.ListView;importandroid.widget.SimpleCursorAdapter;publicclassMainActivityextendsActionBarActivity{privateListViewlistView;protectedvoidonCreate(BundlesavedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);listView=(ListView)findViewById(R.id.listView);//getRelationFromDB();}privatevoidgetRelationFromDB(){finalDatabaseHelperdbHelper=newDatabaseHelper(this);Cursorcursor=dbHelper.query();String[]from={_id,name,tel,groupName};int[]to={R.id._id,R.id.name,R.id.tel,R.id.group};SimpleCursorAdapterscadapter=newSimpleCursorAdapter(this,R.layout.relationlist,cursor,from,to);listView.setAdapter(scadapter);listView.setOnItemClickListener(newAdapterView.OnItemClickListener(){publicvoidonItemClick(AdapterView?adapter,Viewview,intposition,longid){finallongtemp=id;AlertDialog.BuilderadBuilder=newAlertDialog.Builder(MainActivity.this);adBuilder.setMessage(确认要删除记录吗?).setPositiveButton(确认,newDialogInterface.OnClickListener(){@OverridepublicvoidonClick(DialogInterfacedialog,intwhich){//TODOAuto-generatedmethodstubdbHelper.del((int)temp);Cursorcursor=dbHelper.query();String[]from={_id,name,tel,groupName};int[]to={R.id._id,R.id.name,R.id.tel,R.id.group};SimpleCursorAdapterscadapter=newSimpleCursorAdapter(getApplicationContext(),R.layout.relationlist,cursor,from,to);MainActivity.this.listView.setAdapter(scadapter);}}).setNegativeButton(取消,newDialogInterface.OnClickListener(){@OverridepublicvoidonClick(DialogInterfacedialog,intwhich){}});AlertDialogaleraDialog=adBuilder.create();aleraDialog.show();}});dbHelper.close();}publicvoidadd(Viewview){Intentintent=newIntent(MainActivity.this,AddrelationActivity.class);startActivityForResult(intent,0x111);}protectedvoidonActivityResult(intrequestCode,intresultCode,Intentdata){super.onActivityResult(requestCode,resultCode,data);if(requestCode==0x111&&resultCode==0x111){getRelationFromDB();}}@OverridepublicbooleanonCreateOptionsMenu(Menumenu){//Inflatethemenu;thisaddsitemstotheactionbarifitispresent.getMenuInflater().inflate(R.menu.main,menu);returntrue;}@OverridepublicbooleanonOptionsItemSelected(MenuItemitem){//Handleactionbaritemclickshere.Theactionbarwill//automaticallyhandleclicksontheHome/Upbutton,solong//asyouspecifyaparentactivityinAndroidManifest.xml.intid=item.getItemId();if(id==R.id.action_settings){returntrue;}returnsuper.onOptionsItemSelected(item);}}添加联系人AddrelationActivity.javaimportandroid.app.Activity;importandroid.app.AlertDialog;importandroid.content.ContentValues;importandroid.content.DialogInterface;importandroid.content.Intent;impo