This is what i am trying to achieve I am able to achieve this much:
I was able to add text and image to a Spinner, but the images are not showing up in the drop-down menu next to the text. Its only shows up for the selected item of the spinner.
Here is my code:
spinner_layout.xml
The layout containing the main Spinner.
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<Spinner android:id="@+id/mySpinner"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</LinearLayout>
spinner_value_layout.xml
The layout for the elements in the Spinner. This will be inflated using an Adapter.
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent" >
<TextView
android:id="@+id/spinnerTextView"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<ImageView
android:id="@+id/spinnerImages"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:contentDescription="@string/app_name"/>"
</TableRow>
</TableLayout>
SpinnerActivity.java
package com.example.spinner;
import android.app.Activity;
import android.os.Bundle;
import android.widget.ImageView;
import android.widget.Spinner;
import android.widget.TextView;
import com.example.tempspinner.R;
public class SpinnerActivity extends Activity {
String[] textArray = { "clouds", "mark", "techcrunch", "times" };
Integer[] imageArray = { R.drawable.clouds, R.drawable.mark,
R.drawable.techcrunch, R.drawable.times };
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.spinner_layout);
TextView text = (TextView) findViewById(R.id.spinnerTextView);
ImageView imageView =(ImageView)findViewById(R.id.spinnerImages);
Spinner spinner = (Spinner) findViewById(R.id.mySpinner);
SpinnerAdapter adapter = new SpinnerAdapter(this, R.layout.spinner_value_layout, textArray, imageArray);
spinner.setAdapter(adapter);
}
}
SpinnerAdapter.java
package com.example.spinner;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import com.example.tempspinner.R;
public class SpinnerAdapter extends ArrayAdapter<String> {
private Context ctx;
private String[] contentArray;
private Integer[] imageArray;
public SpinnerAdapter(Context context, int resource, String[] objects,
Integer[] imageArray) {
super(context, R.layout.spinner_value_layout, R.id.spinnerTextView, objects);
this.ctx = context;
this.contentArray = objects;
this.imageArray = imageArray;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if (convertView == null) {
LayoutInflater inflater = (LayoutInflater) ctx.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = inflater.inflate(R.layout.spinner_value_layout, null);
}
TextView textView = (TextView) convertView.findViewById(R.id.spinnerTextView);
textView.setText(contentArray[position]);
ImageView imageView = (ImageView)convertView.findViewById(R.id.spinnerImages);
imageView.setImageResource(imageArray[position]);
return convertView;
}
}
Spinner row.xml You can remove my unnecessary drawable styles and images
Activity layout act_add_new_prog.xml
Activity Class
ItemModel for every row
And Adapter Class
Try this..
Try this
Create a new layout inside res/layout/ with any name e.g. spinner_value_layout.xml
Create a new class SimpleImageArrayAdapter
and finally use this at your class where you are passing id of spinner
Output:-