gpt4 book ai didi

Android 使用自定义阵列适配器

转载 作者:行者123 更新时间:2023-12-04 03:27:13 26 4
gpt4 key购买 nike

我正在研究自定义阵列适配器。我有一个可扩展的 ListView ,我正在向其中添加列表。我也有 search view用户应该能够在其中搜索任何项目。下面是我的自定义适配器和 fragment 的代码

public class ThreeLevelListAdapter extends BaseExpandableListAdapter {

String[] parentHeaders;
List<String[]> secondLevel;
private Context context;
List<LinkedHashMap<String, String[]>> data;

/**
* Constructor
* @param context
* @param parentHeader
* @param secondLevel
* @param data
*/
public ThreeLevelListAdapter(Context context, String[] parentHeader, List<String[]> secondLevel, List<LinkedHashMap<String, String[]>> data) {
this.context = context;

this.parentHeaders = parentHeader;

this.secondLevel = secondLevel;

this.data = data;
}

@Override
public int getGroupCount() {
return parentHeaders.length;
}

@Override
public int getChildrenCount(int groupPosition) {


// no idea why this code is working

return 1;

}

@Override
public Object getGroup(int groupPosition) {

return groupPosition;
}

@Override
public Object getChild(int group, int child) {


return child;


}



@Override
public long getGroupId(int groupPosition) {
return groupPosition;
}

@Override
public long getChildId(int groupPosition, int childPosition) {
return childPosition;
}

@Override
public boolean hasStableIds() {
return true;
}



@Override
public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {

LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = inflater.inflate(R.layout.row_first, null);
TextView text = (TextView) convertView.findViewById(R.id.rowParentText);
text.setText(this.parentHeaders[groupPosition]);

return convertView;
}

@Override
public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent) {

final SecondLevelExpandableListView secondLevelELV = new SecondLevelExpandableListView(context);

String[] headers = secondLevel.get(groupPosition);


List<String[]> childData = new ArrayList<>();
HashMap<String, String[]> secondLevelData = data.get(groupPosition);

for (String key : secondLevelData.keySet()) {


childData.add(secondLevelData.get(key));

}


secondLevelELV.setAdapter(new SecondLevelAdapter(context, headers, childData));

secondLevelELV.setGroupIndicator(null);


secondLevelELV.setOnGroupExpandListener(new ExpandableListView.OnGroupExpandListener() {
int previousGroup = -1;

@Override
public void onGroupExpand(int groupPosition) {
if (groupPosition != previousGroup)
secondLevelELV.collapseGroup(previousGroup);
previousGroup = groupPosition;
}
});


return secondLevelELV;
}

@Override
public boolean isChildSelectable(int groupPosition, int childPosition) {
return true;
}}
`
fragment
SearchView mSearchView;
static String TAG = "product search";
ExpandableListView suggestion_list;
ThreeLevelListAdapter threeLevelListAdapterAdapter;
String[] parent = new String[]{"A2A 100 MG TABS", "AQUA-VIT SACHET", "BRONCOPHYLINE SYRUP"};
String[] q1 = new String[]{"BAHRIA TOWN MARKET", "MAIN ROAD BAGH MONCHI LADHA"};
String[] q2 = new String[]{"DAROGHEWALA MAIN BAZAR"};
String[] q3 = new String[]{"ASKARI-10 HOUSING SOCITEY","CHUNGI DOGAJE"};
String[] des1 = new String[]{"M/S MEDSERVE PHARMACY"};
String[] des2 = new String[]{"M/S DANISH MEDICAL STORE"};
String[] des3 = new String[]{"FUTURE HEALTH PHARMACY","M/S ASAD PHARMACY","M/S GHAFOOR MEDICAL STORE"};
String[] des4 = new String[]{"M/S NOOR MEDICOSE"};
String[] des5 = new String[]{"M/S ABDUL GHAFAR MEDIACL STORE"};
ArrayList<String> parentlist = new ArrayList<String>(Arrays.asList(parent));
LinkedHashMap<String, String[]> thirdLevelq1 = new LinkedHashMap<>();
LinkedHashMap<String, String[]> thirdLevelq2 = new LinkedHashMap<>();
LinkedHashMap<String, String[]> thirdLevelq3 = new LinkedHashMap<>();
/**
* Second level array list
*/
List<String[]> secondLevel = new ArrayList<>();
/**
* Inner level data
*/
List<LinkedHashMap<String, String[]>> data = new ArrayList<>();

secondLevel.add(q1);
secondLevel.add(q2);
secondLevel.add(q3);
thirdLevelq1.put(q1[0], des1);
thirdLevelq1.put(q1[1], des2);
thirdLevelq2.put(q2[0], des3);
thirdLevelq3.put(q3[0], des4);
thirdLevelq3.put(q3[1], des5);

data.add(thirdLevelq1);
data.add(thirdLevelq2);
data.add(thirdLevelq3);

threeLevelListAdapterAdapter = new ThreeLevelListAdapter(getActivity(), parent, secondLevel, data);
suggestion_list.setAdapter(threeLevelListAdapterAdapter);

mSearchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String s) {
return false;
}

@Override
public boolean onQueryTextChange(String s) {
if (TextUtils.isEmpty(s)) {
// here I want to empty the threeLevelListAdapterAdapter

suggestion_list.clearTextFilter();
} else {
// here I want to fill the threeLevelListAdapterAdapter
}
return true;
}
});
更新 1
我找到了以下代码,它使用可扩展的 ListView 实现搜索。
 public void filterData(String query){

query = query.toLowerCase();
Log.v("MyListAdapter", String.valueOf(continentList.size()));
continentList.clear();

if(query.isEmpty()){
continentList.addAll(originalList);
}
else {

for(Continent continent: originalList){

ArrayList<Country> countryList = continent.getCountryList();
ArrayList<Country> newList = new ArrayList<Country>();
for(Country country: countryList){
if(country.getCode().toLowerCase().contains(query) ||
country.getName().toLowerCase().contains(query)){
newList.add(country);
}
}
if(newList.size() > 0){
Continent nContinent = new Continent(continent.getName(),newList);
continentList.add(nContinent);
}
}
}

Log.v("MyListAdapter", String.valueOf(continentList.size()));
notifyDataSetChanged();

}
如何在搜索过程中清除和填充我的自定义适配器?
任何帮助将不胜感激

最佳答案

我在这里的项目中实现了类似的东西:github.com/CMPUT301W21T21-H03/DivineInspiration
我做这个 fragment 的方法是制作两个数据数组列表,原始的永不改变的数据包含所有东西,然后另一个用于显示列表。如果您检查链接,第 92 行是过滤器,如果搜索文本的长度为 0,则使用原始数据列表重置显示列表,否则,我从原始数据列表开始过滤并将其附加到一个新列表中,该列表将成为末尾的新显示列表

关于Android 使用自定义阵列适配器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67413157/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com