Удаление лишних отступов в GridView в Android

Я хочу удалить дополнительный отступ, который появляется в виде сетки. У меня есть изображения размером 128*128, которые будут занимать ячейки в сетке. Но почему-то есть дополнительное пространство, которое добавляется к содержимому сетки.

После некоторых исследований я смог определить, что мне нужно переопределить свойство listSelector вида сетки. Теперь вот мой вопрос - я знаю, что здесь нужно указать что-то вроде xml, но что в этом указать? Я попытался использовать форму, которую можно нарисовать с отступом и ходом, установленным на 0dp, но безрезультатно.

Здесь задают и отвечают на вопрос, но они не дали того, что должно содержать рисование.

Может кто-то помочь мне с этим. Спасибо!

РЕДАКТИРОВАТЬ: Хорошо - вот копия интерфейса, который у меня есть. И XML-макет для того же выглядит следующим образом:

<GridView android:id="@+id/GV_A2ZMenu" android:layout_width="fill_parent"
    android:layout_height="wrap_content" android:numColumns="4"
            android:layout_gravity="top" android:stretchMode="columnWidth"
    android:gravity="center" android:listSelector="@null" />

И я использую класс BaseAdapter для заполнения gridView. Вот его код:

public class AtoZMenu extends BaseAdapter {

private static Context AppC;

private Integer[] MenuImg = { R.drawable.alphabet_a, R.drawable.alphabet_b,
        R.drawable.alphabet_c, R.drawable.alphabet_d,
        R.drawable.alphabet_e, R.drawable.alphabet_f,
        R.drawable.alphabet_g, R.drawable.alphabet_h,
        R.drawable.alphabet_i, R.drawable.alphabet_j,
        R.drawable.alphabet_k, R.drawable.alphabet_l,
        R.drawable.alphabet_m, R.drawable.alphabet_n,
        R.drawable.alphabet_o, R.drawable.alphabet_p,
        R.drawable.alphabet_q, R.drawable.alphabet_r,
        R.drawable.alphabet_s, R.drawable.alphabet_t,
        R.drawable.alphabet_u, R.drawable.alphabet_v,
        R.drawable.alphabet_w, R.drawable.alphabet_x,
        R.drawable.alphabet_y, R.drawable.alphabet_z };

public AtoZMenu(Context C) {
    AppC = C;
}

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

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

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

public View getView(int position, View convertView, ViewGroup parent) {
    ImageView IV;
    float density = AppC.getResources().getDisplayMetrics().density;

    if (convertView == null) {
        IV = new ImageView(AppC);
        IV.setMaxHeight((int) (1));
    } else {
        IV = (ImageView) convertView;
    }
    IV.setImageResource(MenuImg[position]);
    return IV;
}
 }

Вы можете заметить ошибку?

Примечание. В итоге я реализовал похожий экран в макете таблицы, который отображает намного лучшие сетки.

6 ответов

Решение

Да, у меня была такая же проблема. Вы хотите установить для listSelector значение @null:

<!-- Setting the listSelector to null removes the 5px border -->
<GridView
    android:id="@+id/view"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:listSelector="@null" />

Также попробуйте следующее:

myGridView.setStretchMode(GridView.STRETCH_COLUMN_WIDTH);

Я вижу, вы можете сделать это в XML, но я не сделал, когда у меня была такая же проблема; не уверен почему.

Я также жестко прописал высоту клавиш:

float density = getContext().getResources().getDisplayMetrics().density;
mKeyHeight = (int) (56 * density);
....
@Override
public View getView(int position, View convertView, ViewGroup parent) {
    ImageButton b = (ImageButton) convertView;
    if (b == null) {
        b = new ImageButton(getContext());
        b.setMinimumHeight(mKeyHeight);
        b.setBackgroundResource(R.drawable.btn_keyboard_key);
        b.setOnClickListener(this);
    }
}

Извините, что не дал точного ответа, поэтому дайте мне знать, если вам все еще нужна помощь после этого.

Правильный ответ - установить android:listSelector в @android:color/transparent, как сказал пользователь mvds здесь.

Даже у меня была такая же проблема. Попробуй это:

image.setLayoutParams(new GridView.LayoutParams(imageWidth , imageHeight)); imageView.setScaleType(ImageView.ScaleType.FIT_XY);,

Добавьте отступы соответственно для изображений. Это сработало для меня.

Я использовал вариант решения Шона... это хорошо смотрится на Эмуляторе.

1) Определитесь с количеством столбцов, я выбрал 4

2) Установите ширину столбца

float xdpi = this.getResources().getDisplayMetrics().xdpi;
int mKeyHeight = (int) ( xdpi/4 );

GridView gridView = (GridView) findViewById(R.id.gridview); 
gridView.setColumnWidth( mKeyHeight );// same Height & Width

3) Настройте изображение в методе getView вашего адаптера.

imageView = new ImageView( mContext );
// (xdpi-4) is for internal padding
imageView.setLayoutParams(new GridView.LayoutParams( (int) (xdpi-4)/2, (int) (xdpi-4)/2));
imageView.setScaleType( ImageView.ScaleType.CENTER_CROP );
imageView.setPadding(1, 1, 1, 1);

4) макет

<?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:numColumns="4"
    android:verticalSpacing="0dp"
    android:horizontalSpacing="0dp"
    android:gravity="center"
    android:listSelector="@null"
/>
<!-- 
    android:columnWidth="90dp"  Specified in code 
    android:stretchMode="columnWidth" no noticable change
-->

Вот и все.

У меня была похожая проблема, хотя в моем случае была довольно большая область заполнения в нижней части моего GridView (было заполнено цветом фона).
Я не видел решения моей проблемы здесь, поэтому я опубликую это здесь, если это будет полезно.

Помимо настройки:

android:listSelector="@null"

в моем GridView я также должен был установить:

android:fadingEdgeLength="0px"

Или в Java:

GridView.setFadingEdgeLength(0);

Попробуйте дать отступы в пикселях, как это

        android:paddingLeft="5px"
Другие вопросы по тегам