Fabric js: Increase font size instead of just scaling when resize with mouse

前端 未结 2 1383
慢半拍i
慢半拍i 2021-02-15 23:46

I am working on fabric js application & I need to increase/decrease the font size when we resize the font with mouse
my tried code

相关标签:
2条回答
  • 2021-02-16 00:28

    While perhaps not the best approach (I'm new to Fabric), this is working for me with version 4.3.0:

    canvas.on('text:changed', function (e) {
      console.log('Text:', e.target.text, e.target.text.length)
      let objectSelection = canvas.getActiveObject()
      switch (e.target.text.length) {
        case 10:
          console.log(`Text is ${e.target.text.length} characters in length.`)
          objectSelection.set('fontSize', 100)
          break
        case 15:
          console.log(`Text is ${e.target.text.length} characters in length.`)
          objectSelection.set('fontSize', 85)
          break
        case 25:
          console.log(`Text is ${e.target.text.length} characters in length.`)
          objectSelection.set('fontSize', 60)
          break
      }
    })
    canvas.on('text:editing:exited', function (e) {
      console.log('Text edited!')
    })
    

    I took inspiration from another answer, which does the job.

    0 讨论(0)
  • 2021-02-16 00:49

    The idea is using the canvas.on("object:modified") event to reset the scaling to 1 and increase fontSize to fit the new size.

    fabric.Object.lockUniScaling is a suggested addition.

    var canvas = new fabric.Canvas('canvas');
    $(document).ready(function() {
      $('#text-font-size').keyup(function() {
        var val = $(this).val();
        if (isNaN(val)) {
          alert('please enter number');
          $(this).val('');
        }
        var activeObject = canvas.getActiveObject();
        activeObject.fontSize = val;
        canvas.renderAll();
      });
      $('#add-text-btn').click(function() {
        if ($('#text-font-size').val()) {
          var txtfontsize = $('#text-font-size').val();
        } else {
          var txtfontsize = 40;
        }
        var message = $('#add-text-value').val();
        //var txtfontfamily = $('#font-family').val();
        var new_text = new fabric.IText(message, {
          left: 100,
          top: 100,
          fontSize: txtfontsize,
          lockUniScaling: true,
          //fontFamily: txtfontfamily,
          fill: '#000'
        });
        canvas.add(new_text);
        canvas.setActiveObject(new_text);
      });
    
      canvas.on('object:selected', function(options) {
        if (options.target) {
          $("textarea#add-text-value").val(options.target.text);
          $("#text-font-size").val(options.target.fontSize);
        }
      });
    
      canvas.on('object:scaling', function(event) {
        if (event.target) {
          $("textarea#add-text-value").val(event.target.text);
          $("#text-font-size").val((event.target.fontSize * event.target.scaleX).toFixed(0));
        }
      });
    
      canvas.on('object:modified', function(event) {
        if (event.target) {
          event.target.fontSize *= event.target.scaleX;
          event.target.fontSize = event.target.fontSize.toFixed(0);
          event.target.scaleX = 1;
          event.target.scaleY = 1;
          event.target._clearCache();
          $("textarea#add-text-value").val(event.target.text);
          $("#text-font-size").val(event.target.fontSize);
        }
      });
    
    });
    <script src="//cdnjs.cloudflare.com/ajax/libs/fabric.js/1.5.0/fabric.min.js"></script>
    <script src="//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <button id="add-text-btn">Add text</button>
    <br>
    <br>
    <textarea rows="7" id="add-text-value">Your Text Here</textarea>
    <br>
    <input id="text-font-size" placeholder="fontsize" type="number" class="form-control">
    <canvas id='canvas' width="500" height="400" style="border:#000 1px solid;"></canvas>

    0 讨论(0)
提交回复
热议问题