我使用NURBS-python并发现了一个有趣的问题,但不确定这样做是有意的还是一个错误。我想用2个代码进行介绍。
第一个输出应该与第二个输出相同,而第二个则不然。第一个成功更新了NURBS曲线的控制点并绘制了一条新曲线,
更改控制点列表的方式会影响结果。
import math
from geomdl import BSpline
from geomdl import NURBS
from geomdl import fitting
from geomdl import convert
from geomdl.visualization import VisMPL
P1=[[0, 0], [0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [0, 0]]
Degree=3
CPN=5
P2=[[0, 0], [0, 1], [2, 1], [2, 0], [2, -1], [0, -1], [0, 0]]
CP=[[0, 0], [1, 2], [2, 0], [1, -2], [0, 0]]
c1=NURBS.Curve()
c1.degree=Degree
c1.ctrlpts=P1
c1.weights=[1, 1, 1, 1, 1, 1, 1]
c1.knotvector=[0, 0, 0, 0, 0.25, 0.5, 0.75, 1, 1, 1, 1]
c1.vis=VisMPL.VisCurve2D()
c1.render()
c1.ctrlpts=P2
c1.vis=VisMPL.VisCurve2D()
c1.render()
c2=convert.bspline_to_nurbs(fitting.approximate_curve(P1, Degree, ctrlpts_size=CPN))
c2.vis=VisMPL.VisCurve2D()
c2.render()
c2.ctrlpts=CP
c2.vis=VisMPL.VisCurve2D()
c2.render()
第二个仅更新控制点时,曲线本身完全没有变化。
import math
from geomdl import BSpline
from geomdl import NURBS
from geomdl import fitting
from geomdl import convert
from geomdl.visualization import VisMPL
P1=[[0, 0], [0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [0, 0]]
Degree=3
CPN=5
P2=[[0, 0], [0, 1], [2, 1], [2, 0], [2, -1], [0, -1], [0, 0]]
CP=[[0, 0], [1, 2], [2, 0], [1, -2], [0, 0]]
c1=NURBS.Curve()
c1.degree=Degree
c1.ctrlpts=P1
c1.weights=[1, 1, 1, 1, 1, 1, 1]
c1.knotvector=[0, 0, 0, 0, 0.25, 0.5, 0.75, 1, 1, 1, 1]
c1.vis=VisMPL.VisCurve2D()
c1.render()
for i in range(len(P2)):
c1.ctrlpts[i]=P2[i]
c1.vis=VisMPL.VisCurve2D()
c1.render()
c2=convert.bspline_to_nurbs(fitting.approximate_curve(P1, Degree, ctrlpts_size=CPN))
c2.vis=VisMPL.VisCurve2D()
c2.render()
for i in range(len(CP)):
c2.ctrlpts[i]=CP[i]
c2.vis=VisMPL.VisCurve2D()
c2.render()
请帮忙,谢谢。
答案 0 :(得分:0)
Curve.ctrlpts
是property。当您访问吸气剂时,它将返回控制点列表。访问setter的功能还很多,主要是一致性检查和必要的清理。
当调用cpts = c1.ctrlpts
时,调用属性的__get__
方法,将返回在Curve
实例内部存储控制点的列表对象的引用,并将其分配给{{1 }}变量:
cpts
当您遍历列表>>> cpts = c1.ctrlpts
>>> type(cpts)
<class 'list'>
时,实际上是遍历cpts
类实例中的引用。由于您是直接与列表对象进行交互,因此您无需访问Curve
设置程序,该设置程序实际上是通过调用ctrlpts
方法进行清理的。
不幸的是,无法覆盖内置类(在API级别上定义的类)的方法。
Curve.reset()
结果,当基础>>> list.__getitem__ = my_getter_method
TypeError: can't set attributes of built-in/extension type 'list'
对象发生更改时触发Curve.reset()
方法变得有点复杂(但并非不可能)。
设置控制点的最佳和最安全的方法是使用属性的setter方法:
list
如果要使用for循环,则需要手动调用reset方法:
my_ctrlpts = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
c1.ctrlpts = my_ctrlpts
注意:我是NURBS-Python(geomdl)的作者