Я пытаюсь создать макет сетки как прикрепленный.Я хотел бы иметь сетку, в которой столбцы имеют разную длину, и если есть некоторое пространство, оставшееся слева, пустой прямоугольник должен быть показан как в макете.
Я пробовал смещенное представление сетки, но оно не даетмне требуется результат.
Элемент сетки
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:foreground="?android:attr/selectableItemBackground"
android:background="@drawable/rounded_grey_layout"
android:layout_margin="@dimen/_2sdp"
android:orientation="vertical">
<TextView
android:id="@+id/individual_grid_item_text_view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="@dimen/_8sdp"
android:textAlignment="center"
android:textColor="@color/text_color"
android:textSize="@dimen/_12sdp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
Адаптер
public class StaggeredRecyclerViewAdapter extends RecyclerView.Adapter<StaggeredRecyclerViewAdapter.ViewHolder> {
private static final String TAG = "StaggeredRecyclerViewAd";
private Context mContext;
private profile_view_activity prof_activity;
ArrayList<individual_interest_item> default_interests_list;
String[] default_interests_array = {"Sports","Travel","Photography","Watching movies","Fitness","Art","Nightlife","Nature","Gaming","Culture","Food","Technology","Music","Meeting new people","Relationship","Cars","Friendship"};
Animation animation;
public StaggeredRecyclerViewAdapter(Context context, profile_view_activity pro_activity) {
this.prof_activity = pro_activity;
default_interests_list = new ArrayList<>();
for (String item : default_interests_array)
{
individual_interest_item individual_interest_item = new individual_interest_item(item,false);
default_interests_list.add(individual_interest_item);
}
mContext = context;
animation = AnimationUtils.loadAnimation(mContext.getApplicationContext(), R.anim.alpha);
}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.individual_grid_item_layout, parent, false);
return new ViewHolder(view);
}
@Override
public void onBindViewHolder(ViewHolder holder, final int position) {
Log.d(TAG, "onBindViewHolder: called.");
holder.name.setText(default_interests_list.get(position).interest_name);
holder.itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (default_interests_list.get(position).is_selected)
{
default_interests_list.get(position).is_selected = false;
}else{
default_interests_list.get(position).is_selected = true;
}
notifyDataSetChanged();
}
});
if (default_interests_list.get(position).is_selected) {
holder.itemView.setBackground(mContext.getResources().getDrawable(R.drawable.new_rounded_background_buttons_border));
holder.name.setTextColor(mContext.getResources().getColor(R.color.white));
}else{
holder.itemView.setBackground(mContext.getResources().getDrawable(R.drawable.rounded_grey_layout));
holder.name.setTextColor(mContext.getResources().getColor(R.color.text_color));
}
}
@Override
public int getItemCount() {
return default_interests_list.size();
}
public class ViewHolder extends RecyclerView.ViewHolder{
ImageView image;
TextView name;
public ViewHolder(View itemView) {
super(itemView);
this.name = itemView.findViewById(R.id.individual_grid_item_text_view);
}
}
}
Высота столбца должна быть постоянной, ширина может изменяться спустые столбцы между ними.