spflutter_number_picker 1.5.0 copy "spflutter_number_picker: ^1.5.0" to clipboard
spflutter_number_picker: ^1.5.0 copied to clipboard

Flutter Number Picker => Forked & Customized number_selection .. Optional with dialog to change value by keyboard.

example/lib/main.dart

import 'package:flutter/material.dart';
import 'package:spflutter_number_picker/spflutter_number_picker.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatefulWidget {
  const MyApp({Key? key}) : super(key: key);

  @override
  State<MyApp> createState() => _MyAppState();
}

// class _MyAppState extends State<MyApp> {
//   @override
//   Widget build(BuildContext context) {
//     return Container();
//   }
// }
//
// void main() {
//   runApp(MyApp());
// }

class _MyAppState extends State<MyApp> {
  // MyApp({Key? key}) : super(key: key);
  TextEditingController textEditingController = TextEditingController();

  double? _resetValue;

  double? XX;

  late NumberPicker np;

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      home: Scaffold(
        backgroundColor: Colors.deepPurple[400],
        body: SafeArea(
          child: SingleChildScrollView(
            child: Column(
              mainAxisAlignment: MainAxisAlignment.spaceAround,
              children: <Widget>[
                OutlinedButton(onPressed: (){
                  _resetValue = 7;
                  setState((){
                    // textEditingController.text = mVal.toStringAsFixed(0);
                    // bb.valueController!.text = mVal.toStringAsFixed(0);
                    // bb.initialValue = mVal;
                  });
                }, child: Text("ADD")),
                NumberPicker(
                  theme: NumberSelectionTheme(
                      draggableCircleColor: Colors.blue,
                      iconsColor: Colors.white,
                      numberColor: Colors.white,
                      backgroundColor: Colors.deepPurpleAccent,
                      outOfConstraintsColor: Colors.deepOrange),
                  interval: 0.1,
                  initialValue: 0,
                  resetValue: _resetValue,
                  // valueController: textEditingController,
                  minValue: 15,
                  maxValue: 50.2,
                  direction: Axis.vertical,
                  withSpring: true,
                  onChanged: (double value) {
                    XX = 23;
                    setState(() {

                    });
                    print("value: $value");
                  },
                  enableOnOutOfConstraintsAnimation: true,
                  onOutOfConstraints: () =>
                      print("This value is too high or too low"),
                ),
                Center(
                  child: Padding(
                    padding: const EdgeInsets.all(18.0),
                    child: SizedBox(
                      height: 50,
                      width: 400,
                      child: np = NumberPicker(
                        theme: NumberSelectionTheme(
                            draggableCircleColor: Colors.blue,
                            iconsColor: Colors.white,
                            iconsDisableColor: Colors.grey,
                            numberColor: Colors.white,
                            progressColor: Colors.deepOrangeAccent,
                            backgroundColor: Colors.deepPurpleAccent,
                            outOfConstraintsColor: Colors.deepOrange),
                        interval: 1,
                        minValue: 5,
                        maxValue: 30,
                        resetValue: XX,
                        initialValue: 10,
                        iconRemove: Icons.remove,
                        iconMin: Icons.delete,
                        iconMax: Icons.fullscreen_exit,
                        // callOnSet: (val0) async {
                        //   return NumberPicker(
                        //     initialValue: 3,
                        //     minValue: 1,
                        //     maxValue: 20,
                        //     interval: 1,
                        //   );
                        // },
                        callBack: (val) async {
                          if (val < 50) {
                            await Future.delayed(const Duration(seconds: 2));
                            return val;
                          } else {
                            return 5;
                          }
                        },
                        direction: Axis.horizontal,
                        withSpring: true,
                        onChanged: (double value) {
                          print(">>value: $value");
                        },
                        dialogShowOnlyLongTouch: false,
                        enableOnOutOfConstraintsAnimation: true,
                        onOutOfConstraints: () =>
                            print("This value is too high or too low"),
                      ),
                    ),
                  ),
                ),
                Padding(
                  padding: const EdgeInsets.all(18.0),
                  child: SizedBox(
                    height: 50,
                    width: 400,
                    child: NumberPicker(
                      theme: NumberSelectionTheme(
                          draggableCircleColor: Colors.blue,
                          iconsColor: Colors.white,
                          iconsDisableColor: Colors.grey,
                          numberColor: Colors.white,
                          progressColor: Colors.deepOrangeAccent,
                          backgroundColor: Colors.deepPurpleAccent,
                          outOfConstraintsColor: Colors.deepOrange),
                      interval: 0.3,
                      minValue: 5,
                      maxValue: 30,
                      initialValue: 0,
                      iconRemove: Icons.remove,
                      iconMin: Icons.delete,
                      iconMax: Icons.fullscreen_exit,
                      callOnSet: (val0) async {
                        NumberPicker ret = NumberPicker();
                        await Future.delayed(const Duration(seconds: 2)).then(
                          (value) => {
                            ret = NumberPicker(
                              initialValue: 3,
                              minValue: 1,
                              maxValue: 20,
                              interval: 1,
                            ),
                          },
                        );
                        return ret;
                        // return NumberPicker();
                      },
                      callBack: (val) async {
                        if (val < 50) {
                          await Future.delayed(const Duration(seconds: 2));
                          return val;
                        } else {
                          return 5;
                        }
                      },
                      direction: Axis.horizontal,
                      withSpring: true,
                      onChanged: (double value) {
                        print("value: $value");
                      },
                      dialogShowOnlyLongTouch: false,
                      enableOnOutOfConstraintsAnimation: true,
                      onOutOfConstraints: () =>
                          print("This value is too high or too low"),
                    ),
                  ),
                )
              ],
            ),
          ),
        ),
      ),
    );
  }
}
8
likes
140
pub points
67%
popularity

Publisher

unverified uploader

Flutter Number Picker => Forked & Customized number_selection .. Optional with dialog to change value by keyboard.

Repository (GitHub)
View/report issues

Documentation

API reference

License

Apache-2.0 (license)

Dependencies

flutter

More

Packages that depend on spflutter_number_picker