- 浏览: 992355 次
- 性别:
- 来自: 珠海
文章分类
最新评论
-
熊猫仙:
请问,这个程序可以和BLE蓝牙设备通讯吗?
C#编程连接蓝牙设备,文件收发 -
lsy234009:
“这个电脑蓝牙不可用!”原因多半是你没打开蓝牙
C#编程连接蓝牙设备,文件收发 -
wujie_cnhn:
这个加密压缩后, linux环境下可以解压缩吗
好用java开源zip压缩解压类库Zip4j -
asdf_2012:
兄弟简单明了。顶你
C#使用Event在窗体之间传递消息和参数 -
xkb281:
简单易懂 不像有的文章 介绍一大堆没整明白是什么地下 赞一个 ...
Android网络请求框架Retrofit使用笔记
UnzipAssets.java
package com.hu.andstar; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.util.zip.ZipEntry; import java.util.zip.ZipInputStream; import android.content.Context; public class UnzipAssets { /** * 解压assets的zip压缩文件到指定目录 * @param context上下文对象 * @param assetName压缩文件名 * @param outputDirectory输出目录 * @param isReWrite是否覆盖 * @throws IOException */ public static void unZip(Context context, String assetName, String outputDirectory,boolean isReWrite) throws IOException { //创建解压目标目录 File file = new File(outputDirectory); //如果目标目录不存在,则创建 if (!file.exists()) { file.mkdirs(); } //打开压缩文件 InputStream inputStream = context.getAssets().open(assetName); ZipInputStream zipInputStream = new ZipInputStream(inputStream); //读取一个进入点 ZipEntry zipEntry = zipInputStream.getNextEntry(); //使用1Mbuffer byte[] buffer = new byte[1024 * 1024]; //解压时字节计数 int count = 0; //如果进入点为空说明已经遍历完所有压缩包中文件和目录 while (zipEntry != null) { //如果是一个目录 if (zipEntry.isDirectory()) { file = new File(outputDirectory + File.separator + zipEntry.getName()); //文件需要覆盖或者是文件不存在 if(isReWrite || !file.exists()){ file.mkdir(); } } else { //如果是文件 file = new File(outputDirectory + File.separator + zipEntry.getName()); //文件需要覆盖或者文件不存在,则解压文件 if(isReWrite || !file.exists()){ file.createNewFile(); FileOutputStream fileOutputStream = new FileOutputStream(file); while ((count = zipInputStream.read(buffer)) > 0) { fileOutputStream.write(buffer, 0, count); } fileOutputStream.close(); } } //定位到下一个文件入口 zipEntry = zipInputStream.getNextEntry(); } zipInputStream.close(); } }
用于第一次运行时解压数据文件到SD卡:
MainActivity.java:
package com.hu.andstar; import java.io.File; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.app.AlertDialog.Builder; import android.content.DialogInterface; import android.content.Intent; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.text.Editable; import android.text.TextWatcher; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.View.OnClickListener; import android.widget.AdapterView; import android.widget.ArrayAdapter; import android.widget.EditText; import android.widget.ImageButton; import android.widget.ListView; import android.widget.TextView; public class MainActivity extends Activity { // 指定数据库文件所在目录 private final String DATABASE_PATH = android.os.Environment .getExternalStorageDirectory().getAbsolutePath() + "/andstar"; // 指定数据库文件名 private final String DATABASE_FILENAME = "data.db"; private SQLiteDatabase database = null; private EditText etInput = null; private ImageButton ibSearch = null; private ListView lvWords = null; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 找到控件 etInput = (EditText) findViewById(R.id.editTextInput); ibSearch = (ImageButton) findViewById(R.id.imageButtonSearch); lvWords = (ListView) findViewById(R.id.listViewWords); initAll(); } private void initAll() { // 获取并打开数据库 database = openDatabase(); // 设置ListView数据 lvWords.setAdapter(getIndexs("")); // 当输入框文本改变时,让ListView现实的数据也随之改变 etInput.addTextChangedListener(new TextWatcher() { public void onTextChanged(CharSequence s, int start, int before, int count) { } public void beforeTextChanged(CharSequence s, int start, int count, int after) { } public void afterTextChanged(Editable s) { // 重新设置ListView的数据 lvWords.setAdapter(getIndexs(etInput.getText().toString())); } }); // 当ListView子项单击时,让文本框内容变成该项文本 lvWords.setOnItemClickListener(new AdapterView.OnItemClickListener() { public void onItemClick(AdapterView<?> parent, View view, int position, long id) { etInput.setText(((TextView) view).getText()); etInput.selectAll(); } }); // 设置查询按钮事件 ibSearch.setOnClickListener(new OnClickListener() { public void onClick(View v) { // 查询SQL语句 String sql = "SELECT dContent FROM words WHERE dIndex = @arg"; Cursor cursor = database.rawQuery(sql, new String[] { etInput .getText().toString() }); // 如果查询有结果,将第一个结果传递给显示结果的Activity if (cursor.getCount() > 0) { cursor.moveToFirst(); Intent intent = new Intent(); intent.putExtra("word", etInput.getText().toString()); intent.putExtra("explain", cursor.getString(0)); cursor.close(); intent.setClass(MainActivity.this, ExplainActivity.class); MainActivity.this.startActivity(intent); } } }); } // 获取ListView所要显示的数据 ArrayAdapter<String> getIndexs(String input) { List<String> list = new ArrayList<String>(); // 获取32条大于等于该文本的数据 String sql = "SELECT dIndex FROM words WHERE dIndex >= @arg limit 0,32"; // 执行查询语句 Cursor cursor = database.rawQuery(sql, new String[] { input }); if (cursor.getCount() > 0) { while (cursor.moveToNext()) { list.add(cursor.getString(0)); } cursor.close(); } else {// 如果获取结果为空 list.add(getString(R.string.no_match)); } return new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_list_item_1, list);// 返回ArrayAdapter } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.activity_main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // 退出选项 if (item.getItemId() == R.id.menu_exit) { Builder builder = new Builder(MainActivity.this); builder.setMessage("确认退出吗?"); builder.setTitle("提示"); builder.setPositiveButton(R.string.button_positive, new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int which) { System.exit(0); } }); builder.setNegativeButton(R.string.button_cancle, null); builder.show(); } else { } return super.onOptionsItemSelected(item); } private SQLiteDatabase openDatabase() {// 打开数据库函数 try { String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME; File databaseFile = new File(databaseFilename); // 如果SD卡上数据库文件不存在,则解压数据库文件 if (!databaseFile.exists()) { UnzipAssets.unZip(MainActivity.this, "data.zip", DATABASE_PATH, true); } // 返回打开的数据库 return SQLiteDatabase.openOrCreateDatabase(databaseFilename, null); } catch (Exception e) { e.printStackTrace(); } return null; } }
查词界面;
ExplainActivity.java
package com.hu.andstar; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.webkit.WebView; import android.widget.TextView; /*用于显示查询结果 * 使用WebView显示 */ public class ExplainActivity extends Activity{ private TextView tvWord = null; private WebView tvExplain = null; @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.activity_explain); tvWord = (TextView) findViewById(R.id.textViewWord); tvExplain = (WebView) findViewById(R.id.webViewExplain); Intent intent = getIntent(); tvWord.setText(intent.getStringExtra("word")); String htmText = intent.getStringExtra("explain"); tvExplain.loadDataWithBaseURL(null,htmText, "text/html", "utf-8", null); } }
用于显示解释:
发表评论
-
Android使用TabLayout与ViewPager结合以及TabItem自定义
2017-09-13 17:25 13313使用android的design支持包中的android. ... -
Android网络请求框架Retrofit使用笔记
2016-04-05 18:09 3768Retrofit是一个安卓端开源网络请求库,目前依赖于ok ... -
RxJava在Android中使用笔记
2016-03-31 14:20 1879使用RxJava可以方便实现观察者模式,数据转换和线程之间 ... -
AndroidStudio中使用NDK编译器笔记
2015-09-25 10:20 2519使用的AndroidStudio版本是1.3.2,可以支持 ... -
Android中ListView常用方式:使用BaseAdapter
2015-04-08 13:57 3328ListView最基础用法: 给ListView设 ... -
Android控件ViewPager与Fragment基础用法
2015-04-07 14:09 6106ViewPager与Fragment实现页面滑动效 ... -
Android 本地开发自动向量化提高效率
2015-02-26 14:56 0从书 <<Android C++ 高级编程 -- ... -
Android使用StaticLayout实现文本绘制自动换行
2015-01-12 21:15 16859使用的场景主要是绘制文本的时候指定绘制区域的宽度,文本需要 ... -
Android实现图片单点旋转缩放保存-仿百度魔图
2015-01-09 22:36 2274当拖动右下角区域时执行围绕图像中心旋转,缩放的操作,拖动其 ... -
Android 使用NDK (JNI)简单解压7z压缩文件
2014-08-16 21:24 10016C语言使用LZMA SDK解压非加密7z文件介绍: ... -
NDK小实例使用QQwry实现Android端IP归属地查询
2014-07-05 00:08 1340学习做一个使用NDK的小项目: QQWry的格式和解析可 ... -
Android弹出对话框的使用
2013-09-20 17:30 2241我们在平时做开发的时候,免不了会用到各种各样的对话框,相信 ... -
Android手势识别和双击事件
2013-09-19 18:16 7289安卓触摸屏的手势识别在很多时候会使用户操作更加方便: 实 ... -
Android中使用jni进行本地开发
2012-10-27 08:49 3349首先要下载eclipse_java,安装ADT,CDT,NDK ... -
Android将assets中的zip压缩文件解压到SD卡
2012-10-24 13:57 10981程序首先要获取写外部存储权限: 程序: package c ... -
Android中绘图的抗锯齿效果
2012-09-14 19:22 12861.使用Paint绘制简单图形 paint.setAntiA ... -
Android在SD卡上的文件读写
2012-09-11 18:14 1386该程序实现将字符串保存到文件,读取文件。 首先要获取外部存储 ... -
Android使用View类动画
2012-07-31 22:35 998package com.hu.move; impor ... -
Android采用SharedPreferences保存数据
2012-07-31 22:21 866使用SharedPreferences在程序的数据空间中生成x ... -
Android在SurfaceView绘图
2012-07-30 22:45 1489MainActivity package com.examp ...
相关推荐
【Android应用源码简单的云词典】是一款基于Android平台的开源项目,旨在为用户提供便捷的在线词汇查询功能,实现类似云服务的词典应用。这个项目对于学习Android开发,特别是对移动应用中的网络数据交互、UI设计...
在Android平台上实现一个简单的电子词典,涉及到的关键技术主要包括Android应用开发基础、SQLite数据库管理和用户界面设计。下面将详细介绍这些知识点。 首先,Android应用开发基础是实现电子词典的基石。这包括...
本项目"基于Android的移动应用中英文电子词典源码(so easy)"提供了一个简单易懂的源码示例,帮助开发者快速理解和实践Android应用开发。 首先,这个应用的核心功能是词典查询。它可能包含以下几个关键组件: 1. ...
【标题】"Android源码——中英文电子词典源码(so easy).7z" 涉及的是一个Android应用程序开发项目,该项目旨在创建一个功能完善的中英文电子词典。开发者通过这个源码可以深入理解Android应用的构建过程,特别是...
如果只是简单地将单个汉字转换为拼音,使用开源库通常是最快速和简便的方式。而如果涉及到大量的汉字处理,可能需要考虑自建词典或使用网络服务。在实现过程中,需要注意性能优化,避免因大量拼音转换导致的内存消耗...
此应用的设计充分利用了Android的优势,提供了移动端的便捷性,操作简单,内容更新迅速。测试表明,系统运行稳定,能有效帮助用户识字,对学习汉语具有实用性价值。综合来看,这个基于Android的中华有词手机应用为...
安卓源码包 UI布局 textView SQLSEVER&安卓 Tab选项卡Android例子源码 33个合集: [四次元]Android ViewPager Fragment实现选项卡.rar [四次元]Android 操作数据库实例.zip [四次元]android 通过jdts.jar 连接SQL...
在项目中,"WiktionarySimple"暗示了应用的目标是实现一个简单的词典功能,可能包括搜索、浏览和解释单词。这就需要开发者对Wiktionary API有深入理解,了解如何发起HTTP请求,以及解析JSON数据。Android提供了一...
在这个章节,可能会使用SQLite数据库创建一个简单的词汇表,包含单词和对应的翻译。你需要创建数据库帮助类,实现数据的插入、查询和删除操作。 5. **查询与显示结果**:当用户输入单词并触发查询后,应用将使用...