【交互 widget】Flutter Slider

简介: 【交互 widget】Flutter Slider

image.png


Slider 是 一个 Material Design widget,用于从一个范围中选定一个值。

Flutter Slider 介绍

slider 可以从连续的值中选值,也可以从非连续的值中选值。默认是从 min 到 max 的连续值中选择值。如果要在非连续的值中选值,需要给 divisions 设置一个值。比如 min is 0.0,max is 50.0 ,divisions is 5,slider 可以选择的值有 0.0,10.0,20.0,30.0,40.0,and 50.0。

  • The "thumb" ,当用户拖动它时会水平滑动。
  • The "track","thumb" 滑动的轨道。
  • The "value indicator",当用户拖动 thumb 选择值的时候会弹出 indicator 指示选中的值。
  • The "active" side 是指在 thumb 到 minmum value 的部分。
  • The "inactive" side 是指在 thumb 到 maximum value 的部分。

如果 onChanged 是 null或 min..max 无值可选(比如 min 等于 max),slider 会被禁用。

slider 本身不维护任何状态。当状态变化的时候,调用 onChanged。 多数 widget 可以在这里更新 UI。要知道状态什么时候开始变化,什么时候变化结束,可以监听  onChangedStart,onChangedEnd。

默认情况下, slider 会在水平方向尽量宽,垂直方向居中。如果收到的是 unbouned constrains,slider 会尝试 让 track 144px 宽(两边留有空白),在垂直方向收缩。

slider 要求至少有一个父 widget 是 Material widget。

slider 要求至少有一个父 widget 是 MediaQuery widget。

使用 Slider

const Slider({
    super.key,
    required this.value,
    required this.onChanged,
    this.onChangeStart,
    this.onChangeEnd,
    this.min = 0.0,
    this.max = 1.0,
    this.divisions,
    this.label,
    this.activeColor,
    this.inactiveColor,
    this.thumbColor,
    this.mouseCursor,
    this.semanticFormatterCallback,
    this.focusNode,
    this.autofocus = false,
  })
复制代码

根据参数,我们把参数都用上。

image.png

Container(
      decoration: BoxDecoration(border: Border.all(color: Colors.blue)),
      width: double.infinity,
      height: 200,
        child: Slider(
      value: _currentSliderValue,
      min: 0,
      max: 100,
      divisions: 5,
      label: _currentSliderValue.toString(),
      onChangeEnd: (value) {
        print('onEnd: $value');
      },
      onChangeStart: (value) {
        print('onStart: $value');
      },
      activeColor: Colors.green,
      inactiveColor: Colors.greenAccent,
      thumbColor: Colors.blueGrey,
      onChanged: (double value) {
        setState(() {
          _currentSliderValue = value;
        });
      },
    ));
复制代码

把 100 分成了 5 等分,每次拖动可以变化 20。 我们看到 slider 在水平方向尽量宽,在垂直方向居中。样式方面除了可以直接在 widget 中指定,也可以用SliderThemeData

目录
相关文章
|
1月前
Flutter-底部弹出框(Widget层级)
文章描述了如何在Flutter中使用DraggableScrollableSheet创建一个底部弹出框,同时保持其可手势滑动关闭。作者遇到问题并提出对原控件进行扩展,以支持头部和列表布局的滑动关闭功能。
70 0
|
2月前
Flutter StreamBuilder 实现局部刷新 Widget
Flutter StreamBuilder 实现局部刷新 Widget
22 0
|
3月前
|
Android开发
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析
|
3月前
|
Dart 前端开发 Android开发
【Flutter前端技术开发专栏】Flutter与原生代码的集成与交互
【4月更文挑战第30天】本文探讨了如何在Flutter中集成和交互原生代码,以利用特定平台的API和库。当需要访问如蓝牙、特定支付SDK或复杂动画时,集成原生代码能提升效率和性能。集成方法包括:使用Platform Channel进行通信,借助现有Flutter插件,以及Android和iOS的Embedding。文中通过一个电池信息获取的例子展示了如何使用`MethodChannel`在Dart和原生代码间传递调用。这些技术使开发者能充分利用原生功能,加速开发进程。
72 0
【Flutter前端技术开发专栏】Flutter与原生代码的集成与交互
|
3月前
|
开发框架 前端开发 搜索推荐
【Flutter前端技术开发专栏】Flutter中的自定义Widget与渲染流程
【4月更文挑战第30天】探索Flutter的自定义Widget与渲染流程。自定义Widget是实现复杂UI设计的关键,优点在于个性化设计、功能扩展和代码复用,但也面临性能优化和复杂性管理的挑战。创建步骤包括设计结构、定义Widget类、实现构建逻辑和处理交互。Flutter渲染流程涉及渲染对象树、布局、绘制和合成阶段。实践案例展示如何创建带渐变背景和阴影的自定义按钮。了解这些知识能提升应用体验并应对开发挑战。查阅官方文档以深入学习。
49 0
【Flutter前端技术开发专栏】Flutter中的自定义Widget与渲染流程
|
3月前
|
JavaScript 前端开发 开发者
【Flutter前端技术开发专栏】Flutter中的Widget与状态管理
【4月更文挑战第30天】本文探讨了Flutter的Widget和状态管理。Widget是Flutter构建UI的基础,分为有状态和无状态两种。状态管理确保UI随应用状态变化更新,影响应用性能和可维护性。文章介绍了`setState`、`Provider`、`Riverpod`、`Bloc`和`Redux`等状态管理方法,并通过计数器应用展示了其实现。选择合适的状态管理策略对高效开发至关重要。
37 0
【Flutter前端技术开发专栏】Flutter中的Widget与状态管理
|
3月前
|
编解码 算法 开发者
Flutter的布局系统:深入探索布局Widget与布局原则
【4月更文挑战第26天】Flutter布局系统详解,涵盖布局Widget(Row/Column、Stack、GridView/ListView、CustomSingleChildLayout)和布局原则(弹性布局、约束优先、流式布局、简洁明了)。文章旨在帮助开发者理解并运用Flutter的布局系统,创建适应性强、用户体验佳的界面。通过选择合适的布局Widget和遵循原则,可实现复杂且高效的UI设计。
|
3月前
|
前端开发 开发者 UED
Flutter的自定义Painter:深入探索自定义绘制Widget的技术实现
【4月更文挑战第26天】Flutter的自定义Painter允许开发者根据需求绘制独特UI,通过继承`CustomPaint`类和重写`paint`方法实现。在`paint`中使用`Canvas`绘制图形、路径等。创建自定义Painter类后,将其作为`CustomPaint` Widget的`painter`属性使用。此技术可实现自定义形状、渐变、动画等复杂效果,提升应用视觉体验。随着Flutter的进化,自定义Painter将提供更丰富的功能。
|
3月前
|
开发框架 搜索推荐 Android开发
Flutter的Widget基础:概念、分类与深入探索
【4月更文挑战第26天】Flutter Widget详解:基础、分类与工作原理。Widget是Flutter UI的核心,描述界面外观而非直接渲染。分为基础、布局、可滚动及状态管理四大类。基于响应式编程,状态变化时自动更新UI。了解其概念、分类和原理,能助开发者高效构建精美应用。随着Flutter生态发展,Widget系统潜力无限。
|
11月前
|
Dart 前端开发 开发工具
谷歌移动UI框架Flutter教程之Widget
谷歌移动UI框架Flutter教程之Widget