Android 安卓布局;调整图像列的大小,使其适合屏幕

Android 安卓布局;调整图像列的大小,使其适合屏幕,android,android-layout,Android,Android Layout,我正在努力使我的图像在不重叠的情况下很好地融入屏幕 但无论我做什么,我都无法让它们正确地缩放。 我原以为ImageView.ScaleType.CENTER\u CROP会缩放我的图像,但可能我做得都不对。 任何帮助都将不胜感激。(如果你知道一个简单的函数可以解决我的问题,那么请不必阅读我的代码(大部分代码都是教程代码)就可以自由响应) 以下是我得到的: main.xml文件: <?xml version="1.0" encoding="utf-8"?> <GridView

我正在努力使我的图像在不重叠的情况下很好地融入屏幕 但无论我做什么,我都无法让它们正确地缩放。 我原以为ImageView.ScaleType.CENTER\u CROP会缩放我的图像,但可能我做得都不对。 任何帮助都将不胜感激。(如果你知道一个简单的函数可以解决我的问题,那么请不必阅读我的代码(大部分代码都是教程代码)就可以自由响应)

以下是我得到的: main.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="fill_parent" 
    android:layout_height="fill_parent"
    android:columnWidth="75dp"
    android:numColumns="auto_fit"
    android:verticalSpacing="0dp"
    android:horizontalSpacing="1dp"
    android:stretchMode="columnWidth"
    android:gravity="center"
/>
我尝试在main.xml文件中编辑填充和水平间距。
我得到的垂直间距刚刚好。我只是在图像调整大小方面遇到问题,所以它们完全适合屏幕

在代码中使用硬编码“图像布局”的一个选项是为ImageView创建新布局。然后在代码中膨胀布局

这样做的好处是,您可以使用graphicla ui编辑器查看属性,查看ImageView行为的预览,并且在不修改代码的情况下更容易修改行为。(例如,对于其他屏幕尺寸,您可能希望使用不同的布局)

更新: 您可以在此处找到如何充气视图的示例:

试一下这个

<GridView xmlns:android="http://schemas.android.com/apk/res/android" 
        android:id="@+id/gridview"
        android:layout_width="fill_parent" 
        android:layout_height="fill_parent"
        android:columnWidth="90dp"
        android:numColumns="auto_fit"
        android:verticalSpacing="10dp"
        android:horizontalSpacing="10dp"
        android:stretchMode="columnWidth"
        android:gravity="center"
    />

正如Kaj已经回答了上述问题,我完全同意他的看法。仅使用ImageView创建行布局文件,然后在ImageAdapter类中展开相同的布局

这种行xml布局的主要优点是可以预览布局


在创建ImageView时,请确保您定义了android:scaleType=“center”,使其显示在中心区域。

而不是试图找出android xml文件中的布局,我下载了AndEngine for android,它非常适合对图像进行排序,使它们彼此相邻。它还允许屏幕滚动,在游戏设计方面非常好。如果其他人感兴趣,这里有链接


感谢您的回复。我很难理解你所说的硬编码是什么意思?你是说“程序化”的UI布局吗?以及在代码中增加布局意味着什么。也许如果你有一些基本布局代码的片段可以告诉我,我会更容易理解。我更新了我的回复,添加了一个扩展布局的示例链接。感谢提供实际代码:)这可以阻止图像重叠,但是我希望图像可以紧挨着彼此,而不重叠。谢谢谢谢你的帮助。在哪里可以找到版面预览?@Xitcod13您在设计版面时没有得到预览吗?我得到了,谢谢。我只是习惯于手工编辑xml文件,我忘了还有另一个标签
package com.grid.example;

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

public class ImageAdapter extends BaseAdapter {
    private Context myContext;

    public ImageAdapter(Context c) {
        myContext = 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(myContext);
            imageView.setLayoutParams(new GridView.LayoutParams(85, 85));
            imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
            imageView.setPadding(4, 0, 4, 0 );
        } else {
            imageView = (ImageView) convertView;
        }

        imageView.setImageResource(mThumbIds[position]);


        return imageView;

    }

    // references to our images
private Integer[] mThumbIds = {

            R.drawable.sample_0, R.drawable.sample_3,
            R.drawable.sample_4, R.drawable.sample_5,
            R.drawable.sample_6, R.drawable.sample_7,
            R.drawable.sample_0, R.drawable.sample_1,
            R.drawable.sample_2, R.drawable.sample_3,
            R.drawable.sample_4, R.drawable.sample_5,
            R.drawable.sample_6, R.drawable.sample_7,
            R.drawable.sample_0, R.drawable.sample_1,
            R.drawable.sample_2, R.drawable.sample_3,
            R.drawable.sample_4, R.drawable.sample_5,
            R.drawable.sample_6, R.drawable.sample_7,
            R.drawable.sample_2, R.drawable.sample_3,
            R.drawable.sample_4, R.drawable.sample_5,
            R.drawable.sample_6, R.drawable.sample_7,
            R.drawable.sample_0, R.drawable.sample_1,
            R.drawable.sample_2, R.drawable.sample_3,
            R.drawable.sample_4, R.drawable.sample_5,
            R.drawable.sample_6, R.drawable.sample_7,
            R.drawable.sample_0, R.drawable.sample_1,
            R.drawable.sample_2, R.drawable.sample_3,
            R.drawable.sample_4, R.drawable.sample_5,
            R.drawable.sample_6, R.drawable.sample_7,
            R.drawable.sample_2, R.drawable.sample_3,
            R.drawable.sample_4, R.drawable.sample_5
            };

}
<GridView xmlns:android="http://schemas.android.com/apk/res/android" 
        android:id="@+id/gridview"
        android:layout_width="fill_parent" 
        android:layout_height="fill_parent"
        android:columnWidth="90dp"
        android:numColumns="auto_fit"
        android:verticalSpacing="10dp"
        android:horizontalSpacing="10dp"
        android:stretchMode="columnWidth"
        android:gravity="center"
    />