剪辑到织物js中的图像形状

时间:2016-02-23 12:50:24

标签: javascript html5-canvas fabricjs clip

我试图像类似网站一样实施。

http://printio.ru/full_print_tees/new

即使我尝试了以下帖子的答案,但它不起作用。任何人都有解决方案或小提琴。 Fabric.js Clip Canvas (or object group) To Polygon

我创建了以下示例,但它的工作方式并不相似。请让我知道什么是问题

<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="css/reset.css" /> <!-- reset css -->
<script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>
<script type="text/javascript" src="fabric.min.js"></script>

<style>
    body{ background-color: ivory; }
    canvas{border: 1px solid red; }
</style>

<script>
    $(function(){

        var canvas = new fabric.Canvas('canvas');
        var group = [];

        fabric.loadSVGFromURL("http://fabricjs.com/assets/2.svg",function(objects,options) {

            var loadedObjects = new fabric.Group(group);

            loadedObjects.set({
                    left: 100,
                    top: 100

            });

            canvas.add(loadedObjects);
            shape = canvas.item(0);
            canvas.remove(shape);
            canvas.clipTo = function(ctx) {
              shape.render(ctx);
            };
            canvas.renderAll();

        },function(item, object) {
                object.set('id',item.getAttribute('id'));
                group.push(object);
        });



          }); // end $(function(){});
</script>

</head>

<body>
    <canvas id="canvas" width="300" height="300"></canvas> 
</body>
</html>

1 个答案:

答案 0 :(得分:2)

你好,我在你的例子中看到这样的东西吗?

  1. 加载一张图片(T恤)
  2. 添加i-text对象
  3. 在T恤上操纵文字对象(编辑,上/下/左/右)
  4. 小片段:

    fabric.Image.fromURL(myImg, function(myImg) {
        var img1 = myImg.scale(scaleFactor).set({ left: 0, top: 0 });
    
        var text = new fabric.Text('the_text_sample\nand more', {
                    fontFamily: 'Arial',
                    fontSize:20,
                });
    
        text.set("top",myImg.height*scaleFactor-myImg.height*scaleFactor+150);
        text.set("left",myImg.width*scaleFactor/2-text.width/2);
    
        var group = new fabric.Group([ img1,text ], { left: 10, top: 10 });
        canvas.add(group);
    console.log(canvas._objects[0]._objects[1].text);
    });
    

    直播示例:https://jsfiddle.net/tornado1979/zrazuhcq/

    enter image description here

    希望有所帮助,祝你好运。