Computer >> Máy Tính >  >> Lập trình >> Android

Chế độ xem tìm kiếm trong Android là gì?

Trước khi đi vào ví dụ searchview, chúng ta nên biết search view trong android là gì, search view cũng giống như search box trong HTML. chúng tôi có thể tìm kiếm bất cứ thứ gì từ các mục danh sách cụ thể.

Ví dụ này minh họa về cách tích hợp chế độ xem tìm kiếm trong android.

Bước 1 - Tạo một dự án mới trong Android Studio, đi tới Tệp ⇒ Dự án Mới và điền tất cả các chi tiết cần thiết để tạo một dự án mới.

Bước 2 - Thêm mã sau vào res / layout / activity_main.xml.

<?xml version = "1.0" encoding = "utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android = "https://schemas.android.com/apk/res/android" xmlns:tools = "https://schemas.android.com/tools" android:layout_width = "match_parent" android:layout_height = "match_parent">
<LinearLayout
   android:layout_width = "match_parent"
   android:layout_height = "match_parent"
   android:orientation = "vertical">
   <android.support.v7.widget.SearchView
      android:id = "@+id/search"
      android:layout_width = "match_parent"
      android:layout_height = "wrap_content" />
   <ListView
      android:id = "@+id/list"
      android:layout_width = "wrap_content"
      android:layout_height = "wrap_content"/>
</LinearLayout>
</android.support.constraint.ConstraintLayout>

Trong đoạn mã trên, chúng tôi cung cấp chế độ xem tìm kiếm và chế độ xem danh sách vì chế độ xem tìm kiếm sẽ chuyển đến phần tử tìm kiếm từ danh sách.

Bước 3 - Thêm mã sau vào src / MainActivity.java

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.SearchView;
import android.widget.Toast;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity {
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      final ListView list = findViewById(R.id.list);
      SearchView search = findViewById(R.id.search);
      search.setActivated(true);
      search.setQueryHint("Type your keyword here");
      search.onActionViewExpanded();
      search.setIconified(false);
      ArrayList<String> arrayList = new ArrayList<>();
      arrayList.add("JAVA");
      arrayList.add("ANDROID");
      arrayList.add("C Language");
      arrayList.add("CPP Language");
      arrayList.add("Go Language");
      arrayList.add("AVN SYSTEMS");
      final ArrayAdapter<String> arrayAdapter = new ArrayAdapter<String>(this,                   android.R.layout.simple_list_item_1, arrayList);
      list.setAdapter(arrayAdapter);
      search.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
         @Override
         public boolean onQueryTextSubmit(String query) {
            return false;
         }
         @Override
         public boolean onQueryTextChange(String newText) {
            arrayAdapter.getFilter().filter(newText);
            return false;
         }
      });
      list.setOnItemClickListener(new AdapterView.OnItemClickListener() {
         @Override
         public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
            String clickedItem = (String) list.getItemAtPosition(position);
            Toast.makeText(MainActivity.this, clickedItem, Toast.LENGTH_LONG).show();
         }
      });
   }
}

Trong chế độ xem tìm kiếm ở trên, chúng tôi đã cung cấp một trình nghe là setOnQueryTextListener. Nó sẽ lắng nghe các thay đổi văn bản của bạn bằng hai phương pháp như được hiển thị bên dưới.

  • onQueryTextSubmit (Truy vấn chuỗi) - Sau khi nhập vào văn bản trong chế độ xem tìm kiếm, nếu bạn muốn làm bất cứ điều gì với chuỗi đó, bạn có thể thực hiện trong phương pháp này.

  • onQueryTextChange (String newText) - sau khi thay đổi văn bản có nghĩa là trong khi nhập văn bản vào chế độ xem tìm kiếm, nó sẽ thực hiện một số hành động.

Trong đoạn mã trên, chúng ta có văn bản bộ lọc trong khi truy vấn thay đổi như được hiển thị bên dưới

@Override
public boolean onQueryTextChange(String newText) {
   arrayAdapter.getFilter().filter(newText);
   return false;
}

Hãy thử chạy ứng dụng của bạn. Tôi giả sử bạn đã kết nối thiết bị Di động Android thực tế với máy tính của mình. Để chạy ứng dụng từ android studio, hãy mở một trong các tệp hoạt động của dự án của bạn và nhấp vào Chạy Chế độ xem tìm kiếm trong Android là gì? biểu tượng từ thanh công cụ. Chọn thiết bị di động của bạn làm tùy chọn, sau đó kiểm tra thiết bị di động sẽ hiển thị màn hình mặc định của bạn

Chế độ xem tìm kiếm trong Android là gì?

Bây giờ, hãy nhập một số văn bản phù hợp nhất với các mục listview như được hiển thị bên dưới

Chế độ xem tìm kiếm trong Android là gì?