【问题标题】:What happens to the radius of a circle on SVG when we apply a matrix transformation to it?当我们对 SVG 应用矩阵变换时,圆的半径会发生什么变化?
【发布时间】:2020-10-26 15:56:04
【问题描述】:

例如,假设我有这个圈子:

<svg viewBox="0 0 200 200" xmlns="http://www.w3.org/2000/svg">
  <circle cx="10" cy="10" r="10" fill="green" />
</svg>

现在我有一个矩阵变换的同一个圆:

<svg viewBox="0 0 200 200" xmlns="http://www.w3.org/2000/svg">
  <circle cx="10" cy="10" r="10" fill="red" transform="matrix(3 1 -1 3 30 40)" />
</svg>

为什么现在圈子变大了?

我正在阅读this,但我不明白这个圈子会发生什么。对于矩形,它似乎为它计算了 4 个新坐标。但是对于圆,它似乎计算了一个新点,即圆的新中心,然后圆的半径发生了一些我不知道它是什么的事情。

【问题讨论】:

标签: svg transform


【解决方案1】:

可以这样考虑转换(尽管不是这样实现的):

  1. 算出你要画的所有点
  2. 将步骤 1 中的每个点映射到您通过乘以矩阵得到的变换点
  3. 绘制所有这些变换点

或者假设您在弹性片材上画了一个圆圈,然后均匀地拉伸弹性片材。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2017-05-09
    • 2014-05-16
    • 1970-01-01
    • 2020-09-30
    • 2021-09-08
    • 1970-01-01
    • 2018-11-05
    • 1970-01-01
    相关资源
    最近更新 更多