【问题标题】:KonvaJS / HTML5 Canvas infinite scroll looping items - cannot clone stage and append to topKonvaJS / HTML5 Canvas 无限滚动循环项目 - 无法克隆舞台并附加到顶部
【发布时间】:2019-05-04 22:23:18
【问题描述】:

我正在尝试创建一个包含许多项目(比如 200 个)的 KonvaJS 画布,这超出了视口的大小。滚动视口效果很好,但我希望整个画布看起来是无限的。与此类似: JS Fiddle example here 因此,当您滚动到顶部时,您会看到底部的内容。我的计划是检测浏览器何时接近顶部或底部并克隆舞台,然后将其附加到原始舞台的顶部或底部。一旦再次发生这种情况,则破坏原始阶段并重复。

    window.onscroll = function(ev)
    {
        var B= document.body; 
        var D= document.documentElement; 
        D= (D.clientHeight)? D: B;

        if (D.scrollTop == 0)
        {
            console.log("scrolled top");
            var cloned_stage = stage.clone();

            cloned_stage.setContainer("container2");

            cloned_stage.draw();


        }

        if ((window.innerHeight + window.scrollY) >= document.body.offsetHeight) {
            console.log("scrolled bottom");
        }
    };

JSFiddle

然而,这似乎什么也没做。我也尝试过使用 Y 偏移,但没有运气。这是最好的方法吗?

【问题讨论】:

    标签: javascript html canvas html5-canvas konvajs


    【解决方案1】:

    Konva 在阶段克隆中存在一个错误。克隆阶段未正确附加到 DOM。作为一种解决方法,您可以对其进行序列化/反序列化。

    var JSON = stage.toJSON();
    
    cloned_stage= Konva.Node.create(JSON, "container2")
    

    演示https://jsfiddle.net/gsaorb82/2/

    【讨论】:

      猜你喜欢
      • 2019-05-07
      • 1970-01-01
      • 2019-12-25
      • 2019-04-20
      • 1970-01-01
      • 2019-04-29
      • 1970-01-01
      • 2018-08-09
      • 2018-04-21
      相关资源
      最近更新 更多