【交互 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

目录
相关文章
|
2天前
|
容器
Flutter Widget 解析
Flutter Widget 解析
|
2天前
|
存储 容器
Flutter 有状态Widget 和 无状态Widget
Flutter 有状态Widget 和 无状态Widget
|
1月前
深入理解Flutter鸿蒙next版本 中的Widget继承:使用extends获取数据与父类约束
本文详细介绍了Flutter中如何通过继承其他Widget来创建自定义组件。首先解释了Widget继承的基本概念,包括StatelessWidget和StatefulWidget的区别。接着通过具体示例展示了如何继承StatelessWidget和StatefulWidget,并在子类中访问父类的build方法和状态。最后,结合多个自定义Widget展示了如何在实际应用中灵活使用继承和组合来构建复杂的UI。
76 8
|
1月前
|
容器
flutter&鸿蒙next 使用 InheritedWidget 实现跨 Widget 传递状态
在 Flutter 中,状态管理至关重要。本文详细介绍了如何使用 InheritedWidget 实现跨 Widget 的状态传递。InheritedWidget 允许数据在 Widget 树中向下传递,适用于多层嵌套的场景。通过一个简单的计数器示例,展示了如何创建和使用 InheritedWidget,包括其基础概念、工作原理及代码实现。虽然 InheritedWidget 较底层,但它是许多高级状态管理解决方案的基础。
103 2
|
1月前
|
Dart UED 开发者
Flutter&鸿蒙next中的按钮封装:自定义样式与交互
在Flutter应用开发中,按钮是用户界面的重要组成部分。Flutter提供了多种内置按钮组件,但有时这些样式无法满足特定设计需求。因此,封装一个自定义按钮组件变得尤为重要。自定义按钮组件可以确保应用中所有按钮的一致性、可维护性和可扩展性,同时提供更高的灵活性,支持自定义颜色、形状和点击事件。本文介绍了如何创建一个名为CustomButton的自定义按钮组件,并详细说明了其样式、形状、颜色和点击事件的处理方法。
86 1
|
2月前
|
容器
flutter:第一个flutter&Widget的使用 (二)
本文介绍了Flutter框架下的基本组件及其用法,包括简单的 Stateless Widget 如文本和按钮,以及更复杂的 StatefulWidget 示例。详细解释了如何使用 `context` 获取祖先小部件的信息,并展示了 `MaterialApp` 的属性及用途。此外,还探讨了 `StatefulWidget` 与 `StatelessWidget` 的区别,以及 `AppBar` 的常见属性配置方法。适合Flutter初学者参考学习。
|
1月前
|
Dart JavaScript 前端开发
Flutter 的 Widget 概述与常用 Widgets 与鸿蒙 Next 的对比
Flutter 是 Google 开发的开源 UI 框架,用于快速构建高性能的移动、Web 和桌面应用。Flutter 通过 Widget 构建 UI,每个 UI 元素都是 Widget,包括文本、按钮、图片等。Widget 不仅描述外观,还描述行为,是不可变的。常见的 Widget 包括结构型(Container、Column、Row)、呈现型(Text、Image)、交互型(ElevatedButton)和状态管理型(StatefulWidget)。Flutter 与鸿蒙 Next 在组件化架构、开发语言、布局系统、性能和跨平台支持方面各有优势
75 0
|
5月前
Flutter-底部弹出框(Widget层级)
文章描述了如何在Flutter中使用DraggableScrollableSheet创建一个底部弹出框,同时保持其可手势滑动关闭。作者遇到问题并提出对原控件进行扩展,以支持头部和列表布局的滑动关闭功能。
199 0
|
6月前
Flutter StreamBuilder 实现局部刷新 Widget
Flutter StreamBuilder 实现局部刷新 Widget
52 0
|
7月前
|
Android开发
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析