本文实例为大家分享了Android实现记事本功能的具体代码,供大家参考,具体内容如下

实现功能

1、文本数据的存储

2、图片数据存储

3、视频数据存储

4、自定义的Adapter

5、SQlite的创建

6、数据listview列表的显示

demo地址

记事本

界面布局

  

数据库创建

public class NotesDB extends SQLiteOpenHelper { public static final String TABLE_NAME = "notes"; public static final String CONTENT = "content"; public static final String PATH = "path"; public static final String VIDEO = "video"; public static final String ID = "_id"; public static final String TIME = "time"; public NotesDB(Context context) { super(context, "notes", null, 1); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL("CREATE TABLE " + TABLE_NAME + " (" + ID + " INTEGER PRIMARY KEY AUTOINCREMENT," + CONTENT + " TEXT NOT NULL," + PATH + " TEXT NOT NULL," + VIDEO + " TEXT NOT NULL," + TIME + " TEXT NOT NULL)"); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}}

数据的加载

public class AddContent extends Activity implements OnClickListener { private String val; private Button savebtn, deletebtn; private EditText ettext; private ImageView c_img; private VideoView v_video; private NotesDB notesDB; private SQLiteDatabase dbWriter; private File phoneFile, videoFile; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.addcontent); //主界面点击Button传递过来的数据 val = getIntent().getStringExtra("flag"); savebtn = (Button) findViewById(R.id.save); deletebtn = (Button) findViewById(R.id.delete); ettext = (EditText) findViewById(R.id.ettext); c_img = (ImageView) findViewById(R.id.c_img); v_video = (VideoView) findViewById(R.id.c_video); savebtn.setOnClickListener(this); deletebtn.setOnClickListener(this); notesDB = new NotesDB(this); dbWriter = notesDB.getWritableDatabase(); initView(); } //判断存储的是文字,图片,还是视频,启动相对应的控件 public void initView() { if (val.equals("1")) { // 文字 c_img.setVisibility(View.GONE); v_video.setVisibility(View.GONE); } if (val.equals("2")) { c_img.setVisibility(View.VISIBLE); v_video.setVisibility(View.GONE); Intent img = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); phoneFile = new File(Environment.getExternalStorageDirectory()  .getAbsoluteFile() + "/" + getTime() + ".jpg"); img.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(phoneFile)); startActivityForResult(img, 1); } if (val.equals("3")) { c_img.setVisibility(View.GONE); v_video.setVisibility(View.VISIBLE); Intent video = new Intent(MediaStore.ACTION_VIDEO_CAPTURE); videoFile = new File(Environment.getExternalStorageDirectory()  .getAbsoluteFile() + "/" + getTime() + ".mp4"); video.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(videoFile)); startActivityForResult(video, 2); } } @Override public void onClick(View v) { switch (v.getId()) { case R.id.save: addDB(); finish(); break; case R.id.delete: finish(); break; } } //存储数据 public void addDB() { ContentValues cv = new ContentValues(); cv.put(NotesDB.CONTENT, ettext.getText().toString()); cv.put(NotesDB.TIME, getTime()); cv.put(NotesDB.PATH, phoneFile + ""); cv.put(NotesDB.VIDEO, videoFile + ""); dbWriter.insert(NotesDB.TABLE_NAME, null, cv); } //时间的显示 private String getTime() { SimpleDateFormat format = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss"); Date curDate = new Date(); String str = format.format(curDate); return str; } //完成数据拍摄后直接显示数据 @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); if (requestCode == 1) { Bitmap bitmap = BitmapFactory.decodeFile(phoneFile  .getAbsolutePath()); c_img.setImageBitmap(bitmap); } if (requestCode == 2) { v_video.setVideoURI(Uri.fromFile(videoFile)); v_video.start(); } }}

自定义Adapter

public class MyAdapter extends BaseAdapter { private Context context; private Cursor cursor; private LinearLayout layout; public MyAdapter(Context context, Cursor cursor) { this.context = context; this.cursor = cursor; } @Override public int getCount() { return cursor.getCount(); } @Override public Object getItem(int position) { return cursor.getPosition(); } @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } public View getView(int position, View convertView, ViewGroup parent) { LayoutInflater inflater = LayoutInflater.from(context); layout = (LinearLayout) inflater.inflate(R.layout.cell, null); TextView contenttv = (TextView) layout.findViewById(R.id.list_content); TextView timetv = (TextView) layout.findViewById(R.id.list_time); ImageView imgiv = (ImageView) layout.findViewById(R.id.list_img); ImageView videoiv = (ImageView) layout.findViewById(R.id.list_video); cursor.moveToPosition(position); String content = cursor.getString(cursor.getColumnIndex("content")); String time = cursor.getString(cursor.getColumnIndex("time")); String url = cursor.getString(cursor.getColumnIndex("path")); String urlvideo = cursor.getString(cursor.getColumnIndex("video")); contenttv.setText(content); timetv.setText(time); imgiv.setImageBitmap(getImageThumbnail(url, 200, 200)); videoiv.setImageBitmap(getVideoThumbnail(urlvideo, 200, 200, MediaStore.Images.Thumbnails.MICRO_KIND)); return layout; } /** ListView 显示图片*/ public Bitmap getImageThumbnail(String uri, int width, int height) { Bitmap bitmap = null; BitmapFactory.Options options = new BitmapFactory.Options(); options.inJustDecodeBounds = true; bitmap = BitmapFactory.decodeFile(uri, options); options.inJustDecodeBounds = false; int beWidth = options.outWidth / width; int beHeight = options.outHeight / height; int be = 1; if (beWidth < beHeight) { be = beWidth; } else { be = beHeight; } if (be <= 0) { be = 1; } options.inSampleSize = be; bitmap = BitmapFactory.decodeFile(uri, options); bitmap = ThumbnailUtils.extractThumbnail(bitmap, width, height, ThumbnailUtils.OPTIONS_RECYCLE_INPUT); return bitmap; } /**视频缩略图*/ private Bitmap getVideoThumbnail(String uri, int width, int height, int kind) { Bitmap bitmap = null; bitmap = ThumbnailUtils.createVideoThumbnail(uri, kind); bitmap = ThumbnailUtils.extractThumbnail(bitmap, width, height, ThumbnailUtils.OPTIONS_RECYCLE_INPUT); return bitmap; }}

ListView点击的详情页显示与数据删除

public class SelectAct extends Activity implements OnClickListener { private Button s_delete, s_back; private ImageView s_img; private VideoView s_video; private TextView s_tv; private NotesDB notesDB; private SQLiteDatabase dbWriter; /** 点击item 的详情页 对数据进行删除操作*/ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.select); s_delete = (Button) findViewById(R.id.s_delete); s_back = (Button) findViewById(R.id.s_back); s_img = (ImageView) findViewById(R.id.s_img); s_video = (VideoView) findViewById(R.id.s_video); s_tv = (TextView) findViewById(R.id.s_tv); /**读写权限*/ notesDB = new NotesDB(this); dbWriter = notesDB.getWritableDatabase(); s_back.setOnClickListener(this); s_delete.setOnClickListener(this); //判断是否存在图片 if (getIntent().getStringExtra(NotesDB.PATH).equals("null")) { s_img.setVisibility(View.GONE); } else { s_img.setVisibility(View.VISIBLE); } if (getIntent().getStringExtra(NotesDB.VIDEO).equals("null")) { s_video.setVisibility(View.GONE); } else { s_video.setVisibility(View.VISIBLE); } // 设置需要显示的图片 s_tv.setText(getIntent().getStringExtra(NotesDB.CONTENT)); Bitmap bitmap = BitmapFactory.decodeFile(getIntent().getStringExtra( NotesDB.PATH)); s_img.setImageBitmap(bitmap); s_video.setVideoURI(Uri .parse(getIntent().getStringExtra(NotesDB.VIDEO))); s_video.start(); } @Override public void onClick(View v) { switch (v.getId()) { case R.id.s_delete: deleteDate(); finish(); break; case R.id.s_back: finish(); break; } } //数据的删除 public void deleteDate() { dbWriter.delete(NotesDB.TABLE_NAME, "_id=" + getIntent().getIntExtra(NotesDB.ID, 0), null); }}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多相关文章

  1. SpringBoot 2.0 中 HikariCP 数据库连接池原理解析
  2. 一句话锁定MySQL数据占用元凶
  3. Android中是用Base64进行加密解密
  4. Android中对话框显示需要判断的前提条件
  5. 获取手机的视频和图片的缩略图
  6. Android根据Url显示gif类型图片
  7. Android应用之PopupWindow显示位置详解
  8. Android图表绘制
  9. 从android相册获取所有图片的路径

随机推荐

  1. Android线程池机制封装
  2. Android(安卓)studio常用设置和快捷键
  3. 【小知识点总结】保存android日志logcat
  4. 【Android(安卓)开发教程】ListView的扩
  5. RN(react-native)踩坑实录--编写项目
  6. 从头学Android之多媒体--使用SoundPool播
  7. Android(安卓)Studio中编译时遇到Finishe
  8. android之xml对象到json对象的转化
  9. Android(安卓)UI开发第十一篇——右上角
  10. 解决 android 下sqlite3_column_table_na