Android 검색 상자 구성 요소 SearchView 의 기본 사용 방법

SearchView 는 안 드 로 이 드 시스템 에 내 장 된 검색 상자 구성 요소 로 사용자 인터페이스 에 쉽게 추가 할 수 있 지만 문제 도 가 져 왔 습 니 다.바로 searchview 의 UI 가 고정 되 어 있 고 맞 춤 형 제작 이 번 거 로 울 수 있 습 니 다.SearchView 에 대한 요구 가 높 으 면 button 과 EditText 로 스스로 실현 할 수 있 습 니 다.여기 서 먼저 Search View 의 사용 에 대해 간단히 말씀 드 리 겠 습 니 다.
main.xml:

<LinearLayout 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:orientation="vertical"
 tools:context=".Main" >

 <SearchView
  android:id="@+id/sv"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:imeOptions="actionGo" />

</LinearLayout>

suggestion 을 표시 할 때 다음 레이아웃 파일 을 사용 합 니 다:my textview.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="50sp"
 android:orientation="vertical" >

 <TextView
  android:id="@+id/textview"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:gravity="center_vertical"
  android:paddingLeft="5sp"
  android:textSize="18sp" />

</LinearLayout>

main.java:

package com.app.main;

import java.lang.reflect.Field;

import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.SearchView;
import android.widget.SearchView.OnQueryTextListener;
import android.widget.SimpleCursorAdapter;
import android.widget.Toast;

public class Main extends Activity {

 SearchView sv = null;
 ListView lv = null;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);

  sv = (SearchView) this.findViewById(R.id.sv);

  sv.setIconifiedByDefault(false);

  sv.setSubmitButtonEnabled(true);

  sv.setQueryHint("  ");

   //    ,       ,   android search_view.xml        
  
  try {
   Field field = sv.getClass().getDeclaredField("mSubmitButton");

   field.setAccessible(true);

   ImageView iv = (ImageView) field.get(sv);

   iv.setImageDrawable(this.getResources().getDrawable(
     R.drawable.pointer));


  } catch (Exception e) {

   e.printStackTrace();
  }

  Cursor cursor = this.getTestCursor();

  @SuppressWarnings("deprecation")
  SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,
    R.layout.mytextview, cursor, new String[] { "tb_name" },
    new int[] { R.id.textview });

  sv.setSuggestionsAdapter(adapter);

  sv.setOnQueryTextListener(new OnQueryTextListener() {

   @Override
   public boolean onQueryTextChange(String str) {

    return false;
   }

   @Override
   public boolean onQueryTextSubmit(String str) {

    Toast.makeText(Main.this, str, Toast.LENGTH_SHORT).show();

    return false;
   }

  });

 }
 
//  suggestion     
 public Cursor getTestCursor() {

  SQLiteDatabase db = SQLiteDatabase.openOrCreateDatabase(
    this.getFilesDir() + "/my.db3", null);

  Cursor cursor = null;
  try {

   String insertSql = "insert into tb_test values (null,?,?)";

   db.execSQL(insertSql, new Object[] { "aa", 1 });

   db.execSQL(insertSql, new Object[] { "ab", 2 });

   db.execSQL(insertSql, new Object[] { "ac", 3 });

   db.execSQL(insertSql, new Object[] { "ad", 4 });

   db.execSQL(insertSql, new Object[] { "ae", 5 });

   String querySql = "select * from tb_test";

   cursor = db.rawQuery(querySql, null);

  } catch (Exception e) {

   String sql = "create table tb_test (_id integer primary key autoincrement,tb_name varchar(20),tb_age integer)";

   db.execSQL(sql);

   String insertSql = "insert into tb_test values (null,?,?)";

   db.execSQL(insertSql, new Object[] { "aa", 1 });

   db.execSQL(insertSql, new Object[] { "ab", 2 });

   db.execSQL(insertSql, new Object[] { "ac", 3 });

   db.execSQL(insertSql, new Object[] { "ad", 4 });

   db.execSQL(insertSql, new Object[] { "ae", 5 });

   String querySql = "select * from tb_test";

   cursor = db.rawQuery(querySql, null);
  }

  return cursor;
 }

}

실현 효 과 는 다음 과 같다.


이상 은 검색 상자 구성 요소 인 SearchView 의 기본 적 인 사용 방법 입 니 다.참고 해 주시 고 많은 응원 부 탁 드 리 겠 습 니 다.

좋은 웹페이지 즐겨찾기