दिलचस्प पोस्ट
एकाधिक फ़ाइलों में जावास्क्रिप्ट में वैश्विक चर स्काला विधि घोषणा में बराबर चिह्न का उपयोग कब करना है? (स्विफ्ट) एआरआर को एनएसयूएसएर डीफॉल करने के लिए भंडारण और पुनः प्राप्त करना पायथन मेटप्ललिब में एक्स-अक्ष और y- अक्ष के तराजू को कैसे समतल करना है? कोशिश / पकड़ / फेंक और कोशिश / पकड़ (ई) / फेंक ई के बीच का अंतर अंगुलियस सीओआरएस मुद्दे Es6 कक्षाओं का उपयोग करते समय प्रतिक्रिया में "सुपर ()" और "सुपर (प्रोपी)" के बीच अंतर क्या है? क्यों नहीं एक std :: shared_ptr <टी > विशेषज्ञता? एंड्रॉइड कंटेंट प्रोवाइडर में बड़े ब्लॉब्स कैसे स्टोर करें? स्ट्रिंग वेरिएबल में संलग्न क्या साइफर निष्पादन योजना दिखाने का कोई तरीका है? खोजशब्द पैरामीटर के रूप में अजगर में किसी फ़ंक्शन के लिए एक शब्दकोश पास करना त्रुटि को कैसे ठीक करें: स्कीमा बनाकर "विशेषता / तत्व के लिए स्कीमा जानकारी नहीं मिली" ग्रिडव्यू से तालिका में रिकॉर्ड्स सम्मिलित करने में सक्षम नहीं – खिड़कियों के रूप एंड्रॉइड में एसडीसीडी से एक विशिष्ट फाइल को पढ़ना

कस्टम अराएडैप्टर में कस्टम GetFilter एंड्रॉइड

कस्टम सरणीएप्टर में कस्टम getFilter को लागू करने में मुझे समस्या आ रही है असल में मुझे नहीं पता कि इसे कैसे कार्यान्वित करना है कई कोड की कोशिश की लेकिन अभी भी कोई भाग्य नहीं है। यहां मेरा कस्टम सरणी एडेप्टर है I

package com.test.FilterableList.Adapters; import java.util.ArrayList; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ArrayAdapter; import android.widget.TextView; import com.test.FilterableList.Models.ListTO; import com.test.FilterableList.R; import android.widget.Filterable; public class FilterableAdapter extends ArrayAdapter<ListTO> implements Filterable { // declaring our ArrayList of items public ArrayList<ListTO> objects; /* here we must override the constructor for ArrayAdapter * the only variable we care about now is ArrayList<Item> objects, * because it is the list of objects we want to display. */ public FilterableAdapter(Context context, int textViewResourceId, ArrayList<ListTO> objects) { super(context, textViewResourceId, objects); this.objects = objects; } /* * we are overriding the getView method here - this is what defines how each * list item will look. */ public View getView(int position, View convertView, ViewGroup parent){ // assign the view we are converting to a local variable View v = convertView; // first check to see if the view is null. if so, we have to inflate it. // to inflate it basically means to render, or show, the view. if (v == null) { LayoutInflater inflater = (LayoutInflater) getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE); v = inflater.inflate(R.layout.list_item, null); } /* * Recall that the variable position is sent in as an argument to this method. * The variable simply refers to the position of the current object in the list. (The ArrayAdapter * iterates through the list we sent it) * * Therefore, i refers to the current Item object. */ ListTO i = objects.get(position); if (i != null) { // This is how you obtain a reference to the TextViews. // These TextViews are created in the XML files we defined. TextView tt = (TextView) v.findViewById(R.id.list_name); if (tt != null){ tt.setText(i.FileName); } } // the view must be returned to our activity return v; } } 

और यहाँ सूची टीओ कक्षा है

 package com.test.FilterableList.Models; public class ListTO { public int Id; public String FileName; public String FileUri; public ListTO(int id, String fileName, String fileUri) { Id = id; FileName = fileName; FileUri = fileUri; } } 

और ये लेआउट है

 <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" android:background="@drawable/blacklikenbackground" tools:context=".AllListActivity" > <EditText android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="Search" android:id="@+id/inputSearch" /> <ListView android:id="@+id/test_list" android:layout_width="match_parent" android:layout_height="wrap_content"> </ListView> </LinearLayout> 

यहां खोज कीवर्ड "इनपुट खोज" से आता है।

यहां टेक्स्ट बदलते श्रोता हैं।

  inputSearch.addTextChangedListener(new TextWatcher() { @Override public void onTextChanged(CharSequence cs, int arg1, int arg2, int arg3) { // When user changed the Text // Toast.makeText(getActivity(), cs.toString(), Toast.LENGTH_LONG).show(); m_adapter.getFilter().filter(cs); } @Override public void beforeTextChanged(CharSequence arg0, int arg1, int arg2, int arg3) { // TODO Auto-generated method stub } @Override public void afterTextChanged(Editable arg0) { // TODO Auto-generated method stub } }); 

धन्यवाद।

Solutions Collecting From Web of "कस्टम अराएडैप्टर में कस्टम GetFilter एंड्रॉइड"

आपको समस्या आ रही है, मुख्यतः क्योंकि आप कस्टम ऑब्जेक्ट का उपयोग कर रहे हैं। यदि आप सरणी एडॉप्टर के लिए स्ट्रिंग या इंट मान पास करते हैं, तो इसका पता कैसे फ़िल्टर करें। लेकिन अगर आप कस्टम ऑब्जेक्ट डिफॉल्ट फिल्टर कार्यान्वयन से गुजारें तो इसका कोई अंदाजा नहीं है कि उसके साथ कैसे निपटें।

यद्यपि यह स्पष्ट नहीं है कि आप अपने फ़िल्टर में क्या करने की कोशिश कर रहे हैं, मैं आपको निम्न चरणों का सुझाव देता हूं

  1. ListTO का उचित कार्यान्वयन, हालांकि अभी आपके लक्ष्य के साथ कुछ भी नहीं करना है
  2. कस्टम फ़िल्टर लागू करें
  3. अपने फ़िल्टर को वापस लौटें

कस्टम फ़िल्टर लागू करें

आपको सबसे पहले करना है, आपके एरे एडैप्टर से Filterable implements

दूसरा, आपके Filter का कार्यान्वयन प्रदान करें

 Filter myFilter = new Filter() { @Override protected FilterResults performFiltering(CharSequence constraint) { FilterResults filterResults = new FilterResults(); ArrayList<ListTO> tempList=new ArrayList<ListTO>(); //constraint is the result from text you want to filter against. //objects is your data set you will filter from if(constraint != null && objects!=null) { int length=objects.size(); int i=0; while(i<length){ ListTO item=objects.get(i); //do whatever you wanna do here //adding result set output array tempList.add(item); i++; } //following two lines is very important //as publish result can only take FilterResults objects filterResults.values = tempList; filterResults.count = tempList.size(); } return filterResults; } @SuppressWarnings("unchecked") @Override protected void publishResults(CharSequence contraint, FilterResults results) { objects = (ArrayList<ListTO>) results.values; if (results.count > 0) { notifyDataSetChanged(); } else { notifyDataSetInvalidated(); } } }; 

अंतिम चरण,

 @Override public Filter getFilter() { return myFilter; } 

आपको अडैप्टर में getFilter() विधि को ओवरराइड करना getFilter() और अपना स्वयं का फ़िल्टर प्रदान करना होगा। वास्तविक कार्यान्वयन को देखने के लिए इस फ़िल्टर किए गए उदाहरण में एक नज़र डालें

अपने FilterableAdapter क्लास में निम्न getFilter() कोड जोड़ें और इसे अपने फ़िल्टरिंग से भरें:

 /* (non-Javadoc) * @see android.widget.ArrayAdapter#getFilter() */ @Override public Filter getFilter() { return new Filter() { /* (non-Javadoc) * @see android.widget.Filter#performFiltering(java.lang.CharSequence) */ @Override protected FilterResults performFiltering(CharSequence constraint) { // TODO Auto-generated method stub /* * Here, you take the constraint and let it run against the array * You return the result in the object of FilterResults in a form * you can read later in publichResults. */ return null; } /* (non-Javadoc) * @see android.widget.Filter#publishResults(java.lang.CharSequence, android.widget.Filter.FilterResults) */ @Override protected void publishResults(CharSequence constraint, FilterResults results) { // TODO Auto-generated method stub /* * Here, you take the result, put it into Adapters array * and inform about the the change in data. */ } }; } 

मैंने संकेत दिया है कि टिप्पणियों में क्या करना है।

सरणी एडेप्टर लिखने की आवश्यकता नहीं है एक toString () विधि लिखें जो कि फ़ाइल नाम का मान वापस करनी चाहिए।

पसंद

 public class ListTO { public int Id; public String FileName; public String FileUri; public ListTO(int id, String fileName, String fileUri) { Id = id; FileName = fileName; FileUri = fileUri; } public String toString(){ return FileName } } 

इसे इस्तेमाल करे:

  public class Adptr extends BaseAdapter implements Filterable { public ArrayList<Model> modelValues; private Activity activity; private LayoutInflater layoutinflater; private List<Model> mOriginalValues; private int PositionSelected = 0; public Adptr (ArrayList<Model> modelValues, Activity activity) { super(); this.modelValues = modelValues; this.activity = activity; } @Override public int getCount() { return modelValues.size(); } @Override public Object getItem(int position) { return modelValues.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(final int position, View convertView, ViewGroup parent) { layoutinflater = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE); ViewHolder holder = null; Model model = modelValues.get(position); if (convertView == null || !(convertView.getTag() instanceof ViewHolder)) { convertView = layoutinflater.inflate(R.layout.row_search, null); holder = new ViewHolder(); holder.txtName = (TextView) convertView.findViewById(R.id.row_serch_txt_name); convertView.setTag(holder); convertView.setTag(R.id.row_serch_txt_name, holder.txtName); } else { holder = (ViewHolder) convertView.getTag(); } holder.txtArtistName.setText("" + modelValue.get_NAME()); return convertView; } class ViewHolder { TextView txtName; } @Override public Filter getFilter() { Filter filter = new Filter() { @SuppressWarnings("unchecked") @Override protected void publishResults(CharSequence constraint, FilterResults results) { modelValues = (ArrayList<ModelValueArtist>) results.values; // has notifyDataSetChanged(); } @Override protected FilterResults performFiltering(CharSequence constraint) { FilterResults results = new FilterResults(); // Holds the // results of a // filtering // operation in // values // List<String> FilteredArrList = new ArrayList<String>(); List<Model> FilteredArrList = new ArrayList<Model>(); if (mOriginalValues == null) { mOriginalValues = new ArrayList<Model>(modelValues); // saves } /******** * * If constraint(CharSequence that is received) is null returns * the mOriginalValues(Original) values else does the Filtering * and returns FilteredArrList(Filtered) * ********/ if (constraint == null || constraint.length() == 0) { // set the Original result to return results.count = mOriginalValues.size(); results.values = mOriginalValues; } else { Locale locale = Locale.getDefault(); constraint = constraint.toString().toLowerCase(locale); for (int i = 0; i < mOriginalValues.size(); i++) { Model model = mOriginalValues.get(i); String data = model.get_NAME(); if (data.toLowerCase(locale).contains(constraint.toString())) { FilteredArrList.add(modelMyMall); } } // set the Filtered result to return results.count = FilteredArrList.size(); results.values = FilteredArrList; } return results; } }; return filter; } } 

आप कस्टम वस्तु वर्ग में स्ट्रिंग () को ओवरराइड कर सकते हैं और स्ट्रिंग ऑब्जेक्ट वापस लौटा सकते हैं जिसे आप फ़िल्टर्ड करना चाहते हैं।

 @Override public void toString(){ return this.toBeFilteredString; } 

और फिर बस सरणी एडेप्टर के डिफ़ॉल्ट अंतर्निर्मित फ़िल्टर का उपयोग करें और इसका उपयोग करके कॉल करें

 adapter.getFilter().filter(Charsequence c); 

जैसा कि आपने कहा "मैं Google में उपयोग की गई सुविधा जैसे ऑटो सुझाव को लागू करना चाहता हूं; लेकिन यहां सूची दृश्य से – Redone"

AutoCompleteTextView का उपयोग करके ऐसा करने का एक और तरीका है

अधिक विवरण के लिए AutoCompleteTextView के माध्यम से जाना

आउटपुट इस तरह दिखेगा

यदि चारचर्च 'ए' दर्ज करें, तो यह दिखाएगा कि शब्दों की सूची 'ए' से शुरू होती है

यहां छवि विवरण दर्ज करें

main.xml

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/listitem_layout" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="#e2e2e2" android:orientation="vertical" > <AutoCompleteTextView android:id="@+id/autocomplete" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_margin="10dp" android:background="@drawable/text_area" android:inputType="text|textNoSuggestions|textMultiLine" android:paddingLeft="10dp" android:popupBackground="#EFEEEC" android:textColor="#333333" android:textColorHint="#9c9c9c" android:textSize="18sp" android:completionThreshold="1" /> </LinearLayout> 

auto_textview.xml

 <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="wrap_content" android:padding="12dp" android:textColor="#333333" android:layout_margin="15dp" android:textSize="16sp" > </TextView> 

MainActivity.java

 public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); AutoCompleteTextView seachView = (AutoCompleteTextView) findViewById(R.id.autocomplete); seachView.setAdapter(new ArrayAdapter<String>(this, R.layout.auto_textview, getHeading())); } /** * @return */ public List<String> getHeading() { List<String> list = new ArrayList<String>(); list.add("Android"); list.add("Arnold"); list.add("Blackberry"); list.add("Blackpearl"); list.add("Country"); list.add("Canada"); list.add("City"); list.add("Street Address"); list.add("Objective C"); return list; } } 

आशा है कि यह आपकी मदद करेगा।