Android 如何创建响应性GridView以覆盖整个屏幕?

Android 如何创建响应性GridView以覆盖整个屏幕?,android,xml,android-layout,gridview,gridviewrow,Android,Xml,Android Layout,Gridview,Gridviewrow,我在Android应用程序的活动中有以下布局: <ImageView android:layout_height="32dp" android:id="@+id/imageView1" android:layout_width="32dp" android:layout_alignParentTop="true" android:layout_centerHorizontal="true">

我在Android应用程序的活动中有以下布局:

    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>

    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>
有3个部分和10个按钮,带有图标和文本。 正如你在大屏幕(现在大多数手机)上看到的,我在屏幕底部有很多空白。 你知道如何使用整个房间并填充白色部分来制作GridView吗? 是否有可能使其具有响应性,以便网格的每一行和每一列都能根据屏幕大小进行调整

    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>
以下是我的XML文件:

    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>
我的活动.xml(由我的活动使用)

    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>

    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>
gridview_row.xml(由GridViewAdapter使用)

    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>

如果您想为所有设备提供响应性布局,最好使用以下约束布局示例:

    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>


    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>
请记住这只是一个示例,您可以随意更改视图的比率/高度/宽度。

    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>

关于指导原则的小说明-它们使用起来非常舒适,在上面的示例中,您可以看到我给出了指导原则百分比,以便告诉它们如何在屏幕上放置(相对于屏幕)。

您可以使用带有多个指导原则的ConstraintLayout。它们可以放置在屏幕宽度的30%处,并且可以制作内容来填充指南之间的空间
    <ImageView
        android:layout_height="32dp"
        android:id="@+id/imageView1"
        android:layout_width="32dp"    
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">
    </ImageView>

    <TextView
        android:text="TextView"
        android:layout_height="wrap_content"
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_below="@+id/imageView1"
        android:layout_marginTop="5dp"
        android:layout_centerHorizontal="true"
        android:textSize="18sp"
        android:ellipsize="marquee">
    </TextView>
</RelativeLayout>