Android: วิธีผูกสปินเนอร์กับรายการวัตถุที่กำหนดเอง


126

ในอินเทอร์เฟซผู้ใช้จะต้องมีสปินเนอร์ซึ่งมีชื่อบางชื่อ (สามารถมองเห็นชื่อได้) และแต่ละชื่อมี ID ของตัวเอง (IDs ไม่เท่ากับลำดับการแสดงผล) เมื่อผู้ใช้เลือกชื่อจากรายการตัวแปร currentID จะต้องเปลี่ยน

แอปพลิเคชันนี้มี ArrayList

โดยผู้ใช้คือวัตถุที่มี ID และชื่อ:

public class User{
        public int ID;
        public String name;
    }

สิ่งที่ฉันไม่รู้คือวิธีสร้างสปินเนอร์ซึ่งแสดงรายชื่อผู้ใช้และผูกรายการสปินเนอร์กับ ID ดังนั้นเมื่อเลือกรายการสปินเนอร์ / เปลี่ยนตัวแปร currentID จะถูกตั้งค่าเป็นค่าที่เหมาะสม

ฉันจะขอบคุณถ้าใครสามารถแสดงวิธีแก้ปัญหาที่อธิบายไว้หรือให้ลิงค์ที่เป็นประโยชน์ในการแก้ปัญหา

ขอบคุณ!


ใช้เมธอด setVisibility และตั้งค่าเป็น INVISIBLE developer.android.com/reference/android/view/…
andoni90

คำตอบ:


42

คุณสามารถดูคำตอบนี้ คุณยังสามารถใช้อะแดปเตอร์แบบกำหนดเองได้ แต่วิธีแก้ปัญหาด้านล่างนี้ใช้ได้ดีสำหรับกรณีทั่วไป

นี่คือการโพสต์ซ้ำ:

ดังนั้นหากคุณมาที่นี่เพราะต้องการมีทั้งป้ายกำกับและค่าใน Spinner - นี่คือวิธีที่ฉันทำ:

  1. เพียงแค่สร้างSpinnerตามปกติของคุณ
  2. กำหนดอาร์เรย์ที่มีขนาดเท่ากัน 2 อาร์เรย์ในarray.xmlไฟล์ของคุณ- หนึ่งอาร์เรย์สำหรับเลเบลและอาร์เรย์สำหรับค่า
  3. ตั้งค่าSpinnerด้วยandroid:entries="@array/labels"
  4. เมื่อคุณต้องการมูลค่าให้ทำสิ่งนี้ (ไม่คุณไม่จำเป็นต้องเชื่อมโยง):

      String selectedVal = getResources().getStringArray(R.array.values)[spinner.getSelectedItemPosition()];

2
มีวิธีที่สวยงามในการเข้าถึงป้ายกำกับที่กำหนดไว้หรือไม่ (สำหรับการเปรียบเทียบกับ selectedVal) ดังนั้นจึงสามารถหลีกเลี่ยงการเข้ารหัสป้ายกำกับสตริงในโค้ดได้ยากหรือไม่
Anti Earth

นี่เป็นกรณีของการทำซ้ำข้อมูลและควรหลีกเลี่ยง
Binoy Babu

18
ผิดไปจากมุมมองความสามารถในการปรับขนาดได้นั่นหมายความว่า "วัตถุ" ของคุณไม่มีทางเป็นแบบไดนามิกได้ - การปฏิบัติที่ไม่ดี
Srneczek

1
@Bostone ฉันไม่ได้ตรวจสอบเวลา แต่ฉันคิดว่ามันไม่เกี่ยวข้องในกรณีนี้ อะแดปเตอร์อยู่ที่นั่นด้วยเหตุผลบางประการและฉันพนันได้เลยว่านี่ไม่เกี่ยวกับการเปลี่ยนแปลง SDK ในเวลา เป็นหนึ่งในเหตุผลที่พวกเขาสร้างอะแดปเตอร์ตั้งแต่แรก ดังนั้นคุณสามารถให้บริการรายการของวัตถุที่ซับซ้อนดังนั้นในความคิดของฉันมักจะเป็นการปฏิบัติที่ไม่ดีใช้ได้เฉพาะในกรณีที่ง่ายมาก แต่นั่นไม่ได้ทำให้เป็นแนวทางปฏิบัติที่ดี
Srneczek

3
@ Bob'sBurgers คุณพลาดประเด็น ฉันไม่เคยบอกว่ามันไม่ได้ผลฉันบอกว่ามันเป็นการปฏิบัติที่ไม่ดีและฉันพูดถูกเกี่ยวกับเรื่องนั้น ตัวแปรส่วนกลางหรือรหัสใน 1 ไฟล์ที่ยาวมากก็ใช้งานได้เช่นกัน ... แต่คุณควรแสดงความคิดเห็นในเธรดเก่าเพราะยังคงปรากฏในการค้นหาในปัจจุบันและ ppl จะใช้คำตอบที่ผิด (วันนี้)
Srneczek

345

ฉันรู้ว่าเธรดเก่า แต่ในกรณี ...

วัตถุของผู้ใช้:

public class User{

    private int _id;
    private String _name;

    public User(){
        this._id = 0;
        this._name = "";
    }

    public void setId(int id){
        this._id = id;
    }

    public int getId(){
        return this._id;
    }

    public void setName(String name){
        this._name = name;
    }

    public String getName(){
        return this._name;
    }
}

Custom Spinner Adapter (ArrayAdapter)

public class SpinAdapter extends ArrayAdapter<User>{

    // Your sent context
    private Context context;
    // Your custom values for the spinner (User)
    private User[] values;

    public SpinAdapter(Context context, int textViewResourceId,
            User[] values) {
        super(context, textViewResourceId, values);
        this.context = context;
        this.values = values;
    }

    @Override
    public int getCount(){
       return values.length;
    }

    @Override
    public User getItem(int position){
       return values[position];
    }

    @Override
    public long getItemId(int position){
       return position;
    }


    // And the "magic" goes here
    // This is for the "passive" state of the spinner
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // I created a dynamic TextView here, but you can reference your own  custom layout for each spinner item
        TextView label = (TextView) super.getView(position, convertView, parent);
        label.setTextColor(Color.BLACK);
        // Then you can get the current item using the values array (Users array) and the current position
        // You can NOW reference each method you has created in your bean object (User class)
        label.setText(values[position].getName());

        // And finally return your dynamic (or custom) view for each spinner item
        return label;
    }

    // And here is when the "chooser" is popped up
    // Normally is the same view, but you can customize it if you want
    @Override
    public View getDropDownView(int position, View convertView,
            ViewGroup parent) {
        TextView label = (TextView) super.getDropDownView(position, convertView, parent);
        label.setTextColor(Color.BLACK);
        label.setText(values[position].getName());

        return label;
    }
}

และการใช้งาน:

public class Main extends Activity {
    // You spinner view
    private Spinner mySpinner;
    // Custom Spinner adapter (ArrayAdapter<User>)
    // You can define as a private to use it in the all class
    // This is the object that is going to do the "magic"
    private SpinAdapter adapter;

        @Override
        public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        // Create the Users array
        // You can get this retrieving from an external source
        User[] users = new User[2];

        users[0] = new User();
        users[0].setId(1);
        users[0].setName("Joaquin");

        users[1] = new User();
        users[1].setId(2);
        users[1].setName("Alberto");

        // Initialize the adapter sending the current context
        // Send the simple_spinner_item layout
        // And finally send the Users array (Your data)
        adapter = new SpinAdapter(Main.this,
            android.R.layout.simple_spinner_item,
            users);
        mySpinner = (Spinner) findViewById(R.id.miSpinner);
        mySpinner.setAdapter(adapter); // Set the custom adapter to the spinner
        // You can create an anonymous listener to handle the event when is selected an spinner item
        mySpinner.setOnItemSelectedListener(new OnItemSelectedListener() {

            @Override
            public void onItemSelected(AdapterView<?> adapterView, View view,
                    int position, long id) {
                // Here you get the current item (a User object) that is selected by its position
                User user = adapter.getItem(position);
                // Here you can do the action you want to...
                Toast.makeText(Main.this, "ID: " + user.getId() + "\nName: " + user.getName(),
                    Toast.LENGTH_SHORT).show();
            }
            @Override
            public void onNothingSelected(AdapterView<?> adapter) {  }
        });
    }
}

43
นี่ควรเป็นคำตอบที่ได้รับการยอมรับ การสร้างอะแดปเตอร์แบบกำหนดเองเป็นวิธีที่จะไปได้อย่างแน่นอน
jamesc

11
สิ่งนี้ใช้ได้ดี ดีมาก. แต่ปัญหาอย่างหนึ่ง ตอนนี้สปินเนอร์เปลี่ยนรูปแบบแล้ว ฉันพยายามตั้งค่า xml ใหม่เพื่อเปลี่ยน paddings ขนาดตัวอักษร แต่ไม่มีอะไรเกิดขึ้น ฉันเปลี่ยนสปินเนอร์ด้วยตัวเองจาก xml และไม่มีอะไรเหลือ สิ่งเดียวที่เปลี่ยนแปลงคือถ้าฉันเปลี่ยนขนาดข้อความของ TextView จากภายใน SpinAdapter มีวาที่จะคงสไตล์ / ธีมของสปินเนอร์เริ่มต้นไว้ แต่โหลดค่าประเภทนี้หรือไม่
lantonis

ฉันทำสิ่งนี้แล้ว แต่ฉันได้รับความล่าช้าเป็นจำนวนมาก ในขณะที่ฉันเพิ่มแค่ 3 ครั้ง ฉันขยายมุมมองเพื่อสร้างเลย์เอาต์ของฉันมันมีเพียงไอคอนและข้อความเท่านั้น Logcat ยืนยันฉันโดยพูดSkipped 317 frames! The application may be doing too much work on its main thread.ความคิดใด ๆ ?
CularBytes

3
+1 สำหรับบรรทัดนี้ :) User user = adapter.getItem (position);
Ahmad Alkhatib

2
เพียงแค่ปรับเปลี่ยนเพื่อใช้มุมมองซ้ำแทนที่จะสร้าง TextView ใหม่ก็ควรทำดังนี้: TextView label = (TextView) super.getView (ตำแหน่ง, convertView, พาเรนต์)
แจ็

94

ทางออกที่ง่ายที่สุด

หลังจากกำจัดสิ่งสกปรกบนการแก้ปัญหาที่แตกต่างกันดังนั้นผมคิดว่าต่อไปนี้จะเป็นทางออกที่ง่ายและสะอาดสำหรับการกระจายค่ากับที่กำหนดเองSpinner Objectsนี่คือการใช้งานเต็มรูปแบบ:

User.java

public class User{
    public int ID;
    public String name;

    @Override
    public String toString() {
        return this.name; // What to display in the Spinner list.
    }
}    

ความละเอียด / รูปแบบ / spinner.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:padding="10dp"
    android:textSize="14sp"
    android:textColor="#FFFFFF"
    android:spinnerMode="dialog" />

ความละเอียด / รูปแบบ / your_activity_view.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical">

    <Spinner android:id="@+id/user" />

</LinearLayout>

ในกิจกรรมของคุณ

List<User> users = User.all(); // This example assumes you're getting all Users but adjust it for your Class and needs.
ArrayAdapter userAdapter = new ArrayAdapter(this, R.layout.spinner, users);

Spinner userSpinner = (Spinner) findViewById(R.id.user);
userSpinner.setAdapter(userAdapter);
userSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
    @Override
    public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
        // Get the value selected by the user
        // e.g. to store it as a field or immediately call a method
        User user = (User) parent.getSelectedItem();
    }

    @Override
    public void onNothingSelected(AdapterView<?> parent) {
    }
});

ข้อแม้เล็ก ๆ อย่างหนึ่งคือไม่ได้ตั้งค่าcurrentIDทันทีที่ค่าSpinnerเปลี่ยนไป เวลาส่วนใหญ่คุณต้องการเพียงค่าของSpinnerหลังจากกดปุ่มในภายหลังเช่นส่งหรือบันทึกไม่ใช่ทันทีหลังจากที่Spinnerเปลี่ยนไปและหากสามารถหลีกเลี่ยงได้สิ่งนี้จะเป็นวิธีที่ง่ายกว่ามาก
Joshua Pinter

ฉันพบว่ามันใช้งานได้และเพียงแค่วางบรรทัดสุดท้ายไว้ที่อื่นคุณจะสามารถแก้ไข "ปัญหา" ที่ @JoshPinter อธิบายได้
x13

@ x13 ถูกต้อง สิ่งที่คุณต้องทำเพื่อให้ได้มูลค่าการเปลี่ยนแปลงคือตั้งค่าตัวฟัง "on change" จากนั้นวางgetSelectedItem()สายเข้าไป ขอบคุณสำหรับทิป.
Joshua Pinter

4
3 ปีผ่านไปผลงานน่าทึ่ง! ไม่อยากจะเชื่อเลยว่าผู้คนเอาชนะสิ่งง่ายๆนี้ได้
Juan De la Cruz

1
@JuanDelaCruz Android และ java ทำให้ง่ายต่อการเอาชนะสิ่งที่ซับซ้อน ความเรียบง่ายเพื่อชัยชนะ!
โจชัวพินเตอร์

53

สำหรับวิธีแก้ปัญหาง่ายๆคุณสามารถเขียนทับ "toString" ในวัตถุของคุณได้

public class User{
    public int ID;
    public String name;

    @Override
    public String toString() {
        return name;
    }
}

จากนั้นคุณสามารถใช้:

ArrayAdapter<User> dataAdapter = new ArrayAdapter<User>(mContext, android.R.layout.simple_spinner_item, listOfUsers);

วิธีนี้สปินเนอร์ของคุณจะแสดงเฉพาะชื่อผู้ใช้


วิธีตั้งค่าสปินเนอร์บน EDIT เป็นรายการที่เลือกซึ่งส่งคืนเมื่อตอบกลับ
Arnold Brown

9

วิธีที่ง่ายที่สุดที่ฉันพบ:

@Override
public String toString() {
    return this.label;           
}

ตอนนี้คุณสามารถติดวัตถุใด ๆ ในเครื่องปั่นด้ายของคุณและจะแสดงป้ายกำกับที่ระบุ


8

การปรับแต่งเพียงเล็กน้อยสำหรับคำตอบของ Joaquin Alberto สามารถแก้ปัญหาสไตล์ได้เพียงแค่เปลี่ยนฟังก์ชัน getDropDownView ในอะแดปเตอร์ที่กำหนดเองดังต่อไปนี้

@Override
    public View getDropDownView(int position, View convertView, ViewGroup parent) {
        View v = super.getDropDownView(position, convertView, parent);
        TextView tv = ((TextView) v);
        tv.setText(values[position].getName());
        tv.setTextColor(Color.BLACK);
        return v;
    }

1
คำตอบนี้ไม่ได้ตอบคำถามจริง ๆ แต่ชี้ให้เห็นสิ่งสำคัญบางอย่างที่เกี่ยวข้องกับคำตอบนี้
Sruit A.uk

6

ใช้งานได้ดีสำหรับฉันรหัสที่จำเป็นสำหรับสิ่ง getResource () มีดังนี้:

spinner = (Spinner) findViewById(R.id.spinner);
spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {

        @Override
        public void onItemSelected(AdapterView<?> spinner, View v,
                int arg2, long arg3) {
            String selectedVal = getResources().getStringArray(R.array.compass_rate_values)[spinner.getSelectedItemPosition()];
            //Do something with the value
        }

        @Override
        public void onNothingSelected(AdapterView<?> arg0) {
            // TODO Auto-generated method stub
        }

    });

เพียงแค่ต้องตรวจสอบให้แน่ใจว่า (ด้วยตัวเอง) ค่าในอาร์เรย์ทั้งสองจัดเรียงอย่างถูกต้อง!


5

แรงบันดาลใจจาก Joaquin Alberto สิ่งนี้ได้ผลสำหรับฉัน:

public class SpinAdapter extends ArrayAdapter<User>{


    public SpinAdapter(Context context, int textViewResourceId,
            User[] values) {
        super(context, textViewResourceId, values);
    }



    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        TextView label = (TextView) super.getView(position, convertView, parent);
        label.setTextColor(Color.BLACK);
        label.setText(this.getItem(position).getName());
        return label;
    }

    @Override
    public View getDropDownView(int position, View convertView,ViewGroup parent) {
        TextView label = (TextView) super.getView(position, convertView, parent);
        label.setTextColor(Color.BLACK);
        label.setText(this.getItem(position).getName());
        return label;
    }
}

5

อ้างอิงจากตัวอย่าง Joaquin Alberto (ขอบคุณ) แต่ใช้ได้กับทุกประเภท (คุณควรใช้ toString () ในประเภทเพื่อให้คุณสามารถจัดรูปแบบผลลัพธ์ได้

import java.util.List;

import android.content.Context;
import android.graphics.Color;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.TextView;

public class SpinAdapter<T> extends ArrayAdapter<T> {
private Context context;
private List<T> values;

public SpinAdapter(Context context, int textViewResourceId, List<T> values) {
    super(context, textViewResourceId, values);
    this.context = context;
    this.values = values;
}

public int getCount() {
    return values.size();
}

public T getItem(int position) {
    return values.get(position);
}

public long getItemId(int position) {
    return position;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    TextView label = new TextView(context);
    label.setTextColor(Color.BLACK);
    label.setText(values.toArray(new Object[values.size()])[position]
            .toString());
    return label;
}

@Override
public View getDropDownView(int position, View convertView, ViewGroup parent) {
    TextView label = new TextView(context);
    label.setTextColor(Color.BLACK);
    label.setText(values.toArray(new Object[values.size()])[position]
            .toString());

    return label;
}
}

ฉันคิดว่าคุณสามารถแทนที่ List by Array ได้ดังนั้นคุณจึงไม่จำเป็นต้องทำ toArray ใน List แต่ฉันมี List ..... :)


3

เพื่อให้เข้าใจเคล็ดลับเราต้องรู้ว่า Adapters ทำงานอย่างไรโดยทั่วไปและ ArrayAdapter โดยเฉพาะ

Adapters: เป็นอ็อบเจ็กต์ที่สามารถผูกโครงสร้างข้อมูลกับวิดเจ็ตจากนั้นวิดเจ็ตเหล่านี้จะแสดงข้อมูลนั้นในรายการหรือใน Spinner

ดังนั้นสองคำถามคำตอบของอะแดปเตอร์คือ:

  1. วิดเจ็ตหรือมุมมองคอมโพสิตใดที่ต้องเชื่อมโยงกับโครงสร้างข้อมูล (ออบเจ็กต์คลาสของคุณ) สำหรับดัชนีบางอย่าง
  2. วิธีการดึงข้อมูลจากโครงสร้างข้อมูล (อ็อบเจ็กต์คลาสของคุณ) และวิธีการตั้งค่าฟิลด์เช่นEditTextวิดเจ็ตหรือมุมมองคอมโพสิตตามข้อมูลนี้

คำตอบของ ArrayAdapter คือ:

  • แต่ละวิดเจ็ต (เช่นrow.xmlOR android.R.layout.simple_spinner_item) สำหรับดัชนีใด ๆ จะเหมือนกันและจะสูงเกินจริงจากรีซอร์สที่ ID ถูกกำหนดให้กับคอนสตรัคเตอร์ของ ArrayAdapter
  • แต่ละวิดเจ็ตคาดว่าจะเป็นอินสแตนซ์ของ TextView (หรือลูกหลาน) .setText()วิธีการของวิดเจ็ตจะใช้กับรูปแบบสตริงของรายการในโครงสร้างข้อมูลสนับสนุน รูปแบบสตริงจะได้รับจากการเรียกใช้.toString()ไอเท็ม

CustomListViewDemo.java

public class CustomListViewDemo extends ListActivity {
  private EfficientAdapter adap;

  private static String[] data = new String[] { "0", "1", "2", "3", "4" };

  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    requestWindowFeature(Window.FEATURE_NO_TITLE);
    setContentView(R.layout.main);
    adap = new EfficientAdapter(this);
    setListAdapter(adap);
  }

  @Override
  protected void onListItemClick(ListView l, View v, int position, long id) {
    // TODO Auto-generated method stub
    super.onListItemClick(l, v, position, id);
    Toast.makeText(this, "Click-" + String.valueOf(position), Toast.LENGTH_SHORT).show();
  }

  public static class EfficientAdapter extends BaseAdapter implements Filterable {
    private LayoutInflater mInflater;
    private Bitmap mIcon1;
    private Context context;
    int firstpos=0;

    public EfficientAdapter(Context context) {
      // Cache the LayoutInflate to avoid asking for a new one each time.
      mInflater = LayoutInflater.from(context);
      this.context = context;
    }

    public View getView(final int position, View convertView, ViewGroup parent) {

      ViewHolder holder;

      if (convertView == null) {
        convertView = mInflater.inflate(R.layout.adaptor_content, null);

        holder = new ViewHolder();
        holder.sp = (Spinner) convertView.findViewById(R.id.spinner1);

        holder.ArrayAdapter_sp = new ArrayAdapter(parent.getContext(),android.R.layout.simple_spinner_item,data);
        holder.ArrayAdapter_sp.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

        holder.sp.setAdapter( holder.ArrayAdapter_sp);
        holder.sp.setOnItemSelectedListener(new OnItemSelectedListener()
        {
            private int pos = position;
            @Override
            public void onItemSelected(AdapterView<?> arg0, View arg1,
                    int p, long arg3) 
            {
                // TODO Auto-generated method stub
                 Toast.makeText(context, "select spinner " + String.valueOf(pos)+" with value ID "+p, Toast.LENGTH_SHORT).show();    

            }

            @Override
            public void onNothingSelected(AdapterView<?> arg0)
            {
                // TODO Auto-generated method stub

            }
        });




        convertView.setTag(holder);
      } else {

        holder = (ViewHolder) convertView.getTag();
      }


      return convertView;
    }

    static class ViewHolder 
    {

        Spinner sp;
        ArrayAdapter ArrayAdapter_sp;

    }

    @Override
    public Filter getFilter() {
      // TODO Auto-generated method stub
      return null;
    }

    @Override
    public long getItemId(int position) {
      // TODO Auto-generated method stub
      return 0;
    }

    @Override
    public int getCount() {
      // TODO Auto-generated method stub
      return data.length;
    }

    @Override
    public Object getItem(int position) {
      // TODO Auto-generated method stub
      return data[position];
    }

  }

}

adaptor_content.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/lineItem"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:gravity="center_vertical" >

    <Spinner
        android:id="@+id/spinner1"
        android:layout_width="314dp"
        android:layout_height="wrap_content" />

</LinearLayout>

main.xml

<?xml version="1.0" encoding="utf-8"?>

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_height="fill_parent" android:layout_width="fill_parent"
    >

    <ListView
        android:id="@+id/android:list"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layout_marginBottom="60dip"
        android:layout_marginTop="10dip"
        android:cacheColorHint="#00000000"
        android:drawSelectorOnTop="false" />

</RelativeLayout>

มันทำงานได้ดีฉันหวังว่ามันจะเป็นประโยชน์


2

วัตถุที่กำหนดเองของฉันคือ

/**
 * Created by abhinav-rathore on 08-05-2015.
 */
public class CategoryTypeResponse {
    private String message;

    private int status;

    private Object[] object;

    public String getMessage() {
        return message;
    }

    public void setMessage(String message) {
        this.message = message;
    }

    public int getStatus() {
        return status;
    }

    public void setStatus(int status) {
        this.status = status;
    }

    public Object[] getObject() {
        return object;
    }

    public void setObject(Object[] object) {
        this.object = object;
    }

    @Override
    public String toString() {
        return "ClassPojo [message = " + message + ", status = " + status + ", object = " + object + "]";
    }

    public static class Object {
        private String name;
        private String _id;
        private String title;
        private String desc;
        private String xhdpi;
        private String hdpi;
        private String mdpi;
        private String hint;
        private String type;
        private Brands[] brands;


        public String getId() {
            return _id;
        }

        public void setId(String id) {
            this._id = id;
        }

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public String getXhdpi() {
            return xhdpi;
        }

        public void setXhdpi(String xhdpi) {
            this.xhdpi = xhdpi;
        }

        public String getHdpi() {
            return hdpi;
        }

        public void setHdpi(String hdpi) {
            this.hdpi = hdpi;
        }

        public String getMdpi() {
            return mdpi;
        }

        public void setMdpi(String mdpi) {
            this.mdpi = mdpi;
        }

        public String get_id() {
            return _id;
        }

        public void set_id(String _id) {
            this._id = _id;
        }

        public String getTitle() {
            return title;
        }

        public void setTitle(String title) {
            this.title = title;
        }

        public String getDesc() {
            return desc;
        }

        public void setDesc(String desc) {
            this.desc = desc;
        }

        public String getHint() {
            return hint;
        }

        public void setHint(String hint) {
            this.hint = hint;
        }

        public String getType() {
            return type;
        }

        public void setType(String type) {
            this.type = type;
        }

        public Brands[] getBrands() {
            return brands;
        }

        public void setBrands(Brands[] brands) {
            this.brands = brands;
        }

        @Override
        public String toString() {
            return "ClassPojo [name = " + name + "]";
        }
    }

    public static class Brands {

        private String _id;
        private String name;
        private String value;
        private String categoryid_ref;

        public String get_id() {
            return _id;
        }

        public void set_id(String _id) {
            this._id = _id;
        }

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public String getValue() {
            return value;
        }

        public void setValue(String value) {
            this.value = value;
        }

        public String getCategoryid_ref() {
            return categoryid_ref;
        }

        public void setCategoryid_ref(String categoryid_ref) {
            this.categoryid_ref = categoryid_ref;
        }

        @Override
        public String toString() {
            return  name;

        }
    }
}

ฉันต้องการตั้งค่าวัตถุนี้เป็นแหล่งอะแดปเตอร์ของฉันไปยังสปินเนอร์โดยไม่ต้องขยายArrayAdapter เพื่อให้สิ่งที่ฉันทำคือ

brandArray = mCategoryTypeResponse.getObject()[fragPosition].getBrands();

ArrayAdapter brandAdapter = new ArrayAdapter< CategoryTypeResponse.Brands>(getActivity(),
                R.layout.item_spinner, brandArray);

ตอนนี้คุณจะสามารถเห็นผลลัพธ์ในสปินเนอร์ของคุณเคล็ดลับคือการแทนที่toString() ในออบเจ็กต์ที่คุณกำหนดเองดังนั้นค่าที่คุณต้องการแสดงในสปินเนอร์เพียงแค่ส่งคืนค่านั้นด้วยวิธีนี้


0

ผมคิดว่าทางออกที่ดีที่สุดคือ"ทางออกที่ง่ายที่สุด"โดยจอชพิน

สิ่งนี้ใช้ได้ผลสำหรับฉัน:

//Code of the activity 
//get linearLayout
LinearLayout linearLayout = (LinearLayout ) view.findViewById(R.id.linearLayoutFragment);       

LinearLayout linearLayout = new LinearLayout(getActivity());
//display css
RelativeLayout.LayoutParams params2 = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.WRAP_CONTENT, RelativeLayout.LayoutParams.WRAP_CONTENT);

//create the spinner in a fragment activiy
Spinner spn = new Spinner(getActivity());

// create the adapter.
ArrayAdapter<ValorLista> spinner_adapter = new ArrayAdapter<ValorLista>(getActivity(), android.R.layout.simple_spinner_item, meta.getValorlistaList());
spinner_adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item); 
spn.setAdapter(spinner_adapter);

//set the default according to value
//spn.setSelection(spinnerPosition);

linearLayout.addView(spn, params2);
//Code of the class ValorLista

import java.io.Serializable;
import java.util.List;

public class ValorLista implements Serializable{


    /**
     * 
     */
    private static final long serialVersionUID = 4930195743192929192L;
    private int id; 
    private String valor;
    private List<Metadato> metadatoList;


    public ValorLista() {
        super();
        // TODO Auto-generated constructor stub
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getValor() {
        return valor;
    }
    public void setValor(String valor) {
        this.valor = valor;
    }
    public List<Metadato> getMetadatoList() {
        return metadatoList;
    }
    public void setMetadatoList(List<Metadato> metadatoList) {
        this.metadatoList = metadatoList;
    }

    @Override
    public String toString() {  
        return getValor();
    }

}

0

หากคุณไม่ต้องการคลาสแยกฉันหมายถึงเพียงอะแดปเตอร์ธรรมดาที่แมปบนวัตถุของคุณ นี่คือรหัสของฉันตามฟังก์ชัน ArrayAdapter ที่มีให้

และเนื่องจากคุณอาจต้องเพิ่มรายการหลังจากสร้างอะแด็ปเตอร์ (เช่นรายการฐานข้อมูลการโหลดแบบอะซิงโครนัส)

เรียบง่าย แต่มีประสิทธิภาพ

editCategorySpinner = view.findViewById(R.id.discovery_edit_category_spinner);

// Drop down layout style - list view with radio button         
dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

// attaching data adapter to spinner, as you can see i have no data at this moment
editCategorySpinner.setAdapter(dataAdapter);
final ArrayAdapter<Category> dataAdapter = new ArrayAdapter<Category>

(getActivity(), android.R.layout.simple_spinner_item, new ArrayList<Category>(0)) {


        // And the "magic" goes here
        // This is for the "passive" state of the spinner
        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            // I created a dynamic TextView here, but you can reference your own  custom layout for each spinner item
            TextView label = (TextView) super.getView(position, convertView, parent);
            label.setTextColor(Color.BLACK);
            // Then you can get the current item using the values array (Users array) and the current position
            // You can NOW reference each method you has created in your bean object (User class)
            Category item = getItem(position);
            label.setText(item.getName());

            // And finally return your dynamic (or custom) view for each spinner item
            return label;
        }

        // And here is when the "chooser" is popped up
        // Normally is the same view, but you can customize it if you want
        @Override
        public View getDropDownView(int position, View convertView,
                                    ViewGroup parent) {
            TextView label = (TextView) super.getDropDownView(position, convertView, parent);
            label.setTextColor(Color.BLACK);
            Category item = getItem(position);
            label.setText(item.getName());

            return label;
        }
    };

จากนั้นคุณสามารถใช้รหัสนี้ (ฉันไม่สามารถใส่ Category [] ในตัวสร้างอะแด็ปเตอร์ได้เนื่องจากข้อมูลถูกโหลดแยกกัน)

โปรดสังเกตว่า adapter.addAll (items) รีเฟรชสปินเนอร์โดยเรียกใช้ alertDataSetChanged () ภายใน

categoryRepository.getAll().observe(this, new Observer<List<Category>>() {

            @Override
            public void onChanged(@Nullable final List<Category> items) {
                dataAdapter.addAll(items);
            }
});

-1

ทำ:

spinner.adapter = object: ArrayAdapter<Project>(
            container.context,
            android.R.layout.simple_spinner_dropdown_item,
            state.projects
        ) {
            override fun getDropDownView(
                position: Int,
                convertView: View?,
                parent: ViewGroup
            ): View {
                val label = super.getView(position, convertView, parent) as TextView
                label.text = getItem(position)?.title
                return label
            }

            override fun getView(position: Int, convertView: View?, parent: ViewGroup): View {
                val label = super.getView(position, convertView, parent) as TextView
                label.text = getItem(position)?.title
                return label
            }
        }

3
คุณยังคงขยายชั้นเรียนที่นี่ คุณแค่ทำกับวัตถุที่ไม่ระบุตัวตน
FutureShocked
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.