import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // This widget is the root of your application. @override Widget build(BuildContext context) { return MaterialApp( title: 'Flutter Slider 100', theme: ThemeData( // This is the theme of your application. // // TRY THIS: Try running your application with "flutter run". You'll see // the application has a purple toolbar. Then, without quitting the app, // try changing the seedColor in the colorScheme below to Colors.green // and then invoke "hot reload" (save your changes or press the "hot // reload" button in a Flutter-supported IDE, or press "r" if you used // the command line to start the app). // // Notice that the counter didn't reset back to zero; the application // state is not lost during the reload. To reset the state, use hot // restart instead. // // This works for code too, not just values: Most code changes can be // tested with just a hot reload. colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple), ), home: const MyHomePage(title: 'Flutter Slider 100'), ); } } class MyHomePage extends StatefulWidget { const MyHomePage({super.key, required this.title}); final String title; @override State createState() => _MyHomePageState(); } class _MyHomePageState extends State { double _currentSliderValue = 50; void onSliderChanged(double value) { setState(() { _currentSliderValue = value; }); } @override Widget build(BuildContext context) { var size = MediaQuery.of(context).size; const double itemHeight = 55; final double itemWidth = size.width / 2; return Scaffold( appBar: AppBar( backgroundColor: Theme.of(context).colorScheme.inversePrimary, title: Text(widget.title), ), body: GridView.count( childAspectRatio: (itemWidth / itemHeight), crossAxisCount: 4, // Generate 100 widgets that display their index in the List. children: List.generate(100, (index) { return Flex( direction: Axis.horizontal, children: [ Expanded( flex: 1, child: Slider(min: 0, max: 100, value: _currentSliderValue, onChanged: onSliderChanged), ), SizedBox( width: 26, child: Text(_currentSliderValue.toStringAsFixed(0)), ), ], ); }), ), ); } }