android日记本代码.doc_第1页
android日记本代码.doc_第2页
android日记本代码.doc_第3页
android日记本代码.doc_第4页
android日记本代码.doc_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

一、 实验详细代码(1) 布局的代码a edit.xml代码b list.xml的代码c row.xml的代码(2) 主要程序代码a DiaryBookDemo代码public class DiaryBookDemo extends ListActivity private static final int ACTIVITY_CREATE = 0;private static final int ACTIVITY_EDIT = 1;private static final int INSERT_ID = Menu.FIRST;private static final int DELETE_ID = Menu.FIRST + 1;private DiaryDbAdapter mDbHelper;private Cursor mDiaryCursor;Overridepublic void onCreate(Bundle savedInstanceState) super.onCreate(savedInstanceState);setContentView(R.layout.list);mDbHelper = new DiaryDbAdapter(this);mDbHelper.open();renderListView();startService(new Intent(this, TimerServer.class);private void renderListView() mDiaryCursor = mDbHelper.getAllNotes();startManagingCursor(mDiaryCursor);String from = new String DiaryDbAdapter.KEY_TITLE,DiaryDbAdapter.KEY_CREATED ;int to = new int R.id.text1, R.id.created ;SimpleCursorAdapter notes = new SimpleCursorAdapter(this,R.layout.row, mDiaryCursor, from, to);setListAdapter(notes);Overridepublic boolean onCreateOptionsMenu(Menu menu) super.onCreateOptionsMenu(menu);menu.add(0, INSERT_ID, 0, 插入);menu.add(0, DELETE_ID, 0, 删除);return true;Overridepublic boolean onMenuItemSelected(int featureId, MenuItem item) switch (item.getItemId() case INSERT_ID:createDiary();return true;case DELETE_ID:mDbHelper.deleteDiary(getListView().getSelectedItemId();renderListView();return true;return super.onMenuItemSelected(featureId, item);private void createDiary() Intent i = new Intent(this, ActivityDiaryEdit.class);startActivityForResult(i, ACTIVITY_CREATE);Override/ 需要对position和id进行一个很好的区分/ position指的是点击的这个ViewItem在当前ListView中的位置/ 每一个和ViewItem绑定的数据,肯定都有一个id,通过这个id可以找到那条数据。protected void onListItemClick(ListView l, View v, int position, long id) super.onListItemClick(l, v, position, id);Cursor c = mDiaryCursor;c.moveToPosition(position);Intent i = new Intent(this, ActivityDiaryEdit.class);i.putExtra(DiaryDbAdapter.KEY_ROWID, id);i.putExtra(DiaryDbAdapter.KEY_TITLE, c.getString(c.getColumnIndexOrThrow(DiaryDbAdapter.KEY_TITLE);i.putExtra(DiaryDbAdapter.KEY_BODY, c.getString(c.getColumnIndexOrThrow(DiaryDbAdapter.KEY_BODY);startActivityForResult(i, ACTIVITY_EDIT);Overrideprotected void onActivityResult(int requestCode, int resultCode,Intent intent) super.onActivityResult(requestCode, resultCode, intent);renderListView();b ActivityDiaryEdit的代码public class ActivityDiaryEdit extends Activity private EditText mTitleText;private EditText mBodyText;private Long mRowId;private DiaryDbAdapter mDbHelper;Overrideprotected void onCreate(Bundle savedInstanceState) super.onCreate(savedInstanceState);mDbHelper = new DiaryDbAdapter(this);mDbHelper.open();setContentView(R.layout.edit);mTitleText = (EditText) findViewById(R.id.title);mBodyText = (EditText) findViewById(R.id.body);Button confirmButton = (Button) findViewById(R.id.confirm);mRowId = null;/ 每一个intent都会带一个Bundle型的extras数据。Bundle extras = getIntent().getExtras();if (extras != null) String title = extras.getString(DiaryDbAdapter.KEY_TITLE);String body = extras.getString(DiaryDbAdapter.KEY_BODY);mRowId = extras.getLong(DiaryDbAdapter.KEY_ROWID);if (title != null) mTitleText.setText(title);if (body != null) mBodyText.setText(body);confirmButton.setOnClickListener(new View.OnClickListener() public void onClick(View view) String title = mTitleText.getText().toString();String body = mBodyText.getText().toString();if (mRowId != null) mDbHelper.updateDiary(mRowId, title, body); elsemDbHelper.createDiary(title, body);Intent mIntent = new Intent();setResult(RESULT_OK, mIntent);finish(););c DiaryDbAdapter的代码public class DiaryDbAdapter public static final String KEY_TITLE = title;public static final String KEY_BODY = body;public static final String KEY_ROWID = _id;public static final String KEY_CREATED = created;private static final String TAG = DiaryDbAdapter;private DatabaseHelper mDbHelper;private SQLiteDatabase mDb;private static final String DATABASE_CREATE = create table diary (_id integer primary key autoincrement, + title text not null, body text not null, created text not null);private static final String DATABASE_NAME = database;private static final String DATABASE_TABLE = diary;private static final int DATABASE_VERSION = 1;private final Context mCtx;private static class DatabaseHelper extends SQLiteOpenHelper DatabaseHelper(Context context) super(context, DATABASE_NAME, null, DATABASE_VERSION);Overridepublic void onCreate(SQLiteDatabase db) db.execSQL(DATABASE_CREATE);Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) db.execSQL(DROP TABLE IF EXISTS diary);onCreate(db);public DiaryDbAdapter(Context ctx) this.mCtx = ctx;public DiaryDbAdapter open() throws SQLException mDbHelper = new DatabaseHelper(mCtx);mDb = mDbHelper.getWritableDatabase();return this;public void closeclose() mDbHelper.close();public long createDiary(String title, String body) ContentValues initialValues = new ContentValues();initialValues.put(KEY_TITLE, title);initialValues.put(KEY_BODY, body);Calendar calendar = Calendar.getInstance();String created = calendar.get(Calendar.YEAR) + 年+ calendar.get(Calendar.MONTH) + 月+ calendar.get(Calendar.DAY_OF_MONTH) + 日+ calendar.get(Calendar.HOUR_OF_DAY) + 小时+ calendar.get(Calendar.MINUTE) + 分钟;initialValues.put(KEY_CREATED, created);return mDb.insert(DATABASE_TABLE, null, initialValues);public boolean deleteDiary(long rowId) return mDb.delete(DATABASE_TABLE, KEY_ROWID + = + rowId, null) 0;public Cursor getAllNotes() return mDb.query(DATABASE_TABLE, new String KEY_ROWID, KEY_TITLE,KEY_BODY, KEY_CREATED , null, null, null, null, null);public Cursor getDiary(long rowId) throws SQLException Cursor mCursor =mDb.query(true, DATABASE_TABLE, new String KEY_ROWID, KEY_TITLE,KEY_BODY, KEY_CREATED , KEY_ROWID + = + rowId, null, null,null, null, null);if (mCursor != null) mCursor.moveToFirst();return mCursor;public boolean updateDiary(long rowId, String title, String body) ContentValues args = new ContentValues();args.put(KEY_TITLE, title);args.put(KEY_BODY, body);Calendar calendar = Calendar.getInstance();String created = calendar.get(Calendar.YEAR) + 年+ calendar.get(Calendar.MONTH) + 月+ calendar.get(Calendar.DAY_OF_MONTH) + 日+ calendar.get(Calendar.HOUR_OF_DAY) + 小时+ calendar.get(Calendar.MINUTE) + 分钟;args.put(KEY_CREATED, created);return mDb.update(DATABASE_TABLE, args, KEY_ROWID + = + rowId, null) 0;d TimerServer的代码public class TimerServer extends Serviceprivate Timer timer;Overridepublic IBinder onBind(Intent arg0) / TODO Auto-generated method stubreturn null;Override public void onCreate() super.onCreate(); timer = new Timer(true);/ 创建Timer对象 Override public void onStart(Intent intent, int startId) super.onStart(intent, startId); timer.schedule(new TimerTask() Override public void run() String ns = Context.NOTIFICATION_SERVICE;

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论