有道词典的查询

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     android:background="@drawable/mainbg"  
  6.     android:paddingBottom="@dimen/activity_vertical_margin"  
  7.     android:paddingLeft="@dimen/activity_horizontal_margin"  
  8.     android:paddingRight="@dimen/activity_horizontal_margin"  
  9.     android:paddingTop="@dimen/activity_vertical_margin"  
  10.     tools:context=".MainActivity" >  
  11.   
  12.     <AutoCompleteTextView  
  13.         android:id="@+id/etWord"  
  14.         android:layout_width="wrap_content"  
  15.         android:layout_height="wrap_content"  
  16.         android:layout_alignParentLeft="true"  
  17.         android:layout_alignParentTop="true"  
  18.         android:layout_marginTop="31dp"  
  19.         android:background="@android:drawable/edit_text"  
  20.         android:ems="10"  
  21.         android:hint="@string/searchHint"  
  22.         android:singleLine="true"  
  23.         android:textColor="#552006"  
  24.         android:textColorHint="#782f10" >  
  25.   
  26.     </AutoCompleteTextView>  
  27.   
  28.     <Button  
  29.         android:id="@+id/btnSearch"  
  30.         android:layout_width="wrap_content"  
  31.         android:layout_height="wrap_content"  
  32.         android:layout_alignBaseline="@+id/etWord"  
  33.         android:layout_alignBottom="@+id/etWord"  
  34.         android:layout_marginLeft="16dp"  
  35.         android:layout_toRightOf="@+id/etWord"  
  36.         android:background="@drawable/ibsearchword"  
  37.         android:onClick="searchWord"  
  38.         android:text="@string/serachWord" />  
  39.   
  40.     <TextView  
  41.         android:id="@+id/tvSearchResult"  
  42.         android:layout_width="match_parent"  
  43.         android:layout_height="match_parent"  
  44.         android:layout_alignLeft="@+id/etWord"  
  45.         android:layout_below="@+id/etWord"  
  46.         android:layout_marginTop="22dp"  
  47.         android:textSize="25sp"  
  48.         android:background="@drawable/bg_roundcorner"  
  49.         android:textAppearance="?android:attr/textAppearanceMedium" />  
  50.   
  51. </RelativeLayout>  
[html]  view plain copy
  1. 分析:定义textview组件,来显示所查询的单词,又定义了<span style="font-family: Arial, Helvetica, sans-serif;">AutoCompleteTextView组件,可以查询显示多个单词的效果</span>  
[html]  view plain copy
  1. <pre name="code" class="html"><?xml version="1.0" encoding="utf-8"?>  
  2. <TextView xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:id="@+id/tvWordItem"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="wrap_content"  
  6.     android:gravity="center_vertical"  
  7.     android:minHeight="?android:attr/listPreferredItemHeight"  
  8.     android:paddingLeft="6dip"  
  9.     android:textAppearance="?android:attr/textAppearanceLarge"  
  10.     android:textColor="@color/gray" />  
[html]  view plain copy
  1. <pre name="code" class="html">import java.io.File;  
  2. import java.io.FileOutputStream;  
  3. import java.io.InputStream;  
  4.   
  5. import com.bzu.gxs.dao.DictionaryAdapter;  
  6. import com.bzu.gxs.db.DBHelper;  
  7. import com.bzu.gxs.R;  
  8.   
  9. import android.app.Activity;  
  10. import android.content.Context;  
  11. import android.database.Cursor;  
  12. import android.database.sqlite.SQLiteDatabase;  
  13. import android.os.Bundle;  
  14. import android.text.Editable;  
  15. import android.text.TextWatcher;  
  16. import android.util.Log;  
  17. import android.view.LayoutInflater;  
  18. import android.view.View;  
  19. import android.view.ViewGroup;  
  20. import android.view.View.OnClickListener;  
  21. import android.widget.AutoCompleteTextView;  
  22. import android.widget.Button;  
  23. import android.widget.CursorAdapter;  
  24. import android.widget.TextView;  
  25.   
  26. public class Dictionary extends Activity implements OnClickListener,  
  27.         TextWatcher {  
  28.     private DBHelper dbHelper; // 用户输入文本框  
  29.     private AutoCompleteTextView word; // 定义数据库的名字  
  30.     private SQLiteDatabase database;  
  31.     private Button searchWord; // 搜索按钮  
  32.     private TextView showResult; // 用户显示查询结果  
  33.   
  34.     @Override  
  35.     public void onCreate(Bundle savedInstanceState) {  
  36.         super.onCreate(savedInstanceState);  
  37.         setContentView(R.layout.activity_main);  
  38.   
  39.         dbHelper = new DBHelper(getBaseContext());// 打开数据库  
  40.         database = dbHelper.openDatabase();  
  41.   
  42.         init();  
  43.   
  44.         searchWord.setOnClickListener(this); // 绑定监听器  
  45.         word.addTextChangedListener(this); // 绑定文字改变监听器  
  46.   
  47.     }  
  48.   
  49.     public void init() {  
  50.         searchWord = (Button) findViewById(R.id.btnSearch);  
  51.         word = (AutoCompleteTextView) findViewById(R.id.etWord);  
  52.         showResult = (TextView) findViewById(R.id.tvSearchResult);  
  53.   
  54.     }  
  55.   
  56.     public void afterTextChanged(Editable s) {  
  57.         Cursor cursor = database.rawQuery(  
  58.                 "select english as _id from t_words where english like ?",  
  59.                 new String[] { s.toString() + "%" });  
  60.           
  61.         // 新建新的Adapter  
  62.         DictionaryAdapter dictionaryAdapter = new DictionaryAdapter(this,cursor, true);  
  63.           
  64.         // 绑定适配器  
  65.         word.setAdapter(dictionaryAdapter);  
  66.   
  67.     }  
  68.   
  69.     public void beforeTextChanged(CharSequence s, int start, int count,  
  70.             int after) {  
  71.   
  72.     }  
  73.   
  74.     public void onTextChanged(CharSequence s, int start, int before, int count) {  
  75.   
  76.     }  
  77.   
  78.     public void onClick(View view) {  
  79.         // 查询指定的单词  
  80.         String sql = "select chinese from t_words where english=?";  
  81.           
  82.         Cursor cursor = database.rawQuery(sql, new String[] { word.getText()  
  83.                 .toString() });  
  84.           
  85.         String result = "查无该词"; // 如果查找单词,显示其中文的意思  
  86.           
  87.         if (cursor.getCount() > 0) {   
  88.               
  89.             cursor.moveToFirst(); // 须使用moveToFirst方法将记录指针移动到第1条记录的位置  
  90.             result = cursor.getString(cursor.getColumnIndex("chinese"))  
  91.                     .replace("&", "&");  
  92.         }  
  93.   
  94.         showResult.setText(word.getText() + "\n" + result.toString());// 将结果显示到TextView中  
  95.     }  
  96.   
  97. }  

分析: 调用适配器,通过textview组件,显示所要查询单词的结果
[html]  view plain copy
  1. </pre>  
[html]  view plain copy
  1. import android.content.Context;  
  2. import android.database.Cursor;  
  3. import android.view.LayoutInflater;  
  4. import android.view.View;  
  5. import android.view.ViewGroup;  
  6. import android.widget.CursorAdapter;  
  7. import android.widget.TextView;  
  8. import com.bzu.gxs.R;  
  9.   
  10. //自定义Adapter类  
  11. public class DictionaryAdapter extends CursorAdapter {  
  12.     private LayoutInflater layoutInflater;  
  13.   
  14.     @Override  
  15.     public CharSequence convertToString(Cursor cursor) {  
  16.         return cursor == null ? "" : cursor.getString(cursor  
  17.                 .getColumnIndex("_id"));  
  18.     }  
  19.   
  20.     // 将单词信息显示到列表中  
  21.     private void setView(View view, Cursor cursor) {  
  22.         TextView tvWordItem = (TextView) view;  
  23.         tvWordItem.setText(cursor.getString(cursor.getColumnIndex("_id")));  
  24.     }  
  25.   
  26.     // 绑定选项到列表中  
  27.     @Override  
  28.     public void bindView(View view, Context context, Cursor cursor) {  
  29.         setView(view, cursor);  
  30.     }  
  31.   
  32.     // 生成新的选项  
  33.     @Override  
  34.     public View newView(Context context, Cursor cursor, ViewGroup parent) {  
  35.         View view = layoutInflater.inflate(R.layout.word_list_item, null);  
  36.         setView(view, cursor);  
  37.         return view;  
  38.     }  
  39.   
  40.     public DictionaryAdapter(Context context, Cursor c, boolean autoRequery) {  
  41.         super(context, c, autoRequery);  
  42.         layoutInflater = (LayoutInflater) context  
  43.                 .getSystemService(Context.LAYOUT_INFLATER_SERVICE);  
  44.     }  
  45. }  

分析:自定义了一个Adapter适配器,通过调用 word_list_item布局,把所查询的单词传过来,绑定选项到列表,生成新的选项
 
[html]  view plain copy
  1. <span style="font-family:Arial, Helvetica, sans-serif;"></span><pre name="code" class="html">import java.io.File;  
  2. import java.io.FileOutputStream;  
  3. import java.io.InputStream;  
  4. import android.content.Context;  
  5. import android.database.sqlite.SQLiteDatabase;  
  6. import com.bzu.gxs.R;  
  7. public class DBHelper {  
  8.     //定义数据库的存放路径  
  9.         private final String DATABASE_PATH = android.os.Environment  
  10.                 .getExternalStorageDirectory().getAbsolutePath()  
  11.                 + "/dictionary";  
  12.         private final String DATABASE_FILENAME = "dictionary.db";  
  13.           
  14.         private Context context;  
  15.   
  16.         public DBHelper(Context context) {  
  17.             this.context = context;  
  18.         }  
  19.           
  20.           
  21.         public SQLiteDatabase openDatabase()  
  22.         {  
  23.             try  
  24.             {  
  25.                 // 获得dictionary.db文件的绝对路径  
  26.                 String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME;  
  27.                 File dir = new File(DATABASE_PATH);                                                                                                           
  28.                 // 如果/sdcard/dictionary目录中存在,创建这个目录  
  29.                 if (!dir.exists())  
  30.                     dir.mkdir();  
  31.                 // 如果在/sdcard/dictionary目录中不存在  
  32.                 // dictionary.db文件,则从res\raw目录中复制这个文件到  
  33.                 // SD卡的目录(/sdcard/dictionary)  
  34.                 if (!(new File(databaseFilename)).exists())  
  35.                 {  
  36.                     // 获得封装dictionary.db文件的InputStream对象  
  37.                     InputStream is = context.getResources().openRawResource(  
  38.                             R.raw.dictionary);  
  39.                     FileOutputStream fos = new FileOutputStream(databaseFilename);  
  40.                     byte[] buffer = new byte[8192];  
  41.                     int count = 0;  
  42.                     // 开始复制dictionary.db文件  
  43.                     while ((count = is.read(buffer)) > 0)  
  44.                     {  
  45.                         fos.write(buffer, 0, count);  
  46.                     }  
  47.                     //关闭文件流  
  48.                     fos.close();  
  49.                     is.close();  
  50.                 }  
  51.                 // 打开/sdcard/dictionary目录中的dictionary.db文件  
  52.                 SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(  
  53.                         databaseFilename, null);  
  54.                 return database;  
  55.             }  
  56.             catch (Exception e)  
  57.             {  
  58.             }  
  59.             //如果打开出错,则返回null  
  60.             return null;  
  61.         }  
  62.   
  63. }  

以下是对提供的参考资料的总结,按照要求结构化多个要点分条输出: 4G/5G无线网络优化与网规案例分析: NSA站点下终端掉4G问题:部分用户反馈NSA终端频繁掉4G,主要因终端主动发起SCGfail导致。分析显示,在信号较好的环境下,终端可能因节能、过热保护等原因主动释放连接。解决方案建议终端侧进行分析处理,尝试关闭节电开关等。 RSSI算法识别天馈遮挡:通过计算RSSI平均值及差值识别天馈遮挡,差值大于3dB则认定有遮挡。不同设备分组规则不同,如64T和32T。此方法可有效帮助现场人员识别因环境变化引起的网络问题。 5G 160M组网小区CA不生效:某5G站点开启100M+60M CA功能后,测试发现UE无法正常使用CA功能。问题原因在于CA频点集标识配置错误,修正后测试正常。 5G网络优化与策略: CCE映射方式优化:针对诺基亚站点覆盖农村区域,通过优化CCE资源映射方式(交织、非交织),提升RRC连接建立成功率和无线接通率。非交织方式相比交织方式有显著提升。 5G AAU两扇区组网:与三扇区组网相比,AAU两扇区组网在RSRP、SINR、下载速率和上传速率上表现不同,需根据具体场景选择适合的组网方式。 5G语音解决方案:包括沿用4G语音解决方案、EPS Fallback方案和VoNR方案。不同方案适用于不同的5G组网策略,如NSA和SA,并影响语音连续性和网络覆盖。 4G网络优化与资源利用: 4G室分设备利旧:面对4G网络投资压减与资源需求矛盾,提出利旧多维度调优策略,包括资源整合、统筹调配既有资源,以满足新增需求和提质增效。 宏站RRU设备1托N射灯:针对5G深度覆盖需求,研究使用宏站AAU结合1托N射灯方案,快速便捷地开通5G站点,提升深度覆盖能力。 基站与流程管理: 爱立信LTE基站邻区添加流程:未提供具体内容,但通常涉及邻区规划、参数配置、测试验证等步骤,以确保基站间顺畅切换和覆盖连续性。 网络规划与策略: 新高铁跨海大桥覆盖方案试点:虽未提供详细内容,但可推测涉及高铁跨海大桥区域的4G/5G网络覆盖规划,需考虑信号穿透、移动性管理、网络容量等因素。 总结: 提供的参考资料涵盖了4G/5G无线网络优化、网规案例分析、网络优化策略、资源利用、基站管理等多个方面。 通过具体案例分析,展示了无线网络优化中的常见问题及解决方案,如NSA终端掉4G、RSSI识别天馈遮挡、CA不生效等。 强调了5G网络优化与策略的重要性,包括CCE映射方式优化、5G语音解决方案、AAU扇区组网选择等。 提出了4G网络优化与资源利用的策略,如室分设备利旧、宏站RRU设备1托N射灯等。 基站与流程管理方面,提到了爱立信LTE基站邻区添加流程,但未给出具体细节。 新高铁跨海大桥覆盖方案试点展示了特殊场景下的网络规划需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值