How to dynamically resize text in Flutter?

后端 未结 7 1678
梦如初夏
梦如初夏 2021-01-31 06:53

I retrieve a piece of text from an API. I want to allot a set amount of space to it (say a max Container with width: 300.0 and height: 100.0). Sometimes, the piece of text fits

7条回答
  •  太阳男子
    2021-01-31 07:31

    Just generate the font size according to the text length and the maximum rendering area. 300.0 * 100.0 in your case, without forgetting the areas lost during the rendering of the text.

    like this :

    class MyWidget extends StatefulWidget {
      @override
      _StateMyWidget createState() => _StateMyWidget();
    }
    
    class _StateMyWidget extends State {
      static const _QUOTES = [
        {"quote": "mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm", "author": "test"},
        {"quote": "Talk is cheap. Show me the code.", "author": "Linus Torvalds"},
        {"quote": "First, solve the problem. Then, write the code.", "author": "John Johnson"},
        {"quote": "To iterate is human, to recurse divine.", "author": "L. Peter Deutsch"},
        {"quote": "The best thing about a boolean is even if you are wrong, you are only off by a bit.", "author": "Anonymous"},
        {"quote": "Software is like sex: It’s better when it’s free.", "author": "Linus Torvalds"},
        {"quote": "The first 90% of the code accounts for the first 90% of the development time.  The remaining 10% of the code accounts for the other 90% of the development time.", "author": "Tom Cargill"},
        {"quote": "I think that it’s extraordinarily important that we in computer science keep fun in computing. When it started out it was an awful lot of fun. Of course the paying customers got shafted every now and then and after a while we began to take their complaints seriously. We began to feel as if we really were responsible for the successful error-free perfect use of these machines. I don’t think we are. I think we’re responsible for stretching them setting them off in new directions and keeping fun in the house. I hope the field of computer science never loses its sense of fun. Above all I hope we don’t become missionaries. Don’t feel as if you’re Bible sales-men. The world has too many of those already. What you know about computing other people will learn. Don’t feel as if the key to successful computing is only in your hands. What’s in your hands I think and hope is intelligence: the ability to see the machine as more than when you were first led up to it that you can make it more.", "author": "Alan J. Perlis"},
        {"quote":"Always code as if the guy who ends up maintaining your code will be a violent psychopath who knows where you live","author": "John Woods"},
        {"quote":"You've baked a really lovely cake, but then you've used dog shit for frosting.","author": "Steve Jobs"},
        {"quote": "Most software today is very much like an Egyptian pyramid with millions of bricks piled on top of each other, with no structural integrity, but just done by brute force and thousands of slaves.","author": "Alan Kay" },
        {"quote": "Software suppliers are trying to make their software packages more ‘user-friendly’…  Their best approach so far has been to take all the old brochures and stamp the words ‘user-friendly’ on the cover.","author": "Bill Gates"},
      ];
    
      static const AREA_LOST_PERCENT = 5;
    
      final rand = math.Random();
    
      @override
      initState() {
        super.initState();
        Timer.periodic(Duration(seconds: 3), (timeVal) {
          setState(() {});
        });
      }
    
      @override
      Widget build(BuildContext context) {
        final Map mapQuote = _QUOTES[rand.nextInt(_QUOTES.length)];
    
        final authorW =
            Text(mapQuote["author"], style: TextStyle(fontStyle: FontStyle.italic));
    
        final quoteW = Text(
          mapQuote["quote"],
          textAlign: TextAlign.center,
          style: TextStyle(
            fontSize: autoSize(
              quoteLength: mapQuote["quote"].length,
              parentArea: (350 - 10 * 2 - 16 * 2) * (450 - 10 * 2),
            ),
          ),
        );
    
        final containerW0 = Container(
            height: 450.0,
            padding: EdgeInsets.all(10.0),
            color: Colors.grey,
            child: Center(child: quoteW));
    
        final containerW1 = Container(
            height: 500.0,
            width: 350,
            padding: EdgeInsets.all(16.0),
            color: Colors.purple,
            child: Column(children: [authorW, containerW0]));
    
        return containerW1;
      }
    
      double autoSize({@required int quoteLength, @required int parentArea}) {
        assert(quoteLength != null, "`quoteLength` may not be null");
        assert(parentArea != null, "`parentArea` may not be null");
        final areaOfLetter = parentArea / quoteLength;
        final pixelOfLetter = math.sqrt(areaOfLetter);
        final pixelOfLetterP = pixelOfLetter - (pixelOfLetter * AREA_LOST_PERCENT) / 100;
        return pixelOfLetterP;
      }
    }
    

    the escape characters must be taken into account during the allocation of the percentage of lost areas. it is best to remove them if the variation is excessive.

    Online view -> dartpad.dev

提交回复
热议问题