ListView inside / with spinner

listview with spinner

Add following files into your project:

1)MainActivity:

2)StarAdapter

3)StarModel

4)activity_main.xml

5)inflator_layout.xml

6) Add some images

public class MainActivity extends AppCompatActivity {

private ListView mListView;

private int[] startImages = new int[]{

R.drawable.brown_star,R.drawable.gray_star,R.drawable.green_star,

R.drawable.ligh_green_star, R.drawable.orange_star, R.drawable.pink_star,

R.drawable.yello_start, R.drawable.brown_star, R.drawable.gray_star,

R.drawable.green_star, R.drawable.ligh_green_star, R.drawable.orange_star,

R.drawable.brown_star,R.drawable.gray_star,R.drawable.green_star,

R.drawable.ligh_green_star, R.drawable.orange_star, R.drawable.pink_star,

R.drawable.yello_start, R.drawable.brown_star, R.drawable.gray_star,

R.drawable.green_star, R.drawable.ligh_green_star, R.drawable.orange_star};

private String[] mColorNames = new String[]{

"Brown star", "Gray star", "Green star" ,

"Light green star", "Orange star", "Pink star",

"Yellow star", "Brown star", "Gray star",

"Green star" , "Light green star", "Orange star",

"Brown star", "Gray star", "Green star" ,

"Light green star", "Orange star", "Pink star",

"Yellow star", "Brown star", "Gray star",

"Green star" , "Light green star", "Orange star"};

private List<StarModel> starModelList = new ArrayList<>();

private String TAG = "Lokesh";

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

mListView = (ListView) findViewById(R.id.listView);

loadListWithImages();

final StarAdapter adapter = new StarAdapter(starModelList,this);

mListView.setAdapter(adapter);

Log.d(TAG, "onCreate: list"+starModelList.size());

}

private void loadListWithImages() {

for (int i = 0; i < startImages.length; i++) {

StarModel starModel = new StarModel();

starModel.setCount(0);

starModel.setImage(startImages[i]);

starModel.setName(mColorNames[i]);

starModelList.add(starModel);

}

}

}

public class StarAdapter extends BaseAdapter {

private List<StarModel> starModelList;

private Context mContext;

private LayoutInflater inflater;

private String TAG = "LokeshSA";

private String[] mColorNames = new String[]{

"Brown star", "Gray star", "Green star" ,

"Light green star", "Orange star", "Pink star",

"Yellow star", "Brown star", "Gray star",

"Green star" , "Light green star", "Orange star",

"Pink star", "Yellow star"};

public StarAdapter(List<StarModel> starModelList, Context mContext) {

this.starModelList = starModelList;

this.mContext = mContext;

inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);

}

@Override

public int getCount() {

return starModelList.size();

}

@Override

public Object getItem(int position) {

return starModelList.get(position);

}

@Override

public long getItemId(int position) {

return position;

}

@Override

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

ViewHolder holder = null;

if (convertView == null) {

convertView = inflater.inflate(R.layout.inflator_layout, null);

holder = new ViewHolder();

holder.spinner = (Spinner) convertView.findViewById(R.id.inflator_layout_spinner);

ArrayAdapter<String> startColorsAdapter = new ArrayAdapter<String>(mContext,

android.R.layout.simple_list_item_1,mColorNames);

holder.spinner.setAdapter(startColorsAdapter);

holder.spinner.setSelection(starModelList.get(position).getCount());

holder.spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {

@Override

public void onItemSelected(AdapterView<?> parent, View view, int position2, long id) {

StarModel starModel = starModelList.get(position);

starModel.setCount(position2);

starModelList.remove(position);

starModelList.add(position,starModel);

}

@Override

public void onNothingSelected(AdapterView<?> parent) {

}

});

convertView.setTag(holder);

}else {

holder = (ViewHolder) convertView.getTag();

}

// initialize image resource

holder.iamge = (ImageView) convertView.findViewById(R.id.inflator_layout_iv);

// setting image

holder.iamge.setImageResource(starModelList.get(position).getImage());

return convertView;

}

private class ViewHolder{

private Spinner spinner;

private ImageView iamge;

}

@Override

public int getViewTypeCount() {

return getCount();

}

@Override

public int getItemViewType(int position) {

return position;

}

}

class StarModel {

int image,count;

String name;

public int getImage() {

return image;

}

public void setImage(int image) {

this.image = image;

}

public int getCount() {

return count;

}

public void setCount(int count) {

this.count = count;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

}

activity_main.xml

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

<ListView

android:id="@+id/listView"

android:layout_width="match_parent"

android:layout_height="match_parent"

xmlns:android="http://schemas.android.com/apk/res/android">

</ListView>

inflator_adaptor.xml

<?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"

xmlns:tools="http://schemas.android.com/tools"

android:orientation="horizontal">

<ImageView

android:id="@+id/inflator_layout_iv"

android:layout_width="30dp"

android:layout_height="30dp"

android:layout_margin="10dp"

tools:src="@drawable/brown_star"/>

<LinearLayout

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:orientation="horizontal">

<Spinner

android:id="@+id/inflator_layout_spinner"

style="@style/textview_normal" />

</LinearLayout>

</LinearLayout>