带按钮的简单网格视图

Rav*_*avo 0 c# visual-studio xamarin.android

如何使用按钮制作简单的网格视图?我已经尝试了最明显的解决方案,但它不起作用。教程真的很糟糕(对我来说),而且简单的解决方案不起作用。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
  <GridView
      android:id="@+id/gridView"
      android:layout_width="match_parent"
      android:layout_height="155.5dp"
      android:numColumns="2"
      android:padding="10dp"
      android:layout_marginBottom="68.0dp"
      android:background="#009967">
      <Button
        android:text="Button"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/button1" />
  </GridView>

</LinearLayout>
Run Code Online (Sandbox Code Playgroud)

Sag*_*Kho 5

SpinnersGridViews并且ListViews是 android 的子类AdapterViews。这意味着它们没有子元素,并且它们是使用扩展BaseAdapter类的自定义适配器以编程方式动态创建的。

Android AdapterViews

要执行您需要执行的操作,首先创建一个空活动并将其命名为GridActivity。将 Activity_grid.xml 布局文件编辑为空的GridView. 例子 -

<?xml version="1.0" encoding="utf-8"?>
<GridView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.user.gridbuttonview.GridActivity"
    android:columnWidth="90dp"
    android:id="@+id/activity_grid"
    android:gravity="center"
    android:horizontalSpacing="10dp"
    android:numColumns="auto_fit"
    android:stretchMode="columnWidth"
    android:verticalSpacing="10dp" />
Run Code Online (Sandbox Code Playgroud)

然后在您的项目中创建一个新类,命名ButtonAdapter如下 -

请注意,可以在变量中设置按钮总数total_btns,默认为 20。

import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.Toast;

public class ButtonAdapter extends BaseAdapter
{
    private Context mContext;
    private int btn_id;
    private int total_btns = 20;

    public ButtonAdapter(Context context) {
        this.mContext = context;
    }

    @Override
    public int getCount() {
        return total_btns;
    }

    @Override
    public Object getItem(int i) {
        return null;
    }

    @Override
    public long getItemId(int i) {
        return 0;
    }

    @Override
    public View getView(final int i, View view, ViewGroup viewGroup)
    {
        Button btn;

        if (view == null) {
            btn = new Button(mContext);
            btn.setText("Button " + (++btn_id));
        } else {
            btn = (Button) view;
        }

        btn.setOnClickListener(new View.OnClickListener()
        {
            @Override
            public void onClick(View v)
            {
                Toast.makeText(v.getContext(), "Button #" + (i + 1), Toast.LENGTH_SHORT).show();
            }
        });

        return btn;
    }
}
Run Code Online (Sandbox Code Playgroud)

最后,更改GridActivity类的onCreate方法以在创建时设置 gridView。

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_grid);

    GridView gridview = (GridView) findViewById(R.id.activity_grid);
    gridview.setAdapter(new ButtonAdapter(this));
}
Run Code Online (Sandbox Code Playgroud)

这将创建您想要的带有按钮的网格视图。一旦触发网格活动,您就会得到以下输出 -

在此输入图像描述

可以编辑适配器类中的单击侦听器来处理每次单击。希望能帮助到你!