2011-02-07 3 views
5

Ho una colonna 3 GridView e 4 elementi.Centrare i bambini in una GridView

Quindi succede che tre di essi compaiono sulla prima riga, e l'ultimo nella seconda fila, ma questo allineato a sinistra. Volevo solo sapere se è possibile farlo apparire centrato nello GridView. Come un 'T', non so se mi spiego ... xD

Grazie :-)

Edit:

Questo è il layout che contiene il GridView

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/section_title_root" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:background="@drawable/bg_gd_home_grid"> 
    <ImageView 
    android:src="@drawable/home_grid_txori" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_marginTop="40dip" 
    android:layout_centerHorizontal="true"/> 
    <GridView 
     android:id="@+id/home_grid" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_alignParentBottom="true" 
     android:numColumns="3" 
     android:drawSelectorOnTop="true" 
     android:layout_marginBottom="30dip" 
     android:layout_marginLeft="30dip" 
     android:layout_marginRight="30dip" 
     android:padding="5dip" 
     android:listSelector="@android:color/transparent" 
     android:background="@drawable/bg_home_grid_item" 
/> 
</RelativeLayout> 

a proposito, android:layout_centerHorizontal="true" non funziona in GridView

Solution Edit:

Questo problema è da anni passati, ma mi è stato chiesto di inviare la soluzione e ho dovuto trovare il mio vecchio pronti contro termine per farlo :-)

Come ho detto soffietto nei commenti, Non potevo realizzarlo solo in XML, quindi ho dovuto ingannare un falso oggetto non cliccabile + non focalizzabile in 3a posizione.

È stata la mia prima app in assoluto, quindi non ho implementato la soluzione "ViewHolder" consigliata. Consiglio vivamente il suo utilizzo

Questo è come il mio metodo GetView() appare come l'adattatore:

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

     if (convertView == null) { 

      convertView = (RelativeLayout) mInflater.inflate(
        R.layout.home_grid_item, null); 

     } 

     /* In order to have 4th item centered in the 2nd row, we create an empty 3rd item */ 
     if (position == 3) { 
      convertView.setFocusable(false); 
      convertView.setClickable(false); 
     } else { 
      ImageView imageView = (ImageView) convertView 
        .findViewById(R.id.image); 
      imageView.setImageResource(mThumbs[position]); 
      TextView textView = (TextView) convertView.findViewById(R.id.title); 
      textView.setText(mTitles[position]); 

     } 

     convertView.setTag(mTabTags[position]); 

     return convertView; 
    } 

risposta

1

si può provare il seguente codice:

android:gravity="center_horizontal" 

nel xml.

+0

Non funziona ... grazie! –

+0

puoi pubblicare il tuo xml? – Herter

+0

prova a guardarti intorno. Http://developer.android.com/reference/android/widget/GridView.html#attr_android:gravity – Herter

0

Ecco come ho risolto questo problema. Ho impostato in modo dinamico numcolumn quando conosco esattamente la colonna.

<GridView 
     android:id="@+id/gr_single" 
     android:verticalSpacing="@dimen/pay_mode_icon_margin" 
     android:horizontalSpacing="@dimen/pay_mode_icon_margin" 
     android:columnWidth="@dimen/pay_icon_width" 
     android:gravity="center" 
     android:stretchMode="columnWidth" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content"/> 

Nella java.

mGridView.setNumColumns(mSingleImageViews.size()); 
mGridView.setAdapter(new ImageAdapter());