- 浏览: 984828 次
- 性别:
- 来自: 珠海
文章分类
最新评论
-
熊猫仙:
请问,这个程序可以和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 13180使用android的design支持包中的android. ... -
Android网络请求框架Retrofit使用笔记
2016-04-05 18:09 3726Retrofit是一个安卓端开源网络请求库,目前依赖于ok ... -
RxJava在Android中使用笔记
2016-03-31 14:20 1842使用RxJava可以方便实现观察者模式,数据转换和线程之间 ... -
AndroidStudio中使用NDK编译器笔记
2015-09-25 10:20 2452使用的AndroidStudio版本是1.3.2,可以支持 ... -
Android中ListView常用方式:使用BaseAdapter
2015-04-08 13:57 3279ListView最基础用法: 给ListView设 ... -
Android控件ViewPager与Fragment基础用法
2015-04-07 14:09 6063ViewPager与Fragment实现页面滑动效 ... -
Android 本地开发自动向量化提高效率
2015-02-26 14:56 0从书 <<Android C++ 高级编程 -- ... -
Android使用StaticLayout实现文本绘制自动换行
2015-01-12 21:15 16747使用的场景主要是绘制文本的时候指定绘制区域的宽度,文本需要 ... -
Android实现图片单点旋转缩放保存-仿百度魔图
2015-01-09 22:36 2224当拖动右下角区域时执行围绕图像中心旋转,缩放的操作,拖动其 ... -
Android 使用NDK (JNI)简单解压7z压缩文件
2014-08-16 21:24 9923C语言使用LZMA SDK解压非加密7z文件介绍: ... -
NDK小实例使用QQwry实现Android端IP归属地查询
2014-07-05 00:08 1290学习做一个使用NDK的小项目: QQWry的格式和解析可 ... -
Android弹出对话框的使用
2013-09-20 17:30 2203我们在平时做开发的时候,免不了会用到各种各样的对话框,相信 ... -
Android手势识别和双击事件
2013-09-19 18:16 7231安卓触摸屏的手势识别在很多时候会使用户操作更加方便: 实 ... -
Android中使用jni进行本地开发
2012-10-27 08:49 3291首先要下载eclipse_java,安装ADT,CDT,NDK ... -
Android将assets中的zip压缩文件解压到SD卡
2012-10-24 13:57 10803程序首先要获取写外部存储权限: 程序: package c ... -
Android中绘图的抗锯齿效果
2012-09-14 19:22 12541.使用Paint绘制简单图形 paint.setAntiA ... -
Android在SD卡上的文件读写
2012-09-11 18:14 1315该程序实现将字符串保存到文件,读取文件。 首先要获取外部存储 ... -
Android使用View类动画
2012-07-31 22:35 948package com.hu.move; impor ... -
Android采用SharedPreferences保存数据
2012-07-31 22:21 830使用SharedPreferences在程序的数据空间中生成x ... -
Android在SurfaceView绘图
2012-07-30 22:45 1449MainActivity package com.examp ...
相关推荐
Android 数据库SQLite 详解,简单学好SQLite
通过sqlite实现最简单的记事本的增删改查
android利用sqlite实现增删改查
android SQLite实现本地登录注册功能,SQLite简单应用(android studio)
本人博客:Android储存---SQLite数据库的简单使用,实现增删改查demo
Android+SQlite 简单的《学生信息管理系统》(实现基本增删改查) 此代码中还有与其相对应的apk文件(在SIMS/bin目录中),大家可先行放手机上看一下效果。 希望对初学者有一定的帮助。(本人自己编写)
SQLite 是非常小的,是轻量级的,完全配置时小于 400KiB,省略可选功能配置时小于250KiB。 SQLite 是自给自足的,这意味着不需要任何外部的依赖。 SQLite 事务是完全兼容 ACID 的,允许从多个进程或线程安全访问。 ...
android之利用SQLite数据库实现登陆和注册,使用SQLiteOpenHelper抽象类建立数据库,建立数据库类DatabaseHelper,写业务类实现查询和插入
android之SQLite数据库开发详解: Android 开发中使用 SQLite 数据库 简介: SQLite 是一款非常流行的嵌入式数据库,它支持 SQL 查询,并且只用很少的内存。Android 在运行时集成了 SQLite,所以每个 Android 应用...
sqlite-android一个Android SQLite支持库
Android数据库SQLite的例子 根据扣丁课堂的教程学习 Android数据库SQLite的例子 Android数据库SQLite的例子
Android Studio SQLite数据库使用
简易词典,关于sqlite的一些用法实例,本实例可以实现单词的添加,单词的查询,主要通过SQLite实现,并且包含listVew的一些相应用法
android的SQlite完整demo实现
一个简单的Android SQLite ORM框架不想花资源分的同学可以上我的github主页下载:https://github.com/chenyihan/Simple-SQLite-ORM-Android,因为要传到github,所以代码中的注释和doc文档都是英文的,对自己英文不...
Android 数据库SQLite的简单使用,实现我的便签
在Android studio上实现了sqlite的数据的新建、查询、添加、删除等功能。
arcgis for android 读取空间数据库,用“JDBC”连接数据库