微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Konva / Canvas 上未缩放的交互层

如何解决Konva / Canvas 上未缩放的交互层

我正在用 React Konva 编写一个简单的图像编辑器。我生成<Stage width={500} height={500}>,但在较小的视口中,我尝试通过 CSS 缩放画布表。

例如:

const Component = () => (
    <Div>
        <Stage {...size}> ... </Stage>
    </Div>
)

const Div = styled.div`
  canvas {
    max-width: 100% !important;
    height: auto !important;
  }
  .konvajs-content {
    width: initial !important;
    height: initial !important;
  }
`;

我注意到整个工作表缩放正确,但交互层不正确。结果,如果我在移动设备上缩放画布,我无法拖放元素并精确点击元素。

示例:https://youtu.be/ulu_ot5f9Xg

我无法通过视口缩放画布。其他功能使用此画布,并期待大分辨率。

解决方法

您不应使用 CSS 缩放 Konva 舞台,也不应更改其内部样式。它可能会破坏命中检测算法,也可能会大大降低您的应用程序的性能。

相反,您应该只读取容器 DOM 元素的大小并将该大小应用于舞台。如果需要,您可以使用 scaleXscaleY 为舞台调整内容。

有关演示,请查看此处:https://konvajs.org/docs/sandbox/Responsive_Canvas.html#Do-you-need-responsive-adaptive-canvas-for-you-desktop-and-mobile-applications

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。