基于Java实现一个简单的单词本Android App的实践

网友投稿 234 2022-11-03

基于Java实现一个简单的单词本Android App的实践

目录布局设计代码AddDanciActivity.javaDBOpenHelper.java

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

布局设计

单词本主界面

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">

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" />

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" />

android:layout_width="match_parent"

android:layout_height="match_parent"

android:layout_alignParentBottom = "true"

android:layout_margin="5dp">

android:id="@+id/add_list"

android:layout_weBnItidth="match_parent"

android:layout_height="match_parent"

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

android:textColorHint="#DCDCDC"

android:textSize="30dp"

android:layout_above="@id/lineLayout"

/>

android:layout_height="50dp"

android:layout_width="match_parent"

android:id="@+id/lineLayout"

android:layout_alignParentBottom="true"

android:orientation="horizontal"

android:gravity="center_horizontal"

>

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">

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" />

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" />

android:layout_width="match_parent"

android:layout_height="match_parent"

android:layout_alignParentBottom = "true"

android:layout_margin="5dp">

android:id="@+id/add_list"

android:layout_weBnItidth="match_parent"

android:layout_height="match_parent"

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

android:textColorHint="#DCDCDC"

android:textSize="30dp"

android:layout_above="@id/lineLayout"

/>

android:layout_height="50dp"

android:layout_width="match_parent"

android:id="@+id/lineLayout"

android:layout_alignParentBottom="true"

android:orientation="horizontal"

android:gravity="center_horizontal"

>

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" />

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" />

android:layout_width="match_parent"

android:layout_height="match_parent"

android:layout_alignParentBottom = "true"

android:layout_margin="5dp">

android:id="@+id/add_list"

android:layout_weBnItidth="match_parent"

android:layout_height="match_parent"

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

android:textColorHint="#DCDCDC"

android:textSize="30dp"

android:layout_above="@id/lineLayout"

/>

android:layout_height="50dp"

android:layout_width="match_parent"

android:id="@+id/lineLayout"

android:layout_alignParentBottom="true"

android:orientation="horizontal"

android:gravity="center_horizontal"

>

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" />

android:layout_width="match_parent"

android:layout_height="match_parent"

android:layout_alignParentBottom = "true"

android:layout_margin="5dp">

android:id="@+id/add_list"

android:layout_weBnItidth="match_parent"

android:layout_height="match_parent"

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

android:textColorHint="#DCDCDC"

android:textSize="30dp"

android:layout_above="@id/lineLayout"

/>

android:layout_height="50dp"

android:layout_width="match_parent"

android:id="@+id/lineLayout"

android:layout_alignParentBottom="true"

android:orientation="horizontal"

android:gravity="center_horizontal"

>

android:layout_width="match_parent"

android:layout_height="match_parent"

android:layout_alignParentBottom = "true"

android:layout_margin="5dp">

android:id="@+id/add_list"

android:layout_weBnItidth="match_parent"

android:layout_height="match_parent"

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

android:textColorHint="#DCDCDC"

android:textSize="30dp"

android:layout_above="@id/lineLayout"

/>

android:layout_height="50dp"

android:layout_width="match_parent"

android:id="@+id/lineLayout"

android:layout_alignParentBottom="true"

android:orientation="horizontal"

android:gravity="center_horizontal"

>

android:id="@+id/add_list"

android:layout_weBnItidth="match_parent"

android:layout_height="match_parent"

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

android:textColorHint="#DCDCDC"

android:textSize="30dp"

android:layout_above="@id/lineLayout"

/>

android:layout_height="50dp"

android:layout_width="match_parent"

android:id="@+id/lineLayout"

android:layout_alignParentBottom="true"

android:orientation="horizontal"

android:gravity="center_horizontal"

>

android:layout_height="50dp"

android:layout_width="match_parent"

android:id="@+id/lineLayout"

android:layout_alignParentBottom="true"

android:orientation="horizontal"

android:gravity="center_horizontal"

>

android:layout_width="100dp"

android:layout_height="50dp"

android:id="@+id/add_btn"

android:text="添加" />

android:layout_width="100dp"

android:layout_height="50dp"

android:layout_centerHorizontal="true"

android:id="@+id/shanchu_btn"

android:layout_gravity="center_vertical"

android:text="删除" />

android:layout_width="100dp"

android:layout_height="50dp"

android:id="@+id/quxiao_btn"

android:layout_gravity="right"

android:text="取消" />

代码

AddDanciActivity.java

单词本主界面的Activity

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("")) {

http:// 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> resultList = new ArrayList>();

while (cursor.moveToNext()) {

Map map = new HashMap();

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自带了一种轻量级数据库,使用非常方便。

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import andeBnItroid.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);

}

}

效果图

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:NoSQL之Redis高可用(理论)
下一篇:带你回顾MCU上可用的外部存储器接口配置
相关文章

 发表评论

暂时没有评论,来抢沙发吧~