Android实现记事本功能

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

实现功能

1、文本数据的存储

2、图片数据存储

3、视频数据存储

4、自定义的Adapter

5、SQlite的创建

6、数据listview列表的显示

demo地址

记事本

界面布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical" >

 <LinearLayout
 android:layout_width="fill_parent"
 android:layout_height="wrap_content"
 android:orientation="horizontal" >

 <Button
 android:id="@+id/text"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_weight="1"
 android:text="文字" />

 <Button
 android:id="@+id/img"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_weight="1"
 android:text="图文" />

 <Button
 android:id="@+id/video"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_weight="1"
 android:text="视频" />
 </LinearLayout>

 <ListView
 android:id="@+id/list"
 android:layout_width="fill_parent"
 android:layout_height="wrap_content" >
 </ListView>

</LinearLayout>

数据库创建

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);
 }
}

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

(0)

相关推荐

  • android实现记事本app

    自己写的一个简单的记事本app,效果如下: 一.首先是第一个界面的编写,最上面是一个TextView,中间是一个Linearlayout中嵌套一个listview布局,最下面是一个button.下面附上第一个页面的简单布局xml文件. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" androi

  • Android+SQLite数据库实现的生词记事本功能实例

    本文实例讲述了Android+SQLite数据库实现的生词记事本功能.分享给大家供大家参考,具体如下: 主activity命名为 Dict: 代码如下: package example.com.myapplication; import android.app.Activity; import android.content.Intent; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase;

  • Android利用Intent实现记事本功能(NotePad)

    本文实例为大家分享了Intent如何实现一个简单的记事本功能的演示过程,供大家参考,具体内容如下 1.运行截图 单击右上角[-]会弹出[添加]菜单项,长按某条记录会弹出快捷菜单[删除]项. 2.主要设计步骤 (1)添加引用 鼠标右击[引用]à[添加引用],在弹出的窗口中勾选"System.Data"和"System.Data.SQlite",如下图所示: 注意:不需要通过NuGet添加SQLite程序包,只需要按这种方式添加即可. (2)添加图片 到Android

  • Android记事本项目开发

    写了一个Android记事本小程序,现在记录一下. 考虑到是记事本小程序,记录的内容只有文字,而且内容不会太长,所以选择使用SQLite数据库,数据存放在用户的手机上. 牵涉到数据库,那自然是一个实体.先设计实体数据表:DBHelper.java package com.ikok.notepad.DBUtil; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android

  • Android中实现记事本动态添加行效果

    本文主要给大家介绍了关于Android实现记事本动态添加行的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍: 先看效果图: 这是昨天在群里面有人在问这个问题,在这里顺便记录一下,这个效果我们可以自定义EditText,实现起来也不难 看详细步骤: 第一:初始化Paint,这里肯定要用到画笔的 this.paint = new Paint(); paint.setStyle(Paint.Style.STROKE); paint.setColor(getResources().getCo

  • Android实现简易记事本

    本文实例为大家分享了Android实现简易记事本的具体代码,供大家参考,具体内容如下 此次做的Android简易记事本的存储方式使用了SQLite数据库,然后界面的实现比较简单,但是,具有增删改查的基本功能,这里可以看一下效果图,如下: 具体操作就是长按可以删除操作,点击可以进行修改,点击添加笔记按钮可以添加一个笔记. 首先我们需要三个界面样式一个是我们的进入程序时的第一个界面,然后第一个界面里面有一个ListView,这个ListView需要一个xml来描述里面的各个元素,这也是第二个.还有一

  • Android实现记事本功能(26)

    本文实例为大家分享了Android实现记事本功能的具体代码,供大家参考,具体内容如下 MainActivity.java代码: package siso.smartnotef.activity; import android.app.AlertDialog; import android.content.DialogInterface; import android.content.Intent; import android.os.Bundle; import android.support.

  • Android实现记事本功能

    本文实例为大家分享了Android实现记事本功能的具体代码,供大家参考,具体内容如下 实现功能 1.文本数据的存储 2.图片数据存储 3.视频数据存储 4.自定义的Adapter 5.SQlite的创建 6.数据listview列表的显示 demo地址 记事本 界面布局 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.

  • Android实现记事本小功能

    本文实例为大家分享了Android实现记事本功能的具体代码,供大家参考,具体内容如下 首先声明,本人是android的小白,主要是新人项目写了这个程序,思路可能不是很清晰,可优化的地方也有很多,望路过的大佬不吝赐教. 该记事本包含创建新条目,数据库增删改查,条目可编辑,滑动删除与拖拽排序,简单闹钟实现(还有个简陋背景音乐开关就不提了太简单),接下来逐一介绍一下. build.gradle导入 apply plugin: 'kotlin-kapt' ''' implementation 'com.

  • listview与SQLite结合实现记事本功能

    android记事本的demo在网上一搜一大堆,但是大神写的demo往往功能太多导致新手难以着手,很难啃得动:而一些新手写的demo又往往是东拼西凑,代码很多都是copy的别人的,直接放在项目里面用,也不知道代码有什么作用.往往代码特别丑,重复性的代码也比较多. 笔者近期学到此处,自己理解之后也还是打算写个demo供新手学习一下.代码说不上优雅,但在笔者看来已经尽力去让人容易理解了.(源码在文章结尾) 为了便于新手学习,在此也是罗列一下涉及的知识点: 1.SQLite的基本使用,增删查改 2.l

  • Android手机开发设计之记事本功能

    本文实例为大家分享了Android手机开发设计之记事本功能,供大家参考,具体内容如下 一.需求分析 1.1业务需求分析 近年来,随着生活节奏的加快,工作和生活的双重压力全面侵袭着人们,如何避免忘记工作和生活中的诸多事情而造成不良的后果就显得非常重要.为此我们开发一款基于Android系统的简单记事本,其能够便携记录生活和工作对诸多事情,从而帮助人们有效地进行时间管理. 1.2功能需求分析 本记事本项目希望可以开发出一款符合用户生活工作习惯的简单应用,能够满足用户的各方面需求,可以对记事进行增加.

  • Android毕业设计记事本APP

    目录 前言 功能概述 系统设计 启动界面 引导界面 更改口令界面 主界面和编辑界面 1 建表 2 添加便签 3 在主界面显示便签 4 再次编辑该便签 5 主界面和编辑界面布局 前言 该设计是一款轻量级的便签工具,使用Android Studio开发,风格简练,可实现便签的添加.删除.修改.查看功能.为保证一定的安全性,设置了进入口令,类似于应用锁,用户可以修改口令.主要使用的技术有共享参数.数据库.SwipeRefreshLayout控件. 功能概述 用户打开应用后,启动页会判断用户是否第一次打

  • Android 偷拍功能实现(手机关闭依然拍照)详解及实例代码

     Android 偷拍功能/手机关闭能拍照 效果如下: 其实偷拍与偷录实现方式是一样的,都是使用到的WindowManager来绘制桌面小控件的原理.那我就不多说了- 一.首先我们需要一个SurfaceView: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android&quo

  • Android登录注册功能 数据库SQLite验证

    本文实例为大家分享了Android登录注册功能的具体代码,供大家参考,具体内容如下 展示效果 代码区 MainActivity(登录方法) public class MainActivity extends AppCompatActivity { @BindView(R.id.editText) EditText editText; @BindView(R.id.editText2) EditText editText2; @BindView(R.id.button) Button button

随机推荐