英语词典小程序

内容简介

英语词典小程序,是通过打开数据库来查询单词,通过openDatabase()方法来实现,另外也可以使用openDatabase()方法来实现实现从res\raw目录复制数据库文件到/sdcard/dictionary目录中,复制数据实际上先读取,再写入数据的过程。把数据库复制到手机内存中,更方便数据的读取。

效果图

下载地址

http://download.csdn.net/detail/gxseveryday/8804655

代码

分析:

activity_main.xml中主要定义了一个按钮,作用是查询单词事件处理,定义了一个TextView显示查询的结果,定义了一个AutoCompleteTextView组件,起到显示多个单词的效果。

UI界面

activity_main.xml

<RelativeLayout 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:background="@drawable/mainbg"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <AutoCompleteTextView
        android:id="@+id/etWord"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginTop="31dp"
        android:background="@android:drawable/edit_text"
        android:ems="10"
        android:hint="@string/searchHint"
        android:singleLine="true"
        android:textColor="#552006"
        android:textColorHint="#782f10" >

    </AutoCompleteTextView>

    <Button
        android:id="@+id/btnSearch"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBaseline="@+id/etWord"
        android:layout_alignBottom="@+id/etWord"
        android:layout_marginLeft="16dp"
        android:layout_toRightOf="@+id/etWord"
        android:background="@drawable/ibsearchword"
        android:onClick="searchWord"
        android:text="@string/serachWord" />

    <TextView
        android:id="@+id/tvSearchResult"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_alignLeft="@+id/etWord"
        android:layout_below="@+id/etWord"
        android:layout_marginTop="22dp"
        android:textSize="25sp"
        android:background="@drawable/bg_roundcorner"
        android:textAppearance="?android:attr/textAppearanceMedium" />

</RelativeLayout>

分析:

word_list_item.xml中只是定义了一TextView组件,用来显示查询出来的多个单词

word_list_item.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/tvWordItem"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:gravity="center_vertical"
    android:minHeight="?android:attr/listPreferredItemHeight"
    android:paddingLeft="6dip"
    android:textAppearance="?android:attr/textAppearanceLarge"
    android:textColor="@color/gray" />

类和方法

分析:

Dictionary.java调用activity_main.xml布局,进行事件处理,调用适配器,查询所要查询的单词。

Dictionary.java

package com.bzu.gxs;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import com.bzu.gxs.dao.DictionaryAdapter;
import com.bzu.gxs.db.DBHelper;
import com.bzu.gxs.R;
import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.View.OnClickListener;
import android.widget.AutoCompleteTextView;
import android.widget.Button;
import android.widget.CursorAdapter;
import android.widget.TextView;
public class Dictionary extends Activity implements OnClickListener,TextWatcher {
    private DBHelper dbHelper; // 用户输入文本框
    private AutoCompleteTextView word; // 定义数据库的名字
    private SQLiteDatabase database;
    private Button searchWord; // 搜索按钮
    private TextView showResult; // 用户显示查询结果

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        dbHelper = new DBHelper(getBaseContext());// 打开数据库
        database = dbHelper.openDatabase();

        init();

        searchWord.setOnClickListener(this); // 绑定监听器
        word.addTextChangedListener(this); // 绑定文字改变监听器

    }

        public void init() {
        searchWord = (Button) findViewById(R.id.btnSearch);
        word = (AutoCompleteTextView) findViewById(R.id.etWord);
        showResult= (TextView) findViewById(R.id.tvSearchResult);

    }

    public void afterTextChanged(Editable s) {
        Cursor cursor = database.rawQuery("select english as _id
                from t_words where english like ?",
                new String[] { s.toString() + "%" });

        // 新建新的Adapter
        DictionaryAdapter dictionaryAdapter = new DictionaryAdapter(this,cursor, true);

        // 绑定适配器
        word.setAdapter(dictionaryAdapter);

    }

    public void beforeTextChanged(CharSequence s, int start, int count,int after) {

    }

    public void onTextChanged(CharSequence s, int start, int before, int count) {

    }

    public void onClick(View view) {
        // 查询指定的单词
        String sql = "select chinese from t_words where english=?";

        Cursor cursor = database.rawQuery(sql, new String[] { word.getText()
                .toString() });

        String result = "查无该词"; // 如果查找单词,显示其中文的意思

        if (cursor.getCount() > 0) { 

            cursor.moveToFirst(); // 须使用moveToFirst方法将记录指针移动到第1条记录的位置
            result = cursor.getString(cursor.getColumnIndex("chinese")).replace("&amp;", "&");
        }

showResult.setText(word.getText() + "\n" + result.toString());// 将结果显示到TextView中
    }

}

分析:

DictionaryAdapter.java是自定义的适配器,调用word_list_item.xml布局, 将单词信息显示到列表中,绑定选项到列表中,生成新的选项。

DictionaryAdapter.java

package com.bzu.gxs.dao;
import android.content.Context;
import android.database.Cursor;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.CursorAdapter;
import android.widget.TextView;
import com.bzu.gxs.R;

public class DictionaryAdapter extends CursorAdapter {
    private LayoutInflater layoutInflater;

    @Override
    public CharSequence convertToString(Cursor cursor) {
        return cursor == null ? "" : cursor.getString(cursor
                .getColumnIndex("_id"));
    }

    // 将单词信息显示到列表中
    private void setView(View view, Cursor cursor) {
        TextView tvWordItem = (TextView) view;
        tvWordItem.setText(cursor.getString(cursor.getColumnIndex("_id")));
    }

    // 绑定选项到列表中
    @Override
    public void bindView(View view, Context context, Cursor cursor) {
        setView(view, cursor);
    }

    // 生成新的选项
    @Override
    public View newView(Context context, Cursor cursor, ViewGroup parent) {
        View view = layoutInflater.inflate(R.layout.word_list_item, null);
        setView(view, cursor);
        return view;
    }

    public DictionaryAdapter(Context context, Cursor c, boolean autoRequery) {
        super(context, c, autoRequery);
        layoutInflater = (LayoutInflater) context
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    }
}

分析:

DBHelper.java数据库操作类,调用数据库,打开数据库,读取数据库中的数据,关闭数据库。通过InputStream输入流,获得封装dictionary.db文件的InputStream对象。

DBHelper.java

package com.bzu.gxs.db;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import com.bzu.gxs.R;

public class DBHelper {
    // 定义数据库的存放路径
    private final String DATABASE_PATH = android.os.Environment
            .getExternalStorageDirectory().getAbsolutePath() + "/dictionary";
    private final String DATABASE_FILENAME = "dictionary.db";
    private Context context;

    public DBHelper(Context context) {
        this.context = context;
    }

    public SQLiteDatabase openDatabase() {

        try {
            // 获得dictionary.db文件的绝对路径
            String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME;
            File dir = new File(DATABASE_PATH);

            // 如果/sdcard/dictionary目录中存在,创建这个目录
            if (!dir.exists())
                dir.mkdir();

            if (!(new File(databaseFilename)).exists()) {

                // 获得封装dictionary.db文件的InputStream对象
                InputStream is = context.getResources().openRawResource(
                        R.raw.dictionary);
                FileOutputStream fos = new FileOutputStream(databaseFilename);
                byte[] buffer = new byte[8192];
                int count = 0;
                // 开始复制dictionary.db文件
                while ((count = is.read(buffer)) > 0) {

                    fos.write(buffer, 0, count);
                }
                // 关闭文件流
                fos.close();
                is.close();
            }

            // 打开/sdcard/dictionary目录中的dictionary.db文件
            SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(
                    databaseFilename, null);
            return database;
        } catch (Exception e) {

        }
        // 如果打开出错,则返回null
        return null;
    }

}
时间: 2024-10-03 20:40:20

英语词典小程序的相关文章

微信小程序学习指南

作者:初雪链接:https://www.zhihu.com/question/50907897/answer/128494332来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 微信小程序正式公测, 张小龙全面阐述小程序,定档1月9日上线(附90分钟演讲全文) ... 前言:新人第一坑,跳坑指南:修改后,必须保存:ctrl+S: 1:官方工具:https://mp.weixin.qq.com/debug/w ... tml?t=1476434678461 2:简易教

聊聊程序员如何学习英语单词:写了一个记单词的小程序

背景: 关于英文对程序员的重要性,就不多说了! 英语的学习,有很多,今天也不聊多,只聊英语单词! 关于单词的记忆,找过很多方法,下载过很多软件. 如图(其它不好用的都卸载了): 上图算是我以前用过软件,注意,是以前哦~~~ 意思就是没有坚持下来~~~~ 随时间的推移,最后它们还是被我遗忘了~~~ 为什么???不能:坚持!坚持!坚持! 学习思考: 一直在找方法: 1:下载过联想记忆法.背文章记单词,词根,各种视频~~~ 2:连单词的数据库都网上下载了一份了,期望从数据库的直接记忆单词快些~~~ 通

个人小程序实现自然语言对话工程查询--快递,身份证,词典,天气等功能完整代码解析

这个小程序旨在通过自然语言对话查询快递.身份证.天气.诗歌.词典等等的功能. 自然语言对话,即使用中文语言直接对程序下命令,比如:‘查一下天气’,“帮我查一下123456这个运单号吧”,“我想听李白的静夜思”等等. 如果还是不明白,请阅读博客 https://i.cnblogs.com/EditPosts.aspx?postid=7203097&update=1 的前言部分. 1. 小程序功能介绍 如果希望直接体验小程序,请直接扫描下面的二维码,这样更直观. 但是发布的小程序里没有身份证查询,因

小程序粉墨登场 --奉上开发教程及书籍合集

微信小程序,简称CX,是一种不需要下载安装即可使用的应用,它实现了应用“触手可及”的梦想,用户扫一扫或搜一下即可打开应用. 小程序处于内测阶段.全面开放申请后,主体类型为个人.企业.政府.媒体或其他组织的开发者,均可申请注册小程序.小程序.订阅号.服务号.企业号是并行的体系. 张小龙在2017微信公开课Pro上发布的小程序于1月9日正式上线. 问题解答: Q:小程序是什么?它有着什么样的功能? A:小程序是一种不需要下载安装即可使用的应用,它实现了应用“触手可及”的梦想,用户扫一扫或者搜一下即可

(离线)英语词典软件推荐

(离线)英语词典软件推荐 MDict Lingoes GoldenDict 欧路 所有软件截图均原创!(为了了解我也够拼了...) 词典数据格式说明: 灵格斯词霸(.ld2) MDict(.mdx,.mdd) GoldenDict(...) 欧路(.eudic,.ld2,.bgl,.mdx .mdd,.tar.gz) 1 MDict MDict for PC 2.0 RC2-win7 MDict软件本身并不提供"词库"(mdx文件),但软件作者提供了词库制作工具(MDXBuilder)

案例:用python实现翻译小程序

案例:翻译小程序 #实现一个翻译小程序 #1 可以查询单词 #2 可以自定义补充单词解释 #3 可以删除某个单词 print('欢迎来到大宝dayday见小词典'.center(30,'-')) orig_dict = {'中文':'chinese','代码':'code','字典':'dict','英语':'english'} query = input('请输入你要查询的中文:') # 判断是否存在 if(orig_dict.get('query')): print(f'你查询的中文:{qu

关注这一个小程序 同时拥有6个小程序的功能

在我们日常生活中,数据查询服务越来越多,比如快递查询.黄页查询,如果出国旅游,英语不好的人难免对话成问题,吃饭点餐也可能带来误会. 这款小程序可以解决上述的烦忧,扫描下面二维码,关注. 首先打开的首页 快递查询 支持2种录入方式.文本录入或快递单条形码扫描 电话黄页 记录一些紧急电话和常用电话,而且可以直接拨打 单位转换 主要提供计量单位间的转换,如:长度.面积.体积.时间等.适用于辅助中小学生 汇率转换 可以查看人民币和不同币种间的汇率转换. 以上功能是这个小程序的基本功能,它其实还可以同时打

「4.0」一个人开发一个App,小程序从0到1,布局

一提到布局这个词,我总是索索发抖,不是因为天冷,而是因为布局的目标实在太宏大.古代想雄霸天下的王,就喜欢布局这个,布局那个,结果硬生生把自己的国家给布局没了.至于是哪个君王,我倒可以非常认真,非常坦诚地告诉你,那个人不是我,也不是你. 否则我们哪有时间在这里用小程序布局手机界面.一个小小手机界面,就有很多花样,那跟大饼脸脸一样大的平板, 不是需要花费更多功夫? 其实可以不是的,只要你在布局界面的时候,留多点空白就好了.更最简单的办法,就是全部空白,什么都不放,只是这样的话,老板会让你早点滚蛋.如

微信小程序源码下载(200多个)

微信小程序源码下载汇总,点击标题进入对应的微信小程序下载页面. 最新 demo源码(点击标题进入帖子下载) 描述 1 微信小程序 会议室预定小程序 微信小程序 会议室预定小程序**** 本内容被作者隐藏 **** 2 微信小程序-双人五子棋小游戏 微信小程序-双人五子棋小游戏**** 本内容被作者隐藏 **** 3 打卡签到小程序 用微信小程序实现的一个简单的打卡签到的小程序拒绝 4 微信小程序---左滑删除 微信小程序---左滑删除**** 本内容被作者隐藏 **** 5 一个借钱的记事本的微