Я новичок в программировании 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
Как реализовать функцию поиска в пользовательском ArrayAdapter с помощью SearchView? ⇐ Android
Форум для тех, кто программирует под Android
1759727865
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
Подробнее здесь: [url]https://stackoverflow.com/questions/47996650/how-to-implement-search-function-on-custom-arrayadapter-with-searchview[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия