SQLite、ListView、ContextMenu.doc

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SQLite、ListView、ContextMenu

SQLite、ListView、ContextMenu 继续上一个例子,结合ListView中对SQLite进行操作。 通过CursorAdapter在ListView中的数据呈现 在上一个例子中,我们可以对SQLite中的数据库进行增删改查,将数据读到游标Cursor中,然后一一读出。在Android中可以通过CursorAdapter直接将数据映射到ListView中,如下处理: public class Chapter22Test1 extends ListActivity{ private SQLiteDatabase db = null; private Cursor cursor = null; private SimpleCursorAdapter adapter = null; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); db= (new Chapter22Db (getApplicationContext())).getWritableDatabase(); cursor =db.rawQuery(SELECT _id,Name,Weight from mytable ORDER BY Weight, null); //layout/chapter_22_test1.xml的Android XML文件定义了ListView中每个单元的排列方式,每个单元R.id.c22_name和R.id.c22_gravity都是TextView,分列左右 adapter = new SimpleCursorAdapter(this, R.layout.chapter_22_test1, cursor, new String[]{Name,Weight},//游标数据的名称,实际是Table列名字 new int[]{R.id.c22_name, R.id.c22_gravity});//对应的UI微件的id setListAdapter(adapter); } protected void onDestroy() { super.onDestroy(); cursor.close(); //我们在onCreate()中没有关闭游标,因为需要和ListView进行数据关联,关闭curosr,会导致List无数据,故在最后释放资源 db.close(); //断开和数据库的连接,释放相关资源 } } 更新数据(以增加为例) 我们要实现:通过Menu弹出菜单,有一个为增加,按之,弹出一个Dialog,可以在当中填入数据,按Dialog的确定按键,在SQLite数据库的表格mytable中加入相关的数据,并且同步ListView的显示。 第一步:建立OptionsMenu,里面有菜单“Add”,按键后,触发执行add()的操作。具体实现不在此罗嗦,可以参见Android学习笔记(八):Activity-OpenMenu和LinearLayout 第二步:在add()中,要完成弹出指定格式的Dialog,采用AlertDialog的方式,Dialog的格式在xml中给出。处理方式之前都学过,但是没有合并使用的例子,包括Dialog的格式,同ListView中自定义元素的格式一样,采用LayoutInflater。具体如下: private void add(){ //步骤2.1:通过LayoutInflater从Android的XML文件中生成View LayoutInflater inflater = LayoutInflater.from(this); final View addView = inflater.inflate(R.layout.add_dialgo,null); //步骤2.2:通过AlertDialog弹出对话框,并且在第一个button,即PositiveButton监听事件,触发操作 new AlertDialog.Builder(this) .setTitle(添加框) .setView(addView) .setPositiveButton(确定,

文档评论(0)

mv2323 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档