广告位联系
返回顶部
分享到

Android实现一个简单的单词本

Android 来源:互联网 作者:秩名 发布时间:2022-01-26 18:28:23 人浏览
摘要

本文基于Java实现了一个简单的单词本安卓app,用的是SQLite数据库,包括布局文件、源码及实现图。 布局设计 单词本主界面 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29

本文基于Java实现了一个简单的单词本安卓app,用的是SQLite数据库,包括布局文件、源码及实现图。

布局设计

单词本主界面

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

<?xml version="1.0" encoding="utf-8"?>

<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=".AddDanciActivity">

  

    <EditText

        android:id="@+id/addword_edit"

        android:layout_width="match_parent"

        android:layout_height="60dp"

        android:layout_marginTop="20dp"

        android:hint="单词:"

        android:textColor="@android:color/black"

        android:textColorHint="#DCDCDC"

        android:textSize="30dp" />

  

    <EditText

        android:id="@+id/fanyiword_edit"

        android:layout_width="match_parent"

        android:layout_height="60dp"

        android:hint="解释:"

        android:textColor="@android:color/black"

        android:textColorHint="#DCDCDC"

        android:textSize="30dp" />

  

    <RelativeLayout

        android:layout_width="match_parent"

        android:layout_height="match_parent"

        android:layout_alignParentBottom = "true"

        android:layout_margin="5dp">

    <ListView

        android:id="@+id/add_list"

        android:layout_width="match_parent"

        android:layout_height="match_parent"

        android:textColor="@android:color/black"

        android:textColorHint="#DCDCDC"

        android:textSize="30dp"

        android:layout_above="@id/lineLayout"

        />

  

        <LinearLayout

            android:layout_height="50dp"

            android:layout_width="match_parent"

            android:id="@+id/lineLayout"

            android:layout_alignParentBottom="true"

            android:orientation="horizontal"

            android:gravity="center_horizontal"

            >

        <Button

            android:layout_width="100dp"

            android:layout_height="50dp"

            android:id="@+id/add_btn"

            android:text="添加" />

        <Button

            android:layout_width="100dp"

            android:layout_height="50dp"

            android:layout_centerHorizontal="true"

            android:id="@+id/shanchu_btn"

            android:layout_gravity="center_vertical"

            android:text="删除" />

        <Button

            android:layout_width="100dp"

            android:layout_height="50dp"

            android:id="@+id/quxiao_btn"

            android:layout_gravity="right"

            android:text="取消" />

        </LinearLayout>

  

    </RelativeLayout>

  

</LinearLayout>

代码

AddDanciActivity.java

单词本主界面的Activity

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

import androidx.appcompat.app.AppCompatActivity;

import android.content.ContentValues;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

import android.os.Bundle;

import android.view.View;

import android.widget.Button;

import android.widget.EditText;

import android.widget.ListView;

import android.widget.SimpleAdapter;

import android.widget.Toast;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.Map;

  

public class AddDanciActivity extends AppCompatActivity {

  

    private EditText wordedit;

    private EditText yisiedit;

    private Button add_btn;

    private Button quxiao_btn;

    private Button shanchu_btn;

    private ListView listview;

    private DBOpenHelper dbOpenHelper;//声明

  

    @Override

    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_add_danci);

        dbOpenHelper = new DBOpenHelper(AddDanciActivity.this, "db_dict", null, 1);//实例化,创建数据库

        wordedit = (EditText) findViewById(R.id.addword_edit);

        yisiedit = (EditText) findViewById(R.id.fanyiword_edit);

        listview = (ListView) findViewById(R.id.add_list);

        add_btn = (Button) findViewById(R.id.add_btn);

        quxiao_btn = (Button) findViewById(R.id.quxiao_btn);

        shanchu_btn = (Button) findViewById(R.id.shanchu_btn);

        quxiao_btn.setOnClickListener(new View.OnClickListener() {

            @Override

            public void onClick(View v) {

                Toast.makeText(AddDanciActivity.this, "返回单词本主界面", Toast.LENGTH_SHORT).show();

                finish();

            }

        });

  

        shanchu_btn.setOnClickListener(new View.OnClickListener() {

            @Override

            public void onClick(View v) {

                String word = wordedit.getText().toString();

                String ys = yisiedit.getText().toString();

                if (word.equals("")) {

                    Toast.makeText(AddDanciActivity.this, "填写的单词为空", Toast.LENGTH_SHORT).show();

                } else {

                    deleteData(dbOpenHelper.getReadableDatabase(), word);

                    Toast.makeText(AddDanciActivity.this, "删除成功", Toast.LENGTH_SHORT).show();

                }

            }

        });

  

        add_btn.setOnClickListener(new View.OnClickListener() {

            @Override

            public void onClick(View v) {

                String word = wordedit.getText().toString();

                String ys = yisiedit.getText().toString();

                if (word.equals("") || ys.equals("")) {

                    Toast.makeText(AddDanciActivity.this, "填写的单词或解释为空", Toast.LENGTH_SHORT).show();

                } else {

                    insertData(dbOpenHelper.getReadableDatabase(), word, ys);//插入生词

                    Toast.makeText(AddDanciActivity.this, "添加生词成功", Toast.LENGTH_SHORT).show();

                    renew();

                }

            }

        });

    }

  

    //插入数据的方法

    private void insertData(SQLiteDatabase sqLiteDatabase, String word, String ys) {

        ContentValues values = new ContentValues();

        values.put("word", word);//保存单词

        values.put("detail", ys);

        sqLiteDatabase.insert("tb_dict", null, values);//执行插入操作

        renew();

    }

  

    private void deleteData(SQLiteDatabase sqLiteDatabase, String word) {

        ContentValues values = new ContentValues();

        String[] args = {String.valueOf(word)};

        sqLiteDatabase.delete("tb_dict", "word=?", args);//执行删除操作

        renew();

    }

  

  

    @Override

    protected void onDestroy() {

        super.onDestroy();

        if (dbOpenHelper != null) {

            dbOpenHelper.close();//关闭

        }

    }

  

    public void renew() {

        Cursor cursor = dbOpenHelper.getReadableDatabase().query("tb_dict", null, null, null, null, null, null);

        ArrayList<Map<String, String>> resultList = new ArrayList<Map<String, String>>();

        while (cursor.moveToNext()) {

            Map<String, String> map = new HashMap<String, String>();

            map.put("word", cursor.getString(1));

            map.put("interpret", cursor.getString(2));

            resultList.add(map);

        }

  

        if (resultList == null || resultList.size() == 0) {

            Toast.makeText(AddDanciActivity.this, "很遗憾,没有相关记录!", Toast.LENGTH_SHORT).show();

        } else {

            SimpleAdapter simpleAdapter = new SimpleAdapter(AddDanciActivity.this, resultList, R.layout.item, new String[]{"word", "interpret"

            }, new int[]{R.id.textView, R.id.textView2});

            listview.setAdapter(simpleAdapter);

        }

    }

  

    @Override

    protected void onStart() {

        super.onStart();

        renew();

    }

}

DBOpenHelper.java

用到的是SQLite数据库,Android自带了一种轻量级数据库,使用非常方便。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteOpenHelper;

import android.util.Log;

import androidx.annotation.Nullable;

  

public class DBOpenHelper extends SQLiteOpenHelper {

  

    final String CREATE_TABLE_SQL = "create table tb_dict (_id integer primary key autoincrement,word,detail)";//定义创建表的

  

    public DBOpenHelper(@Nullable Context context, @Nullable String name, @Nullable SQLiteDatabase.CursorFactory factory, int version) {

        super(context, name, null, version);

    }

  

    @Override

    public void onCreate(SQLiteDatabase db) {

        db.execSQL(CREATE_TABLE_SQL);//创建单词的数据表

    }

  

    @Override

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

        Log.i("词典", "--版本更新" + oldVersion + "-->" + newVersion);

    }

}

效果图


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/zhiwenganyong/article/details/122649922
相关文章
  • Kotlin的Collection与Sequence操作异同点介绍

    Kotlin的Collection与Sequence操作异同点介绍
    在Android开发中,集合是我们必备的容器,Kotlin的标准库中提供了很多处理集合的方法,而且还提供了两种基于容器的工作方式:Collection 和
  • 实现一个Kotlin函数类型方法

    实现一个Kotlin函数类型方法
    接口与函数类型 业务开发中,经常会有实现一个函数式接口(即接口只有一个方法需要实现)的场景,大家应该都会不假思索的写出如下代
  • Android10 App启动Activity源码分析
    ActivityThread的main方法 让我们把目光聚焦到ActivityThread的main方法上。 ActivityThread的源码路径为/frameworks/base/core/java/android/app/ActivityThread。 1 2
  • Android10客户端事务管理ClientLifecycleManager源码解析

    Android10客户端事务管理ClientLifecycleManager源码解析
    在Android 10 App启动分析之Activity启动篇(二)一文中,简单地介绍了Activity的生命周期管理器是如何调度Activity进入onCreate生命周期的流程。这
  • Kotlin对象的懒加载方式by lazy与lateinit异同介绍

    Kotlin对象的懒加载方式by lazy与lateinit异同介绍
    属性或对象的延时加载是我们相当常用的,一般我们都是使用 lateinit 和 by lazy 来实现。 他们两者都是延时初始化,那么在使用时那么他们两
  • Android类加载流程分析

    Android类加载流程分析
    本文分析的代码基于Android8.1.0源码。 流程分析 从loadClass开始,我们来看下Android中类加载的流程 /libcore/ojluni/src/main/java/java/lang/ClassLoader.ja
  • Android实现读写USB串口数据的代码

    Android实现读写USB串口数据的代码
    最近在研究USB方面的内容;先后做了关于Android读写HID、串口设备的DEMO。本文比较简单,主要介绍的是Android实现读取串口数据的功能 废话不
  • Epoxy - 在RecyclerView中构建复杂界面
    Diffing 对于复杂数据结构支持的多个视图类型展示在屏幕上, Epoxy此时是尤其有用的. 在这些场景中, 数据可能会被网络请求, 异步 Observable, 用
  • Android性能优化的详细介绍

    Android性能优化的详细介绍
    性能优化是一个app很重要的一部分,一个性能优良的app从被下载到启动到使用都能给用户到来很好的体验。自然我们做性能优化也是从被下
  • Android进阶宝典-插件化2(Hook启动插件中四大组件

    Android进阶宝典-插件化2(Hook启动插件中四大组件
    在上一节,我们主要介绍了如果通过反射来加载插件中的类,调用类中的方法;既然插件是一个apk,其实最重要的是启动插件中的Activity、
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计