जवाबों:
एंड्रॉयड मीटर
एंड्रॉइड 6.0 में नया, स्पिनर में अब android:popupTheme
पैरामीटर है जो आपको पॉपअप (ड्रॉपडाउन) के लिए उपयोग किए जाने वाले थीम को सेट करने की अनुमति देता है।
आप इसका उपयोग इस प्रकार कर सकते हैं:
<Spinner
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:popupTheme="@android:style/ThemeOverlay.Material.Light" />
यह एपीआई स्तर 23+ पर चलने वाले उपकरणों पर काम करेगा, लेकिन Android के निचले संस्करण को चलाने वाले उपकरणों पर नहीं।
AppCompat
यह वह जगह है जहां AppCompat आता है। इसका स्पिनर कार्यान्वयन भी समर्थन करता है popupTheme
, लेकिन यह सही पाने के लिए थोड़ा अधिक शामिल है।
<Spinner
android:layout_height="wrap_content"
android:layout_width="match_parent"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
उसके बाद, आपको AppCompat के साथ काम करने में सक्षम होने के लिए अपने एडॉप्टर को अपडेट करना होगा। आप इसे नया ThemedSpinnerAdapter
इंटरफ़ेस लागू करके बनाते हैं ।
public class MyAdapter extends BaseAdapter implements ThemedSpinnerAdapter {
Theme getDropDownViewTheme() { ... }
void setDropDownViewTheme(Theme theme) { ... }
}
इन विधियों का उपयोग स्पिनर द्वारा एडॉप्टर को बताने में सक्षम होने के लिए किया जाता है कि किसी भी ड्रॉप डाउन विचारों को बढ़ाने के लिए किस थीम का उपयोग किया जाए। इसे यथासंभव आसान बनाने के लिए हमने आपको एक Helper
वर्ग दिया है जिसे आप अपने एडॉप्टर में प्लग इन कर सकते हैं।
इसका मतलब यह है कि आपका एडॉप्टर कुछ इस तरह बन जाता है:
public class MyAdapter extends BaseAdapter implements ThemedSpinnerAdapter {
private final ThemedSpinnerAdapter.Helper mDropDownHelper;
public MyAdapter(Context context) {
mDropDownHelper = new ThemedSpinnerAdapter.Helper(context);
}
@Override
public View getDropDownView(int position, View convertView, ViewGroup parent) {
View view;
if (convertView == null) {
// Inflate the drop down using the helper's LayoutInflater
LayoutInflater inflater = mDropDownHelper.getDropDownViewInflater();
view = inflater.inflate(R.layout.my_dropdown, parent, false);
}
// ...
return view;
}
@Override
public void setDropDownViewTheme(Theme theme) {
mDropDownHelper.setDropDownViewTheme(theme);
}
@Override
public Theme getDropDownViewTheme() {
return mDropDownHelper.getDropDownViewTheme();
}
}
स्पिनर के तीर के लिए मैंने इसका उपयोग android:backgroundTint="@color/white"
एपीआई 21 से किया है
स्पिनर दृश्य और ड्रॉपडाउन दृश्य के लिए:
ArrayAdapter<Area> areasAdapter = new ArrayAdapter<Area>(getContext(),R.layout.spinner_item, areas);
areasAdapter.setDropDownViewResource(R.layout.dropdwon_item);
areasSpinner.setAdapter(areasAdapter);
के लिए getView () एडाप्टर spinner_item.xml का उपयोग करेगा
के लिए getDropDownView () एडाप्टर dropdwon_item.xml का उपयोग करेगा
फिर आप अपनी पसंद के लेआउट का उपयोग कर सकते हैं
आशा करता हूँ की ये काम करेगा
यदि आप CursorAdapter
अपने कार्यान्वयन का उपयोग करते हैं तो संदर्भ के लिए बहुत आसान हो सकता है, बस ओवरराइड करें newView()
, getDropDownView()
वहां ओवरराइड करने की कोई आवश्यकता नहीं है।
@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
return mDropDownHelper.getDropDownViewInflater().inflate(R.layout.list_item, parent, false);
}
आप इसे आज़मा सकते हैं: अपने लेआउट फ़ोल्डर में एक spinner_item.xml बनाएं:
<TextView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="right"
android:padding="10dp"
android:background = "#ffffff"
android:textColor="@color/primary_text"
android:textSize="@dimen/text_size_normal" />
फिर इस कोड का उपयोग करें:
spinnerAdapter = new ArrayAdapter<String>(R.layout.spinner_item,items);