Android: Como o GridView auto_fit encontra o número de coluna

Gostaria de entender melhor comoGridview funciona, em particularauto_fit. Aqui está o layout XML:

<?xml version="1.0" encoding="utf-8"?>
<GridView xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/gridview"
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content"
    android:columnWidth="60dp"
    android:numColumns="auto_fit"
/>

E funciona bem com uma série de seis miniaturas (48 * 48 pixels). No modo retrato, ele exibe uma linha, seis coluna

O que eu não entendo é por que a linhaandroid:columnWidth="60dp" é necessário porque auto_fitspera-se que @ encontre o número certo de coluna
Sem a linhaandroid:columnWidth="60dp", exibe uma grade 3 linhas e 2 coluna

Aqui está oImageAdapter classe

package com.examples.HelloGridView;

import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;

public class ImageAdapter extends BaseAdapter {
    private Context mContext;

    public ImageAdapter(Context c) {
        mContext = c;
    }

    public int getCount() {
        return mThumbIds.length;
    }

    public Object getItem(int position) {
        return null;
    }

    public long getItemId(int position) {
        return 0;
    }

    // create a new ImageView for each item referenced by the Adapter
    public View getView(int position, View convertView, ViewGroup parent) {
        ImageView imageView;
        if (convertView == null) {  // if it's not recycled, initialize some attributes
            imageView = new ImageView(mContext);
            imageView.setPadding(0, 0, 0, 0);
        } else {
            imageView = (ImageView) convertView;
        }

        imageView.setImageResource(mThumbIds[position]);
        return imageView;
    }

    // references to our images
    private Integer[] mThumbIds = {
            R.drawable.ic_1, R.drawable.ic_2,
            R.drawable.ic_3, R.drawable.ic_4,
            R.drawable.ic_5, R.drawable.ic_6
    };
}

Obrigado pela ajuda

questionAnswers(5)

yourAnswerToTheQuestion