1、需求分析
1)业务需求分析:
近年来,随着生活节奏的加快,工作和生活的双重压力全面侵袭着人们,如何避免忘记工作和生活中的诸多事情而造成不良的后果,就显得非常重要。为此,我们开发了一款基于Android系统的简单记事本,它能够便携记录生活和工作的诸多事情,从而帮助人们有条理的进行时间管理。

2)系统架构分析

记事本界面包含内容列表和添加按钮。

1、当长按列表条目(Item)时,会弹出一个提示是否删除Item的对话框,当点击对话框中的确定按钮时,删除Item,当点击对话框中的取消按钮时,取消删除Item。

2、当点击记事本界面列表中的Item时,会跳转到修改记录界面,该界面可以查看和修改记录。

3、当点击记事本界面中的添加按钮时,会跳转到添加记录界面,该界面可以添加记录内容。

android 小应用记事本 安卓记事本项目_SQL


记事本应用架构图

3)数据库类设计分析

数据库设计是项目中开发中非常关键的一个关节,在记事本应用中,我们通过数据库(Note)存储和读取数据。

android 小应用记事本 安卓记事本项目_android 小应用记事本_02


4)界面需求分析

界面在移动开发平台开发中非常重要,也是用户使用软件的先决条件。记事本应用分为3个界面,分别为记事本界面、添加记录界面和修改记录界面。

①记事本界面:该界面包含添加按钮和记录列表,点击记事本界面中的添加按钮时,程序会跳转到添加记录界面。当点击记事本界面列表中的Item时,程序会跳转到修改记录界面。

android 小应用记事本 安卓记事本项目_xml_03


②添加记录界面:该界面能添加需要记录的内容和清除和保存编辑的内容。

android 小应用记事本 安卓记事本项目_xml_04


③修改记录界面:该界面能够查看和修改已保存的记录内容、清除和保存编辑的内容。

android 小应用记事本 安卓记事本项目_SQL_05

2、开发环境介绍

操作系统:Windows 10系统

开发工具:JDK11,Android3.5.3

API版本:Android API 27

3、记事本功能业务实现

1)搭建聊天布局界面---activity_notepad.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity"
    android:background="#fefefe"
    >
    <TextView
        android:id="@+id/note_name"
        android:layout_width="match_parent"
        android:layout_height="45dp"
        android:textSize="20sp"
        android:textColor="@android:color/white"
        android:gravity="center"
        android:textStyle="bold"
        android:background="#fb7a6a"
        android:text="记事本"
        />
    <ListView
        android:id="@+id/listview"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:cacheColorHint="#00000000"
        android:divider="#E4E4E4"
        android:dividerHeight="1dp"
        android:fadingEdge="none"
        android:listSelector="#00000000"
        android:scrollbars="none"
        android:layout_below="@+id/note_name"
        />
    <ImageView
        android:id="@+id/add"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/add"
        android:layout_marginBottom="30dp"
        android:layout_centerHorizontal="true"
        android:layout_alignParentBottom="true"
        />
</RelativeLayout>

注意:修改清单文件

android 小应用记事本 安卓记事本项目_SQL_06


android 小应用记事本 安卓记事本项目_android_07


2)搭建记事本界面Item布局----notepad_item_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingLeft="12dp"
    >
    <TextView
        android:id="@+id/item_content"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:maxLines="2"
        android:ellipsize="end"
        android:lineSpacingExtra="3dp"
        android:paddingTop="10dp"
        android:textColor="@android:color/black" />
    <TextView
        android:id="@+id/item_time"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textColor="#fb7a6a"
        android:paddingTop="5dp"
        android:paddingBottom="7dp"
        />
</LinearLayout>

3)封装记录信息实体类----创建NotepadBean类

package com.example.notepad;
public class NotepadBean {
    private String id;
    private String notepadContent;
    private String notepadTime;
    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getNotepadContent() {
        return notepadContent;
    }

    public void setNotepadContent(String notepadContent) {
        this.notepadContent = notepadContent;
    }

    public String getNotepadTime() {
        return notepadTime;
    }

    public void setNotepadTime(String notepadTime) {
        this.notepadTime = notepadTime;
    }
}

4)编写记事本列表适配器----创建NotepadAdapter类

package com.example.notepad;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;
import java.util.List;
public class NotepadAdapter extends BaseAdapter {
    private LayoutInflater layoutInflater;
    private List<NotepadBean> list;
    public NotepadAdapter(Context context ,List<NotepadBean>list) {
        this.layoutInflater = LayoutInflater.from(context);
        this.list = list;
    }

    @Override
    public int getCount() {
        return list.size();
    }

    @Override
    public Object getItem(int position) {
        return list.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }
//重写getView()方法,该方法主要通过inflate()方法加载Item界面的布局文件,并将获取的数据显示到对应的控件上。
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder viewHolder;

//判断convertView是否为null,如果为null,则创建一个ViewHolder对象,接着tgsetTag()方法将该对象添加到convertView中进行缓存,否则,将通过getTag()方法获取
                缓存的ViewHolder对象
    if(convertView==null){

            convertView = layoutInflater.inflate(R.layout.notepad_item,null);
            viewHolder = new ViewHolder(convertView);
            convertView.setTag(viewHolder);
        }else{
            viewHolder = (ViewHolder)convertView.getTag();
        }



        NotepadBean noteInfo = (NotepadBean)getItem(position);
        viewHolder.tvNotepadContent.setText(noteInfo.getNotepadContent());
        viewHolder.tvNotepadTime.setText(noteInfo.getNotepadTime());
        return convertView;
    }

    class ViewHolder{
        TextView tvNotepadContent;
        TextView tvNotepadTime;
        public ViewHolder(View view) {
            tvNotepadContent = (TextView)view.findViewById(R.id.item_content);
            tvNotepadTime = (TextView)view.findViewById(R.id.item_time);
        }
    }
}

5)创建数据库----数据库的工具类DBUtils与类SQLiteHelper
数据库的工具类DBUtils

package com.example.notepad;
import java.text.SimpleDateFormat;
import java.util.Date;
public class DBUtils {
    public static final String DATABASE_NAME = "Notepad";    //数据库名
    public static final String DATABASE_TABLE = "Note";    //表名
    public static final int DATABASE_VERSION = 1;    //数据库版本

//数据库表中的列名

    public static final String NOTEPAD_ID = "id";
    public static final String NOTEPAD_CONTENT= "content";
    public static final String NOTEPAD_TIME = "notetime";
    public static final String getTime(){
//获取当前日期
    SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");

        Date date = new Date(System.currentTimeMillis());
        return simpleDateFormat.format(date);
    }
}

类SQLiteHelper

package com.example.notepad;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import java.util.ArrayList;
import java.util.List;
public class SQLiteHelper extends SQLiteOpenHelper {
private SQLiteDatabase sqLiteDatabase;

//创建数据库

    public SQLiteHelper(Context context) {
//通过super()方法创建了一个名为Notepad的数据库

super(context, DBUtils.DATABASE_NAME, null, DBUtils.DATABASE_VERSION);
        sqLiteDatabase = this.getWritableDatabase();
    }
//创建表
    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("create table "+DBUtils.DATABASE_TABLE+"("+DBUtils.NOTEPAD_ID+
                " integer primary key autoincrement,"+ DBUtils.NOTEPAD_CONTENT +
                " text," + DBUtils.NOTEPAD_TIME+ " text)");
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }

    //增加数据
    public boolean insertDate(String userContent,String userTime){
        ContentValues values = new ContentValues();
        values.put(DBUtils.NOTEPAD_CONTENT,userContent);
        values.put(DBUtils.NOTEPAD_TIME,userTime);
        return sqLiteDatabase.insert(DBUtils.DATABASE_TABLE,null,values) > 0;
    }
    //删除数据
    public boolean deleteData(String id){
        String sql = DBUtils.NOTEPAD_ID+"=?";
        String[] contentValuesArray = new String[]{String.valueOf(id)};
        return sqLiteDatabase.delete(DBUtils.DATABASE_TABLE,sql,contentValuesArray) > 0;
    }
    //修改数据
    public boolean updateDate(String id,String content,String userTime){
        ContentValues values = new ContentValues();
        values.put(DBUtils.NOTEPAD_CONTENT,content);
        values.put(DBUtils.NOTEPAD_TIME,userTime);
        String sql = DBUtils.NOTEPAD_ID+"=?";
        String[] strings = new String[]{id};
        return sqLiteDatabase.update(DBUtils.DATABASE_TABLE,values,sql,strings) > 0 ;
    }
    //查询数据
    public List<NotepadBean> query(){
        List<NotepadBean> list = new ArrayList<>();
        Cursor cursor = sqLiteDatabase.query(DBUtils.DATABASE_TABLE, null, null, null, null, null, null);
        if(cursor!=null){
            while(cursor.moveToNext()){
                NotepadBean noteInfo = new NotepadBean();
                String id = String.valueOf(cursor.getInt(cursor.getColumnIndex(DBUtils.NOTEPAD_ID)));
                String content = cursor.getString(cursor.getColumnIndex(DBUtils.NOTEPAD_CONTENT));
                String time = cursor.getString(cursor.getColumnIndex(DBUtils.NOTEPAD_TIME));
                noteInfo.setId(id);
                noteInfo.setNotepadContent(content);
                noteInfo.setNotepadTime(time);
                list.add(noteInfo);
            }
            cursor.close();
        }
        return list;
    }
}

6)实现记事本界面的显示功能----显示列表、添加列表
NotepadActivity类

package com.example.notepad;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.media.Image;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
public class RecordActivity extends AppCompatActivity implements View.OnClickListener{

    ImageView noteback;
    TextView note_time;
    EditText content;
    ImageView delete;
    ImageView note_save;
    SQLiteHelper mSQLiteHelper;
    TextView noteName;
    String id;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_record);
        noteback = (ImageView)findViewById(R.id.note_back);
        note_time = (TextView)findViewById(R.id.tv_time);
        content = (EditText)findViewById(R.id.note_content);
        delete = (ImageView) findViewById(R.id.delete);
        note_save = (ImageView) findViewById(R.id.note_save);
        noteName = (TextView) findViewById(R.id.note_name);
        noteback.setOnClickListener(this);
        delete.setOnClickListener(this);
        note_save.setOnClickListener(this);
        initData();
    }

    protected void initData() {
        mSQLiteHelper = new SQLiteHelper(this);
        Intent intent = getIntent();
        if(intent != null){
            id = intent.getStringExtra("id");
            if(id != null){
                noteName.setText("修改记录");
                content.setText(intent.getStringExtra("content"));
                note_time.setText(intent.getStringExtra("time"));
                note_time.setVisibility(View.VISIBLE);
            }else{
                noteName.setText("添加记录");
            }
        }

    }

    @Override
    public void onClick(View v) {
        switch (v.getId()){
            case R.id.note_back:
                finish();
                break;
            case R.id.delete:
                content.setText("");
                break;
            case R.id.note_save:
                String noteContent = content.getText().toString().trim();
                if(id != null){//修改
                    if(noteContent.length()>0){
                        if(mSQLiteHelper.updateDate(id,noteContent,DBUtils.getTime())){
                            Toast.makeText(RecordActivity.this,"修改成功",Toast.LENGTH_LONG).show();
                            setResult(2);
                            finish();
                        }else{
                            Toast.makeText(RecordActivity.this,"修改失败",Toast.LENGTH_LONG).show();
                        }
                    }else{
                        Toast.makeText(RecordActivity.this,"内容不能为空",Toast.LENGTH_LONG).show();
                    }
                }else{//增加
                    if(noteContent.length()>0){
                        if(mSQLiteHelper.insertDate(noteContent,DBUtils.getTime())){
                            Toast.makeText(RecordActivity.this,"保存成功",Toast.LENGTH_LONG).show();
                            setResult(2);
                            finish();
                        }else{
                            Toast.makeText(RecordActivity.this,"保存失败",Toast.LENGTH_LONG).show();
                        }
                    }else{
                        Toast.makeText(RecordActivity.this,"内容不能为空",Toast.LENGTH_LONG).show();
                    }
                }

                break;
        }

    }
}