使用代码定义GridLayout的方法

网上关于GridLayout的使用方法基本上都是用的xml文件,但既然是要使用网格布局,那说明准备放入其中的子视图肯定不少,都用xml写太过繁琐,那么如果我们想要代码来描述,应该怎么办呢?

问题的关键就是要使用 GridLayout.Spec类。

下面我简单演示一下利用GridLayout.Spec定义GridLayout,给出与xml等价的Java下和Xamarin.Android代码;


1.

定义子视图位于4行4列

android:columnCount="3"
android:rowCount="3"

Java

        GridLayout.Spec row = GridLayout.spec(3);
        GridLayout.Spec col = GridLayout.spec(3);

        Button view = new Button(context);
        view.setLayoutParams(new GridLayout.LayoutParams(row, col));
        gridLayout.addView(view);

Xamarin.Android

需要注意的是,在Xamarin.Android下GridLayout.spec不是GridLayout.Spec,而是GridLayout.InvokeSpec。

    var row = GridLayout.InvokeSpec(3);
    var col = GridLayout.InvokeSpec(3);

    var button = new Button(context);
    button.LayoutParameters = new GridLayout.LayoutParams(row, col);
    gridLayout.AddView(button);

2.

定义子视图位于4行4列,横跨2行,纵向跨3列

android:columnCount="3"
android:rowCount="3"
android:layout_rowSpan = "2" 
android:layout_columnSpan = "3"   

Java

        GridLayout.Spec row = GridLayout.spec(3,2);
        GridLayout.Spec col = GridLayout.spec(3,3);

        Button view = new Button(context);
        view.setLayoutParams(new GridLayout.LayoutParams(row, col));
        gridLayout.addView(view);

Xamarin.Android

    var row = GridLayout.InvokeSpec(3,2);
    var col = GridLayout.InvokeSpec(3,3);

    var button = new Button(context);
    button.LayoutParameters = new GridLayout.LayoutParams(row, col);
    gridLayout.AddView(button);

3.

定义子视图位于4行4列,横纵的比重都为1;

android:columnCount="3"
android:rowCount="3"
android:layout_rowWeight="1" 
android:layout_columnWeight="1"

Java

        GridLayout.Spec row = GridLayout.spec(3,1.0f);
        GridLayout.Spec col = GridLayout.spec(3,1.0f);

        Button view = new Button(context);
        view.setLayoutParams(new GridLayout.LayoutParams(row, col));
        gridLayout.addView(view);

Xamarin.Android

    var row = GridLayout.InvokeSpec(3,1.0f);
    var col = GridLayout.InvokeSpec(3,1.0f);

    var button = new Button(context);
    button.LayoutParameters = new GridLayout.LayoutParams(row, col);
    gridLayout.AddView(button);

这里需要注意和2代码的不同在于传递给GridLayout.spec方法的参数类型不同,如果是int型则表示是size,如果是float型则表示weight。

注意:为了使子视图完全按照我们给定的权重进行布局,我们可以将params的width和height设为0,但在Android5.1版本上使用该方法可能会出现子视图不可见的情况,这个时候我们还需要添加params.setGravity(Gravity.FILL);

GridLayout.spec还有更复杂的重载版本。


Xamarin.Android都有与之对应的方法,只不过调用名为InvokeSpec而已。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,809评论 25 709
  • afinalAfinal是一个android的ioc,orm框架 https://github.com/yangf...
    passiontim阅读 15,646评论 2 45
  • 编译安装libimobiledevice 环境准备 确保你的开发环境满足 Development Packages...
    喵帕斯阅读 1,575评论 0 3
  • 当开片的镜头摇到徐峥那一头八九十年代标准的文艺男青年长发时,我就知道:好吧,又是一部主打怀旧的片子。几分钟后响起的...
    CoreyShu阅读 1,002评论 11 7
  • 感情的开始,需要双方的首肯,感情的终止,一方的背离即意味着结束。任意一方都有权在任何时间地点向对方宣告感情的破裂,...
    YoyoSuperyo阅读 160评论 0 0