图像和文本居中的 GridView

GridView with image and text on center

您好,我想开发这种类型的布局,但我很困惑是这样对齐的网格视图还是图像视图。 好吧,我的问题是如何在我工作的片段中实现这种类型的菜单

https://www.learn2crack.com/2014/01/android-custom-gridview.html

实施 Gridview 之后

我得到了这样的屏幕

如何使 gridView 看起来像第一张图片?

作为块中心的文字,我真的很想实现它。

grid_single.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:padding="5dp" >

    <ImageView
        android:id="@+id/grid_image"
        android:layout_width="match_parent"
        android:src="@drawable/denist_3"
        android:layout_height="50dp">
    </ImageView>

    <TextView
        android:id="@+id/grid_text"

        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="15dp"
        android:layout_gravity="center"
        android:text="Dentist"
        android:textSize="9sp" >
    </TextView>

</LinearLayout>

main_act.xml:

<RelativeLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">
       <GridView
        android:numColumns="auto_fit"
        android:layout_below="@+id/comsp"
        android:gravity="center"
        android:columnWidth="150dp"
        android:stretchMode="columnWidth"
        android:layout_width="fill_parent"
        android:layout_height="600dp"
        android:id="@+id/grid"
        />

</RelativeLayout>

Adapterclass.java

public class CustomGrid extends BaseAdapter{
    private Context mContext;
    private final String[] web;
    private final int[] Imageid;

    public CustomGrid(Context c,String[] web,int[] Imageid ) {
        mContext = c;
        this.Imageid = Imageid;
        this.web = web;
    }

    @Override
    public int getCount() {
        // TODO Auto-generated method stub
        return web.length;
    }

    @Override
    public Object getItem(int position) {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public long getItemId(int position) {
        // TODO Auto-generated method stub
        return 0;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // TODO Auto-generated method stub
        View grid;
        LayoutInflater inflater = (LayoutInflater) mContext
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);

        if (convertView == null) {

            grid = new View(mContext);
            grid = inflater.inflate(R.layout.grid_single, null);
            TextView textView = (TextView) grid.findViewById(R.id.grid_text);
            ImageView imageView = (ImageView)grid.findViewById(R.id.grid_image);
            textView.setText(web[position]);
            imageView.setImageResource(Imageid[position]);
        } else {
            grid = (View) convertView;
        }

        return grid;
    }
}

Mainactivity.java

     CustomGrid adapter = new CustomGrid(getActivity(), web, imageId);

 grid=(GridView)v.findViewById(R.id.grid);
 grid.setAdapter(adapter);
        grid.setOnItemClickListener(new AdapterView.OnItemClickListener() {

            @Override
            public void onItemClick(AdapterView<?> parent, View view,
                                    int position, long id) {
                Toast.makeText(getActivity(), "You Clicked at " +web[+ position], Toast.LENGTH_SHORT).show();

            }
        });

您的 xml 文件太复杂了。您只需在 activity/fragment 布局中使用 GridView 即可实现此目的。然后,您需要一个自定义适配器 class 来为您的 Gridview 扩充另一个 xml 文件,该文件将仅包含一个图像视图和文本视图。 您可以按照此 link 开始使用 GridView:https://www.learn2crack.com/2014/01/android-custom-gridview.html

要获得叠加布局,您可以使用 FrameLayout,因为它的子视图会相互堆叠。在你的情况下,你的 item_layout.xml 看起来像这样

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent" android:layout_height="match_parent">

    <ImageView
        android:id="@+id/ivBackground"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:src="@drawable/myimage"/>

    <TextView
        android:id="@+id/tvOverlayText"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="@string/mytext"
        android:gravity="center"/>

</FrameLayout>

嘿朋友我得到了上述问题的解决方案.. 检查此解决方案..

  1. main_activity.xml 中的 GridView

       <GridView
            android:id="@+id/listRequests"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_marginLeft="10dp"
            android:layout_marginRight="10dp"
            android:layout_marginTop="10dp"
            android:layout_marginBottom="10dp"
            android:columnWidth="10dp"
            android:background="#e1ecef"
            android:horizontalSpacing="10dp"
            android:numColumns="2"
            android:listSelector="#e1ecef"
            android:scrollbars="none"
            android:stretchMode="columnWidth"
            android:verticalSpacing="10dp"/>
    
    1. Item.xml 自定义适配器

    <ImageView
        android:id="@+id/picture"
        android:layout_width="match_parent"
        android:layout_height="128dp"
        android:layout_gravity="center"
        android:adjustViewBounds="true"
        android:contentDescription="@string/app_name"
        android:src="@drawable/plumbing" />
    
    <TextView
        android:id="@+id/text"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_alignBottom="@id/picture"
        android:layout_alignEnd="@id/picture"
        android:layout_alignStart="@id/picture"
        android:layout_alignTop="@id/picture"
        android:layout_margin="1dp"
        android:background="#55000000"
        android:gravity="center"
        android:text=""
        android:textColor="@android:color/white"
        android:textSize="@dimen/_14sdp"
        android:textStyle="normal" />
    

    1. 这是输出。

希望对你有所帮助...