2017-10-13 2 views
0

Après avoir essayé beaucoup, je suis ici pour poster mon problème ici et j'espère avoir une solution. J'essaye de remplir un gridView à l'intérieur de recyclerview mais à chaque position j'ai différent article dans la vue de grille, Le problème que je fais face Supposons que j'ai 2 articles à la position 0, et 6 article à la position 1 ma vue de recycleur a pris l'espace de six point à chaque fois, il ne remplit pas en affichant seulement deux point à la position 0, Comment puis-je obtenir ceci:Impossible de conserver la taille de la vue de la grille dans la vue recycleur?

Mon recyclerView Code adaptateur est: -

public class RecyclerViewDashItemAdapter extends RecyclerView.Adapter<RecyclerViewDashItemAdapter.ViewHolder> { 
    Context mContext; 
    WacsDashboardItemResponse wacsDashboardItemResponse; 
    GridViewItemBaseAdapter gridViewItemBaseAdapter; 

    public RecyclerViewDashItemAdapter(Context mContext, WacsDashboardItemResponse wacsDashboardItemResponse) { 
     this.mContext = mContext; 
     this.wacsDashboardItemResponse = wacsDashboardItemResponse; 
    } 

    @Override 
    public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { 
     View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.recycler_view_dash_item_adapter, parent, false); 
     ViewHolder viewHolder = new ViewHolder(v); 
     return viewHolder; 
    } 

    @Override 
    public void onBindViewHolder(ViewHolder holder, int position) { 

     gridViewItemBaseAdapter = new GridViewItemBaseAdapter(mContext, 
       wacsDashboardItemResponse.subGroup.get(position).itemArray); 

     holder.gridViewDashItem.setAdapter(gridViewItemBaseAdapter); 

    } 

    @Override 
    public int getItemCount() { 
     return wacsDashboardItemResponse.subGroup.size(); 
    } 

    class ViewHolder extends RecyclerView.ViewHolder { 

     GridView gridViewDashItem; 

     public ViewHolder(View itemView) { 

      super(itemView); 

      gridViewDashItem = (GridView) itemView.findViewById(R.id.gridViewDashItem); 
     } 
    } 
} 

Mon xml pour adaptateur recyclerView est: -

<?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:background="@android:drawable/edit_text" 
    android:orientation="vertical"> 

    <GridView 
     android:id="@+id/gridViewDashItem" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:layout_gravity="center_horizontal" 
     android:columnWidth="300dp" 
     android:horizontalSpacing="2dp" 
     android:numColumns="2" 
     android:padding="2dp" 
     android:stretchMode="columnWidth" 
     android:verticalSpacing="8dp" /> 

</LinearLayout> 

Mon code GridView est: -

public class GridViewItemBaseAdapter extends BaseAdapter { 
    Context mContext; 
    List<WacsDashboardItemResponse.SubGroup.ItemArray> itemArray; 

    public GridViewItemBaseAdapter(Context mContext, List<WacsDashboardItemResponse.SubGroup.ItemArray> itemArray) { 
     this.mContext = mContext; 
     this.itemArray = itemArray; 
    } 

    @Override 
    public int getCount() { 

     return itemArray.size(); 
    } 

    @Override 
    public Object getItem(int position) { 
     return position; 
    } 

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

    @Override 
    public View getView(int position, View convertView, ViewGroup viewGroup) { 
     LayoutInflater inflater = (LayoutInflater) mContext 
       .getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
     View gridView = null; 

     if (convertView == null) { 

      gridView = new View(mContext); 
      gridView = inflater.inflate(R.layout.grid_view_dash_item, null); 
      TextView itemName = (TextView) gridView.findViewById(R.id.itemName); 
      itemName.setText(itemArray.get(position).itmeDesc); 


     } 
     return gridView; 
    } 
} 

Mon Xml pour une vue de la grille est: -

<?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:gravity="center_vertical" 
    android:orientation="horizontal"> 

    <com.orbitsysindia.repairordermanagement.servicereception.util.custom.TextViewMedium 
     android:id="@+id/itemName" 
     style="@style/textColorBlack_14sp" 
     android:layout_width="100dp" 
     android:layout_height="wrap_content" 
     android:text="Check Engine" /> 

    <ImageView 
     android:layout_width="45dp" 
     android:layout_height="45dp" 
     android:layout_marginEnd="10dp" 
     android:src="@drawable/wiperblade" /> 

    <Switch 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:theme="@style/SwitchTheme" /> 

</LinearLayout> 

J'ai différents élément différent à chaque position, Comment puis-je résoudre le problème de la hauteur de chaque section , Merci d'avance.

Répondre

1

Vous devez fixer la hauteur de l'élément gridview comme il est actuellement matchparent il prend hauteur maximale

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="match_parent" 
android:layout_height="320dp" 
android:gravity="center_vertical" 
android:orientation="horizontal"> 

<com.orbitsysindia.repairordermanagement.servicereception.util.custom.TextViewMedium 
    android:id="@+id/itemName" 
    style="@style/textColorBlack_14sp" 
    android:layout_width="100dp" 
    android:layout_height="wrap_content" 
    android:text="Check Engine" /> 

<ImageView 
    android:layout_width="45dp" 
    android:layout_height="45dp" 
    android:layout_marginEnd="10dp" 
    android:src="@drawable/wiperblade" /> 

<Switch 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:theme="@style/SwitchTheme" /> 

+0

je l'ai dit tout mon article sont montrant correctement, je dois différents éléments sont comptés à différents position supposer à la position 0 deux position 1 six, Mais mon point de vue recycleur prendre hauteur de six section article donc dans la section 0 Il montre deux article et l'espace vide pour un autre quatre article puis il va à la première position – Champandorid

+0

pouvez-vous s'il vous plaît joindre une séance d'écran pour une meilleure compréhension – yash786

+0

Hey @ yash786 s'il vous plaît vérifier l'attachm ent ci-dessus – Champandorid