返回顶部
首页 > 资讯 > 移动开发 >Flutter GridView 自定义宽高
  • 252
分享到

Flutter GridView 自定义宽高

flutter 2023-10-04 13:10:39 252人浏览 安东尼
摘要

        首先在children获取控件中进行高度设置,是不生效的。因为系统默认宽高比属性childAspectRatio控制,默认宽高比1:1。         先介绍一下系统自带的方式调整大小,但是这个不能控制他的宽高固定是多少,

        首先在children获取控件中进行高度设置,是不生效的。因为系统默认宽高比属性childAspectRatio控制,默认宽高比1:1。
        先介绍一下系统自带的方式调整大小,但是这个不能控制他的宽高固定是多少,只能修改他的比例
GridView.builder(          padding: EdgeInsets.fromLTRB(20, 20, 20, 0),          itemCount: 10,          gridDelegate: const SliverGridDelegateWithFixedCrossAxisCount(             //一行多少个            crossAxisCount: 2,            crossAxisSpacing: 20, //设置列间距            mainAxisSpacing: 10, //设置行间距          ),          itemBuilder: _initlistdata)
        还有一种方式就是直接重写girdview的源码,这个也是我在网上找大神提供的代码,非常好用,废话不多说直接上代码

 

import 'package:flutter/cupertino.dart';import 'package:flutter/material.dart';/// 多按钮布局,可用于单行及多行按钮布局/// 平均分配每个按钮宽度,自适应每行最高高度/// 可添加按钮之间的间距,可添加多行之间的间距class OptionGridView extends StatelessWidget {  final int itemCount;  final int rowCount;  final int columnCount;  final double mainAxisSpacing;  final double crossAxisSpacing;  final EdgeInsetsGeometry? padding;  final IndexedWidgetBuilder itemBuilder;  /// [itemCount] 按钮总个数  /// [rowCount] 每行按钮个数  /// [mainAxisSpacing] 行间距  /// [crossAxisSpacing] 按钮间距  OptionGridView({    Key? key,    required this.itemCount,    required this.rowCount,    this.mainAxisSpacing = 0.0,    this.crossAxisSpacing = 0.0,    this.padding = const EdgeInsets.all(0),    required this.itemBuilder,  })  : assert(itemCount >= 0),        assert(rowCount > 0),        columnCount = (itemCount / rowCount).ceil(),        assert(mainAxisSpacing >= 0),        assert(crossAxisSpacing >= 0),        super(key: key);  @override  Widget build(BuildContext context) {    return ListView.separated(      itemCount: columnCount,      padding: padding,      physics: const NeverScrollableScrollPhysics(),      shrinkWrap: true,      controller: ScrollController(keepScrollOffset: false),      separatorBuilder: (context, index) => SizedBox(height: mainAxisSpacing),      itemBuilder: (context, index) => buildRow(context, index),    );  }  Widget buildRow(BuildContext context, int index) {    if (index < columnCount - 1) {      List row = [];      for (int i = 0; i < rowCount; i++) {        row.add(Expanded(          flex: 1,          child: itemBuilder(context, i + index * rowCount),        ));        if (crossAxisSpacing > 0.0 && i < rowCount - 1) {          row.add(SizedBox(width: crossAxisSpacing));        }      }      return Row(crossAxisAlignment: CrossAxisAlignment.start, children: row);    } else {      // 最后一行      List row = [];      for (int i = 0; i < rowCount; i++) {        int currentIndex = i + index * rowCount;        if (currentIndex < itemCount) {          row.add(Expanded(            flex: 1,            child: itemBuilder(context, i + index * rowCount),          ));          if (crossAxisSpacing > 0.0 && i < rowCount - 1) {            row.add(SizedBox(width: crossAxisSpacing));          }        } else {          row.add(const Expanded(flex: 1, child: SizedBox()));        }      }      return Row(crossAxisAlignment: CrossAxisAlignment.start, children: row);    }  }}

重写后的代码使用 

OptionGridView(          itemCount: 12,          rowCount: 3,          mainAxisSpacing: 10,          crossAxisSpacing: 10,          itemBuilder: _initlistdata,        ),

上述就是修改GridView展示的全部代码了,喜欢的留个赞吧 

来源地址:https://blog.csdn.net/as425017946/article/details/131395380

--结束END--

本文标题: Flutter GridView 自定义宽高

本文链接: https://lsjlt.com/news/423394.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Flutter GridView 自定义宽高
            首先在children获取控件中进行高度设置,是不生效的。因为系统默认宽高比属性childAspectRatio控制,默认宽高比1:1。         先介绍一下系统自带的方式调整大小,但是这个不能控制他的宽高固定是多少,...
    99+
    2023-10-04
    flutter
  • Flutter高级玩法Flow位置自定义
    目录前言第一幕、开场-演员入台1. 展示舞台2. Flow出场3. FlowDelegate出场4. paintChildren方法和FlowPaintingContext对象第二幕...
    99+
    2023-03-03
    Flutter Flow位置自定义 Flutter Flow
  • Flutter高级玩法Flow位置怎么自定义
    本篇内容介绍了“Flutter高级玩法Flow位置怎么自定义”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言Flow布局是一个超级强大的布...
    99+
    2023-07-05
  • Android怎么自定义精美的GridView
    要自定义精美的GridView,你可以按照以下步骤进行: 创建一个新的GridView布局文件:创建一个新的XML布局文件,例如...
    99+
    2023-10-23
    Android GridView
  • Flutter自定义搜索框效果
    本文实例为大家分享了Flutter自定义搜索框效果的具体代码,供大家参考,具体内容如下 效果 实现方式 import 'package:dio/dio.dart'; impor...
    99+
    2024-04-02
  • Flutter自定义圆盘取色器
    本文实例为大家分享了Flutter自定义圆盘取色器的具体代码,供大家参考,具体内容如下 下面展示一些 内联代码片。 圆盘取色器 效果图 完整代码 import 'dart:ma...
    99+
    2024-04-02
  • Flutter自定义弹窗Dialog效果
    本文实例为大家分享了Flutter自定义弹窗Dialog效果的具体代码,供大家参考,具体内容如下 主要是基于系统的dialog机制做一些使用限制和自定义UI的优化 核心代码: cl...
    99+
    2024-04-02
  • Flutter怎么实现自定义themes
    这篇“Flutter怎么实现自定义themes”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Flutter怎么实现自定义th...
    99+
    2023-07-05
  • Flutter怎么集成高德地图并添加自定义Maker
    这篇文章主要介绍“Flutter怎么集成高德地图并添加自定义Maker”,在日常操作中,相信很多人在Flutter怎么集成高德地图并添加自定义Maker问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Flutt...
    99+
    2023-06-29
  • Flutter自定义Appbar搜索框效果
    本文实例为大家分享了Flutter自定义Appbar搜索框效果的具体代码,供大家参考,具体内容如下 首先看一下实现本次实现的效果。 本来想直接偷懒从flutter pub上找个能用...
    99+
    2024-04-02
  • Flutter自定义年月日倒计时
    本文实例为大家分享了Flutter自定义年月日倒计时的具体代码,供大家参考,具体内容如下 因项目中的订单页需要一个定时器,比如下单后需要进行倒计时,等倒计时完后,订单状态自动关闭。 ...
    99+
    2024-04-02
  • Android自定义View实现可以拖拽的GridView
    先看看效果图 主要思想: 1、监听触碰事件 2、用WindowManager添加拖曳的图片 3、用Collections.swap()交换List数据 自定义代码: pu...
    99+
    2022-06-06
    view gridview Android
  • Flutter集成高德地图并添加自定义Maker的实践
    目录一、进入高德地图开放平台申请Key二、yaml文件集成插件目前地图开放平台三大巨头:高德、百度、腾讯基本都支持Flutter插件开发集成。从这里也能看出Flutter的生态在逐渐...
    99+
    2024-04-02
  • 【Flutter】Flutter 设置默认字体 设置自定义字体
    文章目录 一、前言本文重点版本信息 二、如何在 Flutter 中设置默认字体Flutter 中字体的设置方式全局字体设置的步骤和代码示例 三、在 Flutter 中使用自定义字体...
    99+
    2023-09-06
    flutter android ios 前端 原力计划
  • 详解Flutter如何完全自定义TabBar
    目录前言实现过程完整代码总结前言 在App中TabBar形式交互是非常常见的,但是系统提供的的样式大多数又不能满足我们产品和UI的想法,这篇就记录下在Flutter中我在实现自定义T...
    99+
    2024-04-02
  • flutter tabBar 的属性及自定义实现
    flutter tabBar 的属性及自定义实现 前言一、TabBar是什么?二、TabBar 自定义三、 Tab 自定义总结 前言 在Flutter中,TabBar的indicato...
    99+
    2023-09-06
    flutter 开发语言
  • Flutter之自定义路由切换动画
    Flutter之自定义路由切换动画 在Flutter中,我们可以通过Navigator来实现路由管理,包括路由的跳转和返回等。默认情况下,Flutter提供了一些简单的路由切换动画,但是有时候我们需要...
    99+
    2023-09-21
    flutter android 动画 职场和发展 学习 经验分享
  • GridView中如何自定义分页的存储过程
    GridView中如何自定义分页的存储过程,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1. 为什么不使用GridView的默...
    99+
    2024-04-02
  • Flutter实现自定义筛选框的方法
    本篇内容主要讲解“Flutter实现自定义筛选框的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Flutter实现自定义筛选框的方法”吧!目录一、首先自定义筛选框的按钮视图,布局很简单,一个...
    99+
    2023-06-20
  • Flutter刷新组件RefreshIndicator自定义样式demo
    目录前言效果图RefreshIndicator初始样式RefreshIndicator样式修改(简单)RefreshIndicator样式修改(复杂)简单的样式修改复杂的样式修改前言...
    99+
    2023-02-22
    Flutter RefreshIndicator样式 Flutter 刷新组件 RefreshIndicator自定义样式
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作