flutter-一个可以输入的数字增减器

效果

在这里插入图片描述
参考文章

代码

在参考文章上边,主要是改了一下样式,逻辑也比较清楚,对左右两边添加增减方法。

我在此基础上加了_numcontroller 输入框的监听。

加了数字输入框的控制

keyboardType: TextInputType.number, //设置键盘为数字
inputFormatters: [
FilteringTextInputFormatter.digitsOnly, //设置只允许输入整数
],

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

class NumChangeWidget extends StatefulWidget {
   
  final double height;
  int num;
  final ValueChanged<int> onValueChanged;

  final bool disabled;

  NumChangeWidget(
      {
   Key? key,
      this.height = 36.0,
      this.num = 0,
      this.disabled = false,
      required this.onValueChanged})
      : super(key: key);

  
  _NumChangeWidgetState createState() {
   
    return _NumChangeWidgetState();
  }
}

class _NumChangeWidgetState extends State<NumChangeWidget> {
   
  TextEditingController _numcontroller = TextEditingController();

  
  void initState() {
   
    super.initState();
    _numcontroller.addListener(_onNumChange);
  }

  void _onNumChange() {
   
    String text = _numcontroller.text;
    if (text.isNotEmpty) {
   
      String result = text.replaceAll(RegExp(r'^[0]+'), '');// 去掉首位0的正则替换
      if (result != '') {
   
        widget.num = int.parse(result);
        widget.onValueChanged(widget.num);
      }
      if (result != text) {
   
        _numcontroller.selection =
            TextSelection.fromPosition(TextPosition(offset: result.length));
      }
    }
  }

  
  Widget build(BuildContext context) {
   
    _numcontroller.text = widget.num.toString();

    return Container(
      height: widget.height,
      decoration: BoxDecoration(
          borderRadius: BorderRadius.all(Radius.circular(2.0)),
          color: Color(0x1FFFFFFF)),
      child: Row(
        mainAxisSize: MainAxisSize.min,
        children: <Widget>[
          GestureDetector(
            onTap: _minusNum,
            child: Container(
              width: 32.0,
              alignment: Alignment.center,
              child: Icon(Icons.horizontal_rule_outlined,
                  color: widget.num == 0 || widget.disabled
                      ? Color.fromRGBO(255, 255, 255, .4)
                      : Colors.white),
            ),
          ),
          Container(
            width: 0.5,
            color: Colors.black54,
          ),
          Container(
            width: 62.0,
            alignment: Alignment.center,
            child: TextField(
                controller: _numcontroller, //TextEditingController,用于获取文本值
                keyboardType: TextInputType.number, //设置键盘为数字
                textAlign: TextAlign.center, // 内容左右居中
                maxLines: 1,
                decoration: const InputDecoration(
                  border: InputBorder.none,
                  contentPadding: EdgeInsets.only(bottom: 10),
                ),
                inputFormatters: [
                  FilteringTextInputFormatter.digitsOnly, //设置只允许输入整数
                ],
                style: TextStyle(fontSize: 16, color: Colors.white),
                readOnly: widget.disabled),
          ),
          Container(
            width: 0.5,
            color: Colors.black54,
          ),
          GestureDetector(
            onTap: _addNum,
            child: Container(
              width: 32.0,
              alignment: Alignment.center,
              child: Icon(
                Icons.add_outlined,
                color: widget.disabled
                    ? const Color.fromRGBO(255, 255, 255, .4)
                    : Colors.white,
              ), // 设计图
            ),
          ),
        ],
      ),
    );
  }

  void _minusNum() {
   
    if (widget.num == 0 || widget.disabled) {
   
      return;
    }

    setState(() {
   
      widget.num -= 1;

      if (widget.onValueChanged != null) {
   
        widget.onValueChanged(widget.num);
      }
    });
  }

  void _addNum() {
   
    if (widget.disabled) {
   
      return;
    }
    setState(() {
   
      widget.num += 1;

      if (widget.onValueChanged != null) {
   
        widget.onValueChanged(widget.num);
      }
    });
  }
}

最近更新

  1. TCP协议是安全的吗?

    2023-12-08 11:52:03       17 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-08 11:52:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-08 11:52:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-08 11:52:03       18 阅读

热门阅读

  1. Git的相关命令

    2023-12-08 11:52:03       37 阅读
  2. Docker创建mqtt容器mosquitto

    2023-12-08 11:52:03       32 阅读
  3. CNN,DNN,RNN,GAN,RL+图像处理常规算法(未完待续)

    2023-12-08 11:52:03       36 阅读
  4. miot-plugin-sdk. npm install安装失败

    2023-12-08 11:52:03       50 阅读