Как реализовать функцию поиска в пользовательском ArrayAdapter с помощью SearchView?Android

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Как реализовать функцию поиска в пользовательском ArrayAdapter с помощью SearchView?

Сообщение Anonymous »

Я новичок в программировании Android, и у меня есть проблема, для которой я не могу найти решение. Я искал Stackoverflow в течение нескольких часов, но я все еще не совсем понял, как мне делать это: < /p>

Я создал тонкий API с PHP, который общается с локальным сервером XAMPP MySQL, и я могу выполнять основные операции CRUD на нем. Я получаю данные с API с сервера, который возвращает все «элементы» в базе данных в список, и я могу использовать это в списке. Каждый элемент списка имеет 6 TextViews, поэтому я создал пользовательский ArryAdapter, но я не знаю, чтобы искать конкретные элементы списка. < /p>

Класс мой элемент: < /p>

public class Item {

private String mName;
private String mQuantity;
private String mDate_added;
private String mBarcode;
private String mPrice;
private String mWarranty;
private int mId;

public Item(String mName, String mQuantity, String mDate_added, String mBarcode, String mPrice, String mWarranty,int mId) {
this.mName = mName;
this.mQuantity = mQuantity;
this.mDate_added = mDate_added;
this.mBarcode = mBarcode;
this.mPrice = mPrice;
this.mWarranty = mWarranty;
this.mId = mId;
}

public int getmId(){return mId; }

public String getmName() {
return mName;
}

public String getmQuantity() {
return mQuantity;
}

public String getmDate_added() {
return mDate_added;
}

public String getmBarcode() {
return mBarcode;
}

public String getmPrice() {
return mPrice;
}

public String getmWarranty() {
return mWarranty;
}
}
< /code>

Мой адаптер < /p>

public class ItemAdapter extends ArrayAdapter {

public ItemAdapter(Context context, ArrayList items) {
super(context,0, items);

}

@NonNull
@Override
public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {

View ListItemView= convertView;
if (ListItemView == null) {

ListItemView = LayoutInflater.from(getContext()).inflate(R.layout.list_item,parent,false);

Item currentItem = getItem(position);

TextView nameText = (TextView) ListItemView.findViewById(R.id.name);
TextView quantityText = (TextView) ListItemView.findViewById(R.id.quantity);
TextView date_addedText = (TextView) ListItemView.findViewById(R.id.date_added);
TextView barcodeText = (TextView) ListItemView.findViewById(R.id.barcode);
TextView priceText = (TextView) ListItemView.findViewById(R.id.price);
TextView warrantyText = (TextView) ListItemView.findViewById(R.id.warranty);

nameText.setText(currentItem.getmName());
quantityText.setText(currentItem.getmQuantity() +" e");
date_addedText.setText(currentItem.getmDate_added());
barcodeText.setText(currentItem.getmBarcode());
priceText.setText(currentItem.getmPrice()+ " pr/e");
warrantyText.setText(currentItem.getmWarranty());

}

return ListItemView;
}

}
< /code>

Я получаю данные с помощью метода httpurlconnection get, и я использую для этого Asynctaskloader. Это возвращает данные в список из данного URL. < /p>

public class ItemLoader extends AsyncTaskLoader {

private String mUrl;

public ItemLoader(Context context, String url) {
super(context);
mUrl = url;
}

@Override
protected void onStartLoading() {

forceLoad();
}

@Override
public List loadInBackground() {

if (mUrl == null) {
return null;
}

// Perform the network request, parse the response, and extract a list of items.
List items = QueryUtils.fetchItemData(mUrl);
return items;
}

}
< /code>

Далее, в моей основной деятельности я реализую обратные вызовы загрузчика. < /p>

private ItemAdapter mAdapter;

@Override
public android.content.Loader onCreateLoader(int i, Bundle bundle) {

return new ItemLoader(this,API_REQUEST_URL);
}

@Override
public void onLoadFinished(android.content.Loader loader, List items) {
mAdapter.clear();

if (items != null && !items.isEmpty()) {

mAdapter.addAll(items);
}

}

@Override
public void onLoaderReset(android.content.Loader loader) {
Log.e("init loader","Log");

mAdapter.clear();
}
< /code>

in oncreate < /p>

android.app.LoaderManager loaderManager = getLoaderManager();
loaderManager.initLoader(0, null, MainActivity.this);

listView.setAdapter(mAdapter);
< /code>

Я хочу искать имена элементов и вернуть соответствующее в списке. Я создал представление поиска для его с помощью setOnqueryTextListener: < /p>

@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_main,menu);

SearchManager manager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
SearchView search = (SearchView) menu.findItem(R.id.search).getActionView();
search.setSearchableInfo(manager.getSearchableInfo(getComponentName()));

search.setOnQueryTextListener(new SearchView.OnQueryTextListener() {

@Override
public boolean onQueryTextSubmit(String s) {

return false;
}

@Override
public boolean onQueryTextChange(String s) {

return false;
}

});

return true;
}
< /code>

aaand... теперь я вроде как застрял. Я знаю, что должен реализовать «фильтруемый» в классе адаптеров, переопределить некоторые методы, создать фильтр и т. Д., И это не так сложно, если у меня есть жесткий список, который мне просто нужно изменить, но эти сетевые запросы, фоновые потоки, получают данные с сервера, так много меня путали, я не знаю, что делать. < /p>

halp! : c

Подробнее здесь: https://stackoverflow.com/questions/479 ... searchview
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»