Flutter   发布时间:2022-03-30  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Flutter Widgets 之 ListWheelScrollView大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

Flutter Widgets 之 ListWheelScrollView

基础用法

在展示大量数据的时候我们第一会想到使用ListView,如果你觉得ListView比较单一、枯燥,你可以使用ListWheelScrollView,ListWheelScrollView和ListView同源,但它的渲染效果类似于车轮(或者滚筒),它不是在平面上滑动,而是转动车轮,先来看一波效果

Flutter Widgets 之 ListWheelScrollView

ListWheelScrollView的用法和ListView基本相同,基础用法

ListWheelScrollView(
      itemExtent: 150,children: <Widget>[
		...
	  ],);
@H_675_23@

children 是子控件,itemExtent 指定每一个Item的高度。

当有大量数据的时候这种方式明显是不科学的,就像ListView.builder一样,用法如下:

ListWheelScrollView.useDelegate(
      itemExtent: 150,childDelegate: ListWheelChildBuilderDelegate(
          builder: (context,indeX) {
            return Container(
              margin: EdgeInsets.symmetric(vertical: 10,horizontal: 30),color: Colors.primaries[index % 10],alignment: Alignment.center,child: Text('$index'),);
          },childCount: 100),);
@H_675_23@

调整直径

ListWheelScrollView的渲染效果类似车轮,设置diameterRatio 调整其直径属性

ListWheelScrollView(
      itemExtent: 150,diameterRatio: 1,children: <Widget>[
        ...
      ],)
@H_675_23@

diameterRatio是圆筒直径和主轴渲染窗口的尺寸的比,认值是2,如果是垂直方向,主轴渲染窗口的尺寸是ListWheelScrollView的高。diameterRatio越小表示圆筒越圆。

调整perspective

perspective属性表示圆柱投影透视图,类似OpenGLES中透视投影,理解为看圆柱的距离,为0时表示从无限远处看,1表示从无限近处看,值的范围(0,0.01],注意是左开右闭区间,认值是0.003,值越大,渲染效果越圆,用法如下:

ListWheelScrollView(
      itemExtent: 150,perspective: 0.003,);
@H_675_23@

offAxisFraction

offAxisFraction 属性表示车轮水平偏离中心的程度,用法如下:

ListWheelScrollView(
      itemExtent: 150,offAxisFraction: 13,children: <Widget>[

      ],);
@H_675_23@

offAxisFraction 的值从0到2的效果

Flutter Widgets 之 ListWheelScrollView

放大镜

通过useMagnifier和@H_682_21@magnification属性实现放大镜效果useMagnifier是否启用放大镜,@H_682_21@magnification属性是放大倍率,用法如下:

ListWheelScrollView(
      itemExtent: 150,useMagnifier: true,magnification: 1.5,);
@H_675_23@

效果如下:

Flutter Widgets 之 ListWheelScrollView

squeeze

squeeze属性表示车轮上的子控件数量与在同等大小的平面列表上的子控件数量之比,例如,如果高度为100px,[itemExtent]为20px,那么5个项将放在一个等效的平面列表中。当squeeze为1时,RenderListWheelViewport中也会显示5个子控件。当squeeze为2时,RenderListWheelViewport中将显示10个子控件,认值为1,用法如下:

ListWheelScrollView(
      itemExtent: 150,squeeze: 1,);
@H_675_23@

更多相关阅读:

如果这篇文章有帮助到您,希望您来个“赞”并关注我的公众号,非常谢谢。

Flutter Widgets 之 ListWheelScrollView

大佬总结

以上是大佬教程为你收集整理的Flutter Widgets 之 ListWheelScrollView全部内容,希望文章能够帮你解决Flutter Widgets 之 ListWheelScrollView所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: