fabricjs的polygon如何在指定的位置增加新的顶点,而不使原多边形形状扭曲呢?

直接向polygon的points数组中插入新的点会自动使其变形,貌似是由于polygon是根据points数组中点的顺序绘制的?如何才能在原轮廓上增加新顶点而不改变图形呢

阅读 2k
1 个回答

绘制 polygon 肯定要按照数据的顺序来绘制。
我理解你的想法,以为如果加入新节点的话应该自动把节点插入到最近的两个点之间,polygon 负责找到最短的路径来绘制多边形。但是这样一来就没有办法直接绘制有非最短路径的多边形了,并且绘制的运算量会很大(需要遍历计算节点距离并取最短)、开发者对图形的控制力下降(如果要绘制非最短路径的多边形,则需要额外的参数来修改绘制顺序),所以 polygon 把这个问题交给开发者自己处理。
正确的方法是自己计算插入节点在数组中的位置,然后插入到数组相应位置:MDN 文档:Array.prototype.splice

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏