【问题标题】:Write custom text on image canvas with fabric.js and HTML5使用 fabric.js 和 HTML5 在图像画布上编写自定义文本
【发布时间】:2016-04-16 19:56:37
【问题描述】:

我正在使用 HTML5 和 fabric.js 上传多张图片。我想在这个图像画布上添加自定义文本。现在我正在将多张图像一张一张地上传到画布中。上传图片后,我想在画布上添加自定义文本。

var canvas = new fabric.Canvas('canvas');
document.getElementById('file').addEventListener("change",function (e) {
  var file = e.target.files[0];
  var reader = new FileReader();
  console.log("reader   " + reader);
  reader.onload = function (f) {
    var data = f.target.result;
    fabric.Image.fromURL(data, function (img) {
      var oImg = img.set({left: 70, top: 100, width: 250, height: 200, angle: 0}).scale(0.9);
      canvas.add(oImg).renderAll();
      var a = canvas.setActiveObject(oImg);
      var dataURL = canvas.toDataURL({format: 'png', quality: 0.8});
    });
  };
  reader.readAsDataURL(file);
});
document.querySelector('#txt').onclick = function (e) {
  e.preventDefault();
  canvas.deactivateAll().renderAll();
  document.querySelector('#preview').src = canvas.toDataURL();
};
canvas{
  border: 1px solid black;
}
<script src="https://rawgit.com/kangax/fabric.js/master/dist/fabric.min.js"></script>
<input type="file" id="file">
<canvas id="canvas" width="750" height="550"></canvas>
<a href='' id='txt' target="_blank">Click Me!!</a><br />
<img id="preview" />

https://jsfiddle.net/varunPes/vb1weL93/

我看过一些链接:

更新

我需要用户可以选择文本的colorfont-family

单击Click Me!! 按钮后,custom text 和图像应合并为一张图像。

【问题讨论】:

    标签: javascript css html canvas fabricjs


    【解决方案1】:

    你可以像这样使用IText

    canvas.add(new fabric.IText('Tap and Type', {
      fontFamily: 'arial black',
      left: 100,
      top: 100,
    }));
    

    以及完整的代码:

    var canvas = new fabric.Canvas('canvas');
    
    document.getElementById('file').addEventListener("change", function (e) {
      var file = e.target.files[0];
      var reader = new FileReader();
      console.log("reader   " + reader);
      reader.onload = function (f) {
        var data = f.target.result;
        fabric.Image.fromURL(data, function (img) {
          var oImg = img.set({left: 70, top: 100, width: 250, height: 200, angle: 0}).scale(0.9);
          canvas.add(oImg).renderAll();
          canvas.setActiveObject(oImg);  
        });
      };
      reader.readAsDataURL(file);
    });
    
    $('#fill').change(function(){
      var obj = canvas.getActiveObject();
    
      if(obj){
        // old api
        // obj.setFill($(this).val());
        obj.set("fill", this.value);
      }
      canvas.renderAll();
    });
    
    $('#font').change(function(){
      var obj = canvas.getActiveObject();
      
      if(obj){
        // old api
        // obj.setFontFamily($(this).val());
        obj.set("fontFamily", this.value);
      }
      
      canvas.renderAll();
    });
    
    function addText() {
      var oText = new fabric.IText('Tap and Type', { 
        left: 100, 
        top: 100 ,
      });
    
      canvas.add(oText);
      oText.bringToFront();
      canvas.setActiveObject(oText);
      $('#fill, #font').trigger('change');
    }
    
    document.querySelector('#txt').onclick = function (e) {
      e.preventDefault();
      canvas.deactivateAll().renderAll();
      document.querySelector('#preview').src = canvas.toDataURL();
    };
    canvas{
      border: 1px solid black;
    }
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/2.3.6/fabric.min.js"></script>
    
    <input type="file" id="file">
    <input type="color" value="blue" id="fill" />
    <select id="font">
      <option>arial</option>
      <option>tahoma</option>
      <option>times new roman</option>
    </select>
    <button onclick="addText()">Add Custom Text</button>
    <br />
    <canvas id="canvas" width="750" height="550"></canvas>
    <a href='' id='txt' target="_blank">Click Me!!</a>
    <br />
    <img id="preview" />

    更新: 要使文本始终位于最前面,您需要使用 .bringToFront() 函数。
    (感谢@Amit Sharma Fabric.js - problem with drawing multiple images zindex

    http://jsbin.com/qicesa/edit?html,css,js,output

    【讨论】:

    • 我只想自定义一次文本。在您的代码中有多个图像的多个自定义标签。我想要文字颜色,字体样式。
    • one time custom text 你的意思是用户第一次上传图片吗? i want text color, font style你的意思是要控制颜色和字体?如果是这样,请参阅 sn-p:fontFamily: 'arial black',。另外,阅读有关它的文档(点击IText
    • 你还有什么想法吗?
    • 因为我只想要用户选择的文本颜色和字体样式。
    • 你的答案是正确的。但是当我上传下一张图片时,自定义文本将隐藏。自定义文本应高于所有图片
    猜你喜欢
    • 2012-11-20
    • 2016-03-31
    • 2014-01-29
    • 2011-12-10
    • 2011-04-11
    • 2015-03-13
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多