Kinetics.js可以根据用户操作自动重新绘制画布

Kinetics.js to automatically redraw canvas on user actions

本文关键字:新绘制 绘制 js 操作 用户 Kinetics      更新时间:2023-09-26

我使用Kinetics.js操作我的画布和jQuery来处理用户操作。所以,当我一个接一个地使用它们时,所有的功能都能很好地工作。但是,当我尝试将两个函数组合为一个事件时,如$('.selections img')。单击……(见下文)该函数只设置背景并忽略文本。然而,文本层已经创建,但由于某种原因,我看不到它。我试图更改函数调用的顺序,但没有成功。

当我检查控制台时,并没有错误或警报,当我使用console.log检查我的变量时,所有变量都会打印到控制台。

这里可能有什么问题?

PS。这里的目标是保存img和t变量,并使用它们:首先在画布上绘制背景,第二次打印文本在现有背景上的单独层

 img = '';
 t = '';
 function setCanvas (){
        hiddenCanvas = new Kinetic.Stage({
        container : 'hiddenCanvasHolder',
        width : 2340,
        height : 1660
    });
}
function setBackground (image){
        background = new Kinetic.Layer();
    var imageObj = new Image();
     imageObj.onload = function (){
     var backImg = new Kinetic.Image({
         x: 0,
         y: 0,
         image: imageObj,
         width: 2340,
         height: 1660
         });
   background.add(backImg);
   hiddenCanvas.add(background);         
     };
     imageObj.src = image;
}
function setText(txt){
    textLayer = new Kinetic.Layer ();
    var text = new Kinetic.Text({
        x: 200,
        y: 500,
        text: txt,
        fontSize: 70,
        fontFamily: 'Calibri',
        fill: '#555',
        align: 'center'
        });
    textLayer.add(text);
    hiddenCanvas.add(textLayer);
}
$(document).ready(function(e) {
setCanvas();
setBackground(img);
setText(t);
/* Handles image selection and background setting for canvas */
$('.selections img').click(function(e) {
    img = $(this).attr('alt');
    textLayer.destroy();
    background.destroy();
    setBackground(img);
    setText(t);
});
/* Handles text input field and text printing to canvas */
$('#print').click(function(e) {
    t = $('#quoteInput').val();
    background.destroy();
    setBackground(img);
    textLayer.destroy();
    setText(t);
});
/* Handles quote selection from database instead of input it manually */


});

函数范围内隐藏了其他函数所需的变量。

  • 隐藏画布
  • 背景
  • 文本层
  • img
  • t

所以,

  • 将这些变量设置为全局变量或
  • 在需要的地方传递,或者
  • 在需要时创建

更好的资源方法是在层中销毁yChildren(),而不是销毁层本身:

     background.destroyChildren();
    textLayer.destroyChildren();

此外,您还将图像路径存储在img的alt属性中。

这是对残疾观众的不尊重,他们需要这种财产来帮助他们理解图像。

以下是代码和Fiddle:http://jsfiddle.net/m1erickson/ZFz3z/

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>Prototype</title>
    <script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>
    <script src="http://d3lp1msu2r81bx.cloudfront.net/kjs/js/lib/kinetic-v4.5.4.min.js"></script>
<style>
#container{
  border:solid 1px #ccc;
  margin-top: 10px;
  width:234px;
  height:234px;
}
</style>        
<script>
$(function(){
    var hiddenCanvas = new Kinetic.Stage({
        container : 'container',
        width : 234,
        height : 234
    });
    var background = new Kinetic.Layer();
    hiddenCanvas.add(background);
    var textLayer = new Kinetic.Layer();
    hiddenCanvas.add(textLayer);

    function setBackground (image){
         var imageObj = new Image();
         imageObj.onload = function (){
         var backImg = new Kinetic.Image({
             x: 0,
             y: 0,
             image: imageObj,
             width: 234,
             height: 234
             });
             background.destroyChildren();
             background.add(backImg);
             background.draw();
         };
         imageObj.src = image;
    }
    function setText(txt){
        var text = new Kinetic.Text({
            x: 20,
            y: 50,
            text: txt,
            fontSize: 36,
            fontFamily: 'Calibri',
            fill: '#555',
            align: 'center'
            });
            textLayer.destroyChildren();
            textLayer.add(text);
            textLayer.draw();
    }
    /* Handles image selection and background setting for canvas */
    $('.imgs').click(function(e) {
        img = $(this).attr('src');
        setBackground(img);
    });
    /* Handles text input field and text printing to canvas */
    $('#print').click(function(e) {
        t = $('#quoteInput').val();
        setText(t);
    });

}); // end $(function(){});
</script>       
</head>
<body>
    <div id="container"></div>
    <button id="print">Text</button>
    <input id="quoteInput" type="text" value="Hello">
    <img class="imgs" src="houseicon.png">
</body>
</html>