热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

本地数据库词典

本文章采用主要引用了本地数据库进行词典构建,之前上传的网页版的词典也是在此基础上进行改造,因此把本地数据库版的版本上传分享一下,依然添加下

本文章采用主要引用了本地数据库进行词典构建,之前上传的网页版的词典也是在此基础上进行改造,因此把本地数据库版的版本上传分享一下,依然添加下拉菜单,此内容属于本地数据库进行连接进行自动提示。

1.MainActivity

package com.example.happydictionary;import java.util.ArrayList;
import java.util.List;import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.webkit.WebView;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;import com.example.happydictionary.dao.WordDao;
import com.example.happydictionary.db.DBHelper;public class MainActivity extends Activity {private WordDao wordDao;private EditText etWord;private TextView tvResult;private AutoCompleteTextView ac;// protected void onCreate1(Bundle savedInstanceState) {// super.onCreate(savedInstanceState);// setContentView(R.layout.activity_main);//// initViews();// }@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);SetView();}// private void initViews() {// // TODO Auto-generated method stub//// }private Button btnSearch;// private EditText editText;private WebView reswebView;private WebView wvSearchResult;private void SetView() {btnSearch = (Button) findViewById(R.id.btnSearch);// etWord = (EditText) findViewById(R.id.etWord);tvResult = (TextView) findViewById(R.id.tvSearchResult);ac = (AutoCompleteTextView)findViewById(R.id.etWord);/*** 原来的editText换成了AutoCompleteTextView*/DBHelper helper = new DBHelper(MainActivity.this);SQLiteDatabase db = helper.openDatabase();// Cursor cur = db.query("dictionary", new String[] { "t_words" },// null, null, null, null, null);String sql = "select english from t_words";Cursor cur = db.rawQuery(sql, null);int i = 0;int j = 0;List list = new ArrayList();while (cur.moveToNext()) {String chinese = cur.getString(cur.getColumnIndex("english"));list.add(chinese);}//// String[] countries = new String[] { "Afghanistan", "Albania",// "Algeria", "American Samoa", "Andorra" };// 这里只举例说明,数据较少AutoCompleteTextView autoCompleteTextView = (AutoCompleteTextView) findViewById(R.id.etWord);// 找到相应的控件ArrayAdapter adapter = new ArrayAdapter(this,R.layout.list_item, list);// 配置AdaptorautoCompleteTextView.setAdapter(adapter);btnSearch.setOnClickListener(new OnClickListener() {public void onClick(View v) {
// String strUri = etWord.getText().toString();
// strUri = strUri.trim();
// if (strUri.length() == 0) {
// Toast.makeText(getApplicationContext(), "请输入查询字符", 1)
// .show();
// } else {
// String strURL = "http://dict.youdao.com/m/search?keyfrom=dict.mindex&q="
// + strUri;
// // 这个地方抛出空指针异常,我没学过这个方法,没办法,不知道这个有道接口格式
// reswebView.loadUrl(strURL);
// }WordDao wd = new WordDao(MainActivity.this);String chinese = wd.getChinese(ac.getText().toString());tvResult.setText(ac.getText().toString()+"\n"+chinese);}});}}



2.WordDao.java

package com.example.happydictionary.dao;import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;import com.example.happydictionary.db.DBHelper;public class WordDao {private DBHelper dbHelper;private SQLiteDatabase sqLiteDatabase;public WordDao(Context context){dbHelper=new DBHelper(context);}public String getChinese(String english){sqLiteDatabase=dbHelper.openDatabase();String sql="select chinese from t_words where english=?";Cursor cursor=sqLiteDatabase.rawQuery(sql, new String[]{english});String chinese="查无该词";if(cursor.moveToFirst()){chinese=cursor.getString(cursor.getColumnIndex("chinese"));}return chinese;}
}



3.DBHelper.java

package com.example.happydictionary.db;import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;import com.example.happydictionary.R;
import com.example.happydictionary.R.raw;import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.os.Environment;
import android.util.Log;/*** 实现将数据库文件从raw目录拷贝到手机里存放数据库的位置* * @author cabbage*/
public class DBHelper {private final int BUFFER_SIZE = 400000;public static final String DB_NAME = "idiom.db"; // 保存的数据库文件名public static final String PACKAGE_NAME = "com.example.happydictionary";// 应用的包名public static final String DB_PATH = "/data"+ Environment.getDataDirectory().getAbsolutePath() + "/"+ PACKAGE_NAME + "/databases";/*// SDCard 定义数据库的存放路径private final String DATABASE_PATH = android.os.Environment.getExternalStorageDirectory().getAbsolutePath() + "/dictionary";*/private Context context;public DBHelper(Context context) {this.context = context;}public SQLiteDatabase openDatabase() {try {File myDataPath = new File(DB_PATH);if (!myDataPath.exists()) {myDataPath.mkdirs();// 如果没有这个目录则创建}String dbfile = myDataPath + "/" + DB_NAME;if (!(new File(dbfile).exists())) {// 判断数据库文件是否存在,若不存在则执行导入,否则直接打开数据库InputStream is = context.getResources().openRawResource(R.raw.dictionary); // 欲导入的数据库FileOutputStream fos = new FileOutputStream(dbfile);byte[] buffer = new byte[BUFFER_SIZE];int count = 0;while ((count = is.read(buffer)) > 0) {fos.write(buffer, 0, count);}Log.v("###", "bucunzai");fos.close();is.close();}SQLiteDatabase db = SQLiteDatabase.openOrCreateDatabase(dbfile,null);Log.v("###", "cunzai");return db;} catch (FileNotFoundException e) {Log.e("###", "File not found");e.printStackTrace();} catch (IOException e) {Log.e("###", "IO exception");e.printStackTrace();}return null;}
}



4.Word.java

package com.example.happydictionary.entity;public class Word {private String english;private String chinese;public String getEnglish() {return english;}public void setEnglish(String english) {this.english = english;}public String getChinese() {return chinese;}public void setChinese(String chinese) {this.chinese = chinese;}}



5.DBHelperTest.java

package com.example.happydictionary.test;import com.example.happydictionary.db.DBHelper;import android.test.AndroidTestCase;public class DBHelperTest extends AndroidTestCase {public void testCreateDB(){DBHelper dbHelper=new DBHelper(getContext());dbHelper.openDatabase();}
}



6.activity_mian.xml


7.list_item.xml






8.menu>mian.xml




9.strings.xml


电子词典SettingsHello world!请输入您要查询的单词查询






推荐阅读
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 展开全部下面的代码是创建一个立方体Thisexamplescreatesanddisplaysasimplebox.#Thefirstlineloadstheinit_disp ... [详细]
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • iOS Swift中如何实现自动登录?
    本文介绍了在iOS Swift中如何实现自动登录的方法,包括使用故事板、SWRevealViewController等技术,以及解决用户注销后重新登录自动跳转到主页的问题。 ... [详细]
  • IOS开发之短信发送与拨打电话的方法详解
    本文详细介绍了在IOS开发中实现短信发送和拨打电话的两种方式,一种是使用系统底层发送,虽然无法自定义短信内容和返回原应用,但是简单方便;另一种是使用第三方框架发送,需要导入MessageUI头文件,并遵守MFMessageComposeViewControllerDelegate协议,可以实现自定义短信内容和返回原应用的功能。 ... [详细]
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
author-avatar
张嫱的小屋_133
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有