Android项目开发实战——简单备忘录

项目简介

本次项目主要是结课的一个关于Android的基本应用开发,根据所学习到的知识,开发一个简单的入门级应用。

开发环境介绍

  • PC计算机(操作系统win10)

  • JDK安装包

  • Android studio 3.5.2

  • Android SDK 集成环境

实验内容

  1. 搭建Android studio开发安卓的集成开发环境
    Android Studio的安装,史上最详细(超多图)
  2. 创建project空的工程,开发一个简单的备忘录APP

程序设计流程

流程图

如图所示,APP包含三个页面,启动页(activity_welcome)、主页面(activity_main)和添加页面(activity_add)

项目主要目录及文件

在这里插入图片描述
在这里插入图片描述
如图所示,APP的布局文件均存放在layout文件夹中、所调用函数和方法均存放于com.example.bwl中。所需要的图片均存放在drawable。

项目开发

创建程序项目BWL

启动Android studio,创建新的项目 这里我们命名为BWL。步骤如图4、5、6所示。语言选择Java,最后单击Finish完成创建。
在这里插入图片描述
在这里插入图片描述

实现启动界面

将左上角的Android切换成Project,找到com.example.bwl,在同一目录下创建一个新的activity,创建方法与创建项目方法相同。步骤如下图。将新创建的activity项命名为welcome。

在这里插入图片描述

  • 选择一张图片,复制粘贴在drawable目录下,作为启动界面图片。照片命名为bcg。格式不限,jpg或png均可。
  • 打开activity_welcome.xml文件,修改为LinerLayout布局,添加图片和倒计时文本框。

在这里插入图片描述

<LinearLayout 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=".WelcomeActivity"
    android:background="@drawable/bcg"
    >
    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <TextView
            android:id="@+id/tv"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_marginRight="20dp"
            android:layout_marginTop="10dp"
            android:textSize="20sp" />
    </RelativeLayout>
</LinearLayout>

修改启动页顺序

配置启动顺序,打开AndroidMainfest.xml文件,如图所示,将intent代码块放在WelcomeActivity里
在这里插入图片描述

  • 配置WelcomeActivity.java,添加倒计时和点击触发关闭方法。
  • WelcomeActivity.java页代码:
import java.util.Timer;
import  android.content.Intent;
import java.util.TimerTask;
public class WelcomeActivity extends AppCompatActivity implements View.OnClickListener {

    private int recLen = *;//跳过倒计时提示*秒
    private TextView tv;
    Timer timer = new Timer();
    private Handler handler;
    private Runnable runnable;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //定义全屏参数
        int flag= WindowManager.LayoutParams.FLAG_FULLSCREEN;
        //设置当前窗体为全屏显示
        getWindow().setFlags(flag, flag);
        setContentView(R.layout.activity_welcome);
        initView();
        timer.schedule(task, 1000, 1000);//等待时间一秒,停顿时间一秒
        /**
         * 不点击跳过
         */
        handler = new Handler();
        handler.postDelayed(runnable = new Runnable() {
            @Override
            public void run() {
                //从闪屏界面跳转到主界面
                Intent intent = new Intent(WelcomeActivity.this, MainActivity.class);
                startActivity(intent);
                finish();
            }
        }, ****);//设置延迟时间,后发送handler信息
    }
    private void initView() {
        tv = findViewById(R.id.tv);//跳过
        tv.setOnClickListener(this);//跳过监听
    }
    TimerTask task = new TimerTask() {
        @Override
        public void run() {
            runOnUiThread(new Runnable() { // UI thread
                @Override
                public void run() {
                    recLen--;
                    tv.setText("跳过 " + recLen);
                    if (recLen < 0) {
                        timer.cancel();
                        tv.setVisibility(View.GONE);//倒计时到0隐藏字体
                    }
                }
            });
        }
    };
   
    @Override
    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.tv:
                //跳转到主界面
                Intent intent = new Intent(WelcomeActivity.this, MainActivity.class);
                startActivity(intent);
                finish();
                if (runnable != null) {
                    handler.removeCallbacks(runnable);
                }
                break;
            default:
                break;
        }
    }
}

设置主界面布局

  • 打开activity_main.xml文件。同样的修改布局为LinearLayout,依次添加背景图片,主页面标题TextView、输入框EditText、以及两个ImageButton。

在这里插入图片描述
activity_main.xml:

<LinearLayout
    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"
    android:background="@drawable/backgroundone"
    android:orientation="vertical"
    tools:context=".MainActivity">
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="15dp"
        android:layout_gravity="center_horizontal">
        <TextView
            android:id="@+id/test"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            android:text="我的备忘录"
            android:textColor="#474646"
            android:textSize="45sp"
            android:textStyle="bold" />
    </LinearLayout>
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="40dp"
        android:layout_gravity="center_horizontal"
        android:layout_marginLeft="10dp"
        android:orientation="horizontal">
        <EditText
            android:id="@+id/view_select"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            android:ems="13"
            android:hint="此处可以查询数据!"
            android:inputType="textPersonName" />
        <ImageButton
            android:id="@+id/btn_select"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:background="@android:color/transparent"
            app:srcCompat="@android:drawable/ic_menu_search" />
    </LinearLayout>
    <ScrollView
        android:layout_width="match_parent"
        android:layout_height="490dp"
        android:layout_margin="5dp"
        android:layout_marginLeft="40dp"
        android:layout_marginRight="20dp">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
            <TextView
                android:id="@+id/data"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:gravity="center_horizontal"
                android:textSize="20dp"></TextView>
            <Button
                android:id="@+id/next"
                android:layout_width="206dp"
                android:layout_height="wrap_content"
                android:layout_gravity="right"
                android:onClick="onClickNext"
                android:text="添加新备忘"
                tools:ignore="DuplicateIds" />
        </LinearLayout>

    </ScrollView>
    <ImageButton
        android:id="@+id/btn_add"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_marginLeft="300dp"
        android:background="@android:color/transparent"
        app:srcCompat="@mipmap/add1" />
</LinearLayout>

设置添加界面

  • 打开activity_add.xml文件。依次添加三个ImageButton,依次设置为返回按钮,保存按钮,清空按钮。以及一个输入框EditText。
    在这里插入图片描述
    activity_add.xml:
<LinearLayout 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"
    android:orientation="vertical"
    tools:context=".add">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        <ImageButton
            android:id="@+id/btn_back"
            android:layout_width="120dp"
            android:layout_height="60dp"
            android:background="@drawable/colorsilve"
            app:srcCompat="@android:drawable/ic_menu_revert" />
        <ImageButton
            android:id="@+id/btn_finish"
            android:layout_width="120dp"
            android:layout_height="60dp"
            android:visibility="visible"
            android:background="@drawable/colorsilve"
            app:srcCompat="@android:drawable/checkbox_on_background" />
        <ImageButton
            android:id="@+id/btn_clear"
            android:layout_width="120dp"
            android:layout_height="60dp"
            android:visibility="visible"
            android:background="@drawable/colorsilve"
            app:srcCompat="@android:drawable/ic_delete" />
    </LinearLayout>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">
        <TextView
            android:id="@+id/now_time"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="10dp"
            android:layout_marginBottom="10dp"
            android:textStyle="bold"
            android:textSize="20dp">
        </TextView>
    </LinearLayout>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <EditText
            android:id="@+id/data_information"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="#00FFFFFF"
            android:gravity="start"
            android:textSize="25dp"
            android:hint="此处写文章"
            android:textColor="#070507"
            >
        </EditText>
    </LinearLayout>
</LinearLayout>

设置主页面和添加页Java方法

  • MainActivity.java页:
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
    private ImageButton btn_add;
    private TextView data;
    private ImageButton btn_select;
    private EditText view_select;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        data = findViewById(R.id.data);
        btn_select = findViewById(R.id.btn_select);
        view_select = findViewById(R.id.view_select);
        //跳转
        btn_add = (ImageButton) findViewById(R.id.btn_add);
        btn_add.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent();
                intent.setClass(MainActivity.this, add.class);
                startActivity(intent);
            }
        });
        Intent i = getIntent();
        String get_data = i.getStringExtra("data");
        data.setText(get_data);
        //查询监听
        btn_select.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                String input = view_select.getText().toString().trim();
                String get = data.getText().toString().trim();
                if (!input.isEmpty()) {
                    int a = get.indexOf(input); //内容第一次出现
                    if ( a != -1 ){
                        String front = get.substring(0,a+1);
                        String after = get.substring(a+1,get.length());
                        int a1 = front.lastIndexOf("2020");
                        int b1 = after.indexOf("2020");
                        String front2 ;//传值
                        String after2 ;//传值
                        //防止查询数据为第一
                        if (a1 == -1) {
                            front2 = front;
                        }else{
                            String front1 = front.substring(a1, front.length());
                            front2 = front1;
                        }
                        if (b1 == -1){
                            after2 = after;
                        }else {
                            String after1 = after.substring(0,b1);
                            after2 = after1;
                        }

                        showMsg(front2 + after2 );//显示查询结果信息

                    }else {
                        showMsg("无匹配数据");
                    }
                }else{
                    showMsg("请输入查询的数据");
                }
            }

        });

    }
    //显示提示
    private void showMsg(String msg){
        Toast.makeText(this,msg,Toast.LENGTH_SHORT).show();
    }
    public void onClickNext(View view) {
        Intent intent = new Intent();
        intent.setClass(MainActivity.this, add.class);//this前面为当前activty名称,class前面为要跳转到得activity名称
        startActivity(intent);
        }
    }
  • Add.java页代码:
public class add extends AppCompatActivity {
    private ImageButton btn_back; //返回
    private ImageButton btn_finish;//完成
    private ImageButton btn_clear;//清空
    private TextView now_time;//当前时间
    private EditText data_information;//存储数据
    //与数据库操作相关的成员变量
    private MyDbHelper myDbHelper;
    private SQLiteDatabase db;
    private ContentValues values;
    private static final String mTablename = "mymemo";
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_add);
        //建立联系
        btn_back = findViewById(R.id.btn_back);
        data_information = findViewById(R.id.data_information);
        now_time = findViewById(R.id.now_time);
        btn_finish = findViewById(R.id.btn_finish);
        btn_clear = findViewById(R.id.btn_clear);
        //初始化数据库工具类实例
        myDbHelper  = new MyDbHelper(this);    
        //获取手机当前时间
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        Date date = new Date(System.currentTimeMillis());
        final String str_time = simpleDateFormat.format(date);
        now_time.setText(str_time);
        
        //返回主界面
        btn_back.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent();
                intent.setClass(add.this,MainActivity.class);
                startActivity(intent);
                queryData();
            }
        });  
        //执行添加
        btn_finish.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                String input = data_information.getText().toString().trim();
                if (input.isEmpty()){
                    showMsg("请输入要记录的内容");
                }else {
                    addData(str_time.trim(),input);
                    finish();
                    queryData();
                }
            }
        });
        btn_clear.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                clearData();
                showMsg("数据清楚完毕");
            }
        });
    }
    private void addData(String now_time,String data_information){
        db = myDbHelper.getWritableDatabase();
        values = new ContentValues();
        values.put("now_time",now_time);
        values.put("information",data_information);
        db.insert(mTablename,null,values);
        showMsg("添加成功");

    }
    //清空数据
    private void clearData(){

        db = myDbHelper.getWritableDatabase();
        db.delete(mTablename,null,null);
        String srtResult = "";
        Intent intent = new Intent(add.this,MainActivity.class);
        intent.putExtra("data",srtResult);
        startActivity(intent);
        showMsg("已经全部清空");
    }   
    //显示消息
    private void showMsg(String msg){
        Toast.makeText(this,msg,Toast.LENGTH_SHORT).show();
    }    
    //查询方法
    private void queryData(){
        db = myDbHelper.getReadableDatabase();
        Cursor cursor = db.query(mTablename,null,null,null,
                null,null,null);
        String srtResult = "";
        while (cursor.moveToNext()){
            srtResult += "\n" + cursor.getString(1);
            srtResult += "\n内容:" + cursor.getString(2);
            srtResult += "\n";
        }
        Intent intent = new Intent(add.this,MainActivity.class);
        intent.putExtra("data",srtResult);
        startActivity(intent);
    }
    class MyDbHelper extends SQLiteOpenHelper{

        public MyDbHelper(@Nullable Context context) {
            super(context, "mymemo.db", null, 2);
        }
        @Override
        public void onCreate(SQLiteDatabase db) {
            db.execSQL("create table " + mTablename + "(_id integer primary key autoincrement, " +
                    "now_time varchar(50) unique,information varchar(100) )");
        }

开启虚拟机测试功能性

启动页
主界面
添加页面

导出,打包为APK应用程序包

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 如图所示,将项目打包为APK应用程序包,根据提示设置签名,打包类型设置为release,单击完成。

结语

代码一定要多敲多练!代码一定要多敲多练!代码一定要多敲多练!

往期博客: https://blog.csdn.net/weixin_44087406/article/details/111187687

  • 37
    点赞
  • 289
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 24
    评论
评论 24
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

兔师傅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值