I used this logic for animation. Is it possible to simplify this logic?
SliverAppBar FlexibleSpaceBar
  void _positionListener() {
    final FlexibleSpaceBarSettings settings = context.dependOnInheritedWidgetOfExactType();
    _fontSize = getFontSize(settings.minExtent.toInt(), settings.maxExtent.toInt(), settings.currentExtent.toInt());
setState(() {});
  }
need to simplify below logic
 double getFontSize(int minExtent, int maxExtent, int currentExtent){
    double onePaddingExtent = (maxExtent - minExtent) / 31;
    if (currentExtent >= minExtent && currentExtent <= minExtent + (1 * onePaddingExtent))
      return 3.0;
    else if (currentExtent > minExtent + (1 * onePaddingExtent) && currentExtent <= minExtent + (2 * onePaddingExtent))
      return 2.9;
    else if (currentExtent > minExtent + (2 * onePaddingExtent) && currentExtent <= minExtent + (3 * onePaddingExtent))
      return 2.8;
    else if (currentExtent > minExtent + (3 * onePaddingExtent) && currentExtent <= minExtent + (4 * onePaddingExtent))
      return 2.7;
    else if (currentExtent > minExtent + (4 * onePaddingExtent) && currentExtent <= minExtent + (5 * onePaddingExtent))
      return 2.6;
    else if (currentExtent > minExtent + (5 * onePaddingExtent) && currentExtent <= minExtent + (6 * onePaddingExtent))
      return 2.5;
    else if (currentExtent > minExtent + (6 * onePaddingExtent) && currentExtent <= minExtent + (7 * onePaddingExtent))
      return 2.4;
    else if (currentExtent > minExtent + (7 * onePaddingExtent) && currentExtent <= minExtent + (8 * onePaddingExtent))
      return 2.3;
    else if (currentExtent > minExtent + (8 * onePaddingExtent) && currentExtent <= minExtent + (9 * onePaddingExtent))
      return 2.2;
    else if (currentExtent > minExtent + (9 * onePaddingExtent) && currentExtent <= minExtent + (10 * onePaddingExtent))
      return 2.1;
    else if (currentExtent > minExtent + (10 * onePaddingExtent) && currentExtent <= minExtent + (11 * onePaddingExtent))
      return 2.0;
    else if (currentExtent > minExtent + (11 * onePaddingExtent) && currentExtent <= minExtent + (12 * onePaddingExtent))
      return 1.9;
    else if (currentExtent > minExtent + (12 * onePaddingExtent) && currentExtent <= minExtent + (13 * onePaddingExtent))
      return 1.8;
    else if (currentExtent > minExtent + (13 * onePaddingExtent) && currentExtent <= minExtent + (14 * onePaddingExtent))
      return 1.7;
    else if (currentExtent > minExtent + (14 * onePaddingExtent) && currentExtent <= minExtent + (15 * onePaddingExtent))
      return 1.6;
    else if (currentExtent > minExtent + (15 * onePaddingExtent) && currentExtent <= minExtent + (16 * onePaddingExtent))
      return 1.5;
    else if (currentExtent > minExtent + (16 * onePaddingExtent) && currentExtent <= minExtent + (17 * onePaddingExtent))
      return 1.4;
    else if (currentExtent > minExtent + (17 * onePaddingExtent) && currentExtent <= minExtent + (18 * onePaddingExtent))
      return 1.3;
    else if (currentExtent > minExtent + (18 * onePaddingExtent) && currentExtent <= minExtent + (19 * onePaddingExtent))
      return 1.2;
    else if (currentExtent > minExtent + (19 * onePaddingExtent) && currentExtent <= minExtent + (20 * onePaddingExtent))
      return 1.0;
    else if (currentExtent > minExtent + (20 * onePaddingExtent) && currentExtent <= minExtent + (21 * onePaddingExtent))
      return 1;
    else if (currentExtent > minExtent + (21 * onePaddingExtent) && currentExtent <= minExtent + (22 * onePaddingExtent))
      return 0.9;
    else if (currentExtent > minExtent + (22 * onePaddingExtent) && currentExtent <= minExtent + (23 * onePaddingExtent))
      return 0.8;
    else if (currentExtent > minExtent + (23 * onePaddingExtent) && currentExtent <= minExtent + (24 * onePaddingExtent))
      return 0.7;
    else if (currentExtent > minExtent + (24 * onePaddingExtent) && currentExtent <= minExtent + (25 * onePaddingExtent))
      return 0.6;
    else if (currentExtent > minExtent + (25 * onePaddingExtent) && currentExtent <= minExtent + (26 * onePaddingExtent))
      return 0.5;
    else if (currentExtent > minExtent + (26 * onePaddingExtent) && currentExtent <= minExtent + (27 * onePaddingExtent))
      return 0.4;
    else if (currentExtent > minExtent + (27 * onePaddingExtent) && currentExtent <= minExtent + (28 * onePaddingExtent))
      return 0.3;
    else if (currentExtent > minExtent + (28 * onePaddingExtent) && currentExtent <= minExtent + (29 * onePaddingExtent))
      return 0.2;
    else if (currentExtent > minExtent + (29 * onePaddingExtent) && currentExtent <= minExtent + (30 * onePaddingExtent))
      return 0.1;
    else if (currentExtent > minExtent + (30 * onePaddingExtent) && currentExtent <= minExtent + (31 * onePaddingExtent))
      return 0;
    else
      return 0;
  }
I tried this way, but not working
  double getFontSize(int minExtent, int maxExtent, int currentExtent) {
    double onePaddingExtent = (maxExtent - minExtent) / 31;
    
    var baseValue = (currentExtent + minExtent) / onePaddingExtent ;
    var upperBaseValue = baseValue.round();
    var lowerBaseValue = baseValue.floor();
    var result = 30 - Math.min(upperBaseValue, lowerBaseValue);
    return Math.max(result, 0);
  }
 
     
    