本文整理匯總了Python中FreeCAD.Matrix方法的典型用法代碼示例。如果您正苦於以下問題:Python FreeCAD.Matrix方法的具體用法?Python FreeCAD.Matrix怎麽用?Python FreeCAD.Matrix使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類FreeCAD
的用法示例。
在下文中一共展示了FreeCAD.Matrix方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: getElementPlacement
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def getElementPlacement(obj,mat=None):
'''Get the placement of an element
obj: either a document object or a tuple(obj,subname)
mat: if not None, then this should be a matrix, and the returned
placement will be relative to this transformation matrix.
'''
if not isElement(obj):
if not isinstance(obj,(tuple,list)):
pla = obj.Placement
else:
_,mat = obj[0].getSubObject(obj[1],1,FreeCAD.Matrix())
pla = FreeCAD.Placement(mat)
else:
pla = FreeCAD.Placement(getElementPos(obj),getElementRotation(obj))
if not mat:
return pla
return FreeCAD.Placement(mat.inverse()).multiply(pla)
示例2: helicalextrusion
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def helicalextrusion(wire, height, angle, double_helix=False):
direction = bool(angle < 0)
if double_helix:
first_spine = makeHelix(height * 2. * np.pi /
abs(angle), 0.5 * height, 10., 0, direction)
first_solid = first_spine.makePipeShell([wire], True, True)
second_solid = first_solid.mirror(
fcvec([0., 0., 0.]), fcvec([0, 0, 1]))
faces = first_solid.Faces + second_solid.Faces
faces = [f for f in faces if not on_mirror_plane(
f, 0., fcvec([0., 0., 1.]))]
solid = makeSolid(makeShell(faces))
mat = App.Matrix()
mat.move(fcvec([0, 0, 0.5 * height]))
return solid.transformGeometry(mat)
else:
first_spine = makeHelix(height * 2 * np.pi /
abs(angle), height, 10., 0, direction)
first_solid = first_spine.makePipeShell([wire], True, True)
return first_solid
示例3: execute
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def execute(self,obj):
sayd("execute _Plugger")
self.obj2.status=0
obj.end=obj.start+obj.duration
if self.obj2.trafoMode == "yz":
self.obj2.trafoMatrix=FreeCAD.Matrix(
0,0,0,0,
1,0,0,0,
0,1,0,0,
0,0,0,1);
if self.obj2.trafoMode == "xz":
self.obj2.trafoMatrix=FreeCAD.Matrix(
1,0,0,0,
0,0,0,0,
0,1,0,0,
0,0,0,1);
obj.setEditorMode("end", 1) #ro
示例4: get_transformation_matrix_from_vectors
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def get_transformation_matrix_from_vectors(x, y, z):
x_local = x.normalize()
y_local = y.normalize()
z_local = z.normalize()
m = FreeCAD.Matrix()
if z_local is not None:
m.A11 = x_local.x
m.A12 = y_local.x
m.A13 = z_local.x
m.A21 = x_local.y
m.A22 = y_local.y
m.A23 = z_local.y
m.A31 = x_local.z
m.A32 = y_local.z
m.A33 = z_local.z
return m
示例5: get_matrix_transform
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def get_matrix_transform(face):
x_local, y_local_not_normalized, z_local_not_normalized = get_local_axis(face)
y_local = y_local_not_normalized.normalize()
z_local = z_local_not_normalized.normalize()
m = FreeCAD.Matrix()
if z_local is not None:
m.A11 = x_local.x
m.A12 = y_local.x
m.A13 = z_local.x
m.A21 = x_local.y
m.A22 = y_local.y
m.A23 = z_local.y
m.A31 = x_local.z
m.A32 = y_local.z
m.A33 = z_local.z
return m
示例6: __init__
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def __init__(self, info):
self.info = info.ElementInfo
idx = len(self.info.Subname)
if idx:
sub = info.SelSubname[:-idx]
else:
sub = info.SelSubname
_,mat = info.SelObj.getSubObject(sub,1,FreeCAD.Matrix())
pos = utils.getElementPos(self.info.Shape)
if not pos:
pos = self.info.Shape.BoundBox.Center
pos = mat.multiply(pos)
self.matrix = mat*self.info.Placement.inverse().toMatrix()
base = self.matrix.multiply(self.info.Placement.Base)
self.offset = pos - base
self.matrix.invert()
self.view = info.SelObj.ViewObject.Document.ActiveView
self.callbackMove = self.view.addEventCallback(
"SoLocation2Event",self.moveMouse)
self.callbackClick = self.view.addEventCallback(
"SoMouseButtonEvent",self.clickMouse)
self.callbackKey = self.view.addEventCallback(
"SoKeyboardEvent",self.keyboardEvent)
FreeCAD.setActiveTransaction('Assembly quick move',True)
self.active = True
示例7: execute
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def execute(self,obj):
link = obj.LinkedObject
if isinstance(link,tuple):
subname = link[1]
link = link[0]
else:
subname = ''
linked,mat = link.getSubObject(subname,1,FreeCAD.Matrix())
if linked and linked.Label != linked.Name:
obj.Label = linked.Label
info = None
if getattr(obj,'Count',None):
info = self.getInfo(True)
version = self.childVersion(linked,mat)
if not self.version.update(version):
logger.debug('skip {}, {}, {}',
objName(obj),self.version.childVersion,version)
return
logger.debug('not skip {}, {}',objName(obj),version)
if not info:
info = self.getInfo(True)
relationGroup = self.getAssembly().getRelationGroup()
if relationGroup and (not self.part or self.part!=info.Part):
oldPart = self.part
self.part = info.Part
relationGroup.Proxy.update(
self.parent.Object,oldPart,info.Part,info.PartName)
self.version.commit()
return False
示例8: matrixAt
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def matrixAt(self, p, i):
t = self.rails[i].valueAt(p)
u,v,w = self.frameAt(p,i)
m = FreeCAD.Matrix( u.x, v.x, w.x, t.x,
u.y, v.y, w.y, t.y,
u.z, v.z, w.z, t.z,
0.0, 0.0, 0.0, 1.0)
return(m)
示例9: matrix1At
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def matrix1At(self, p):
t = self.rail1.valueAt(p)
u,v,w = self.frame1At(p)
m=FreeCAD.Matrix( u.x,v.x,w.x,t.x,
u.y,v.y,w.y,t.y,
u.z,v.z,w.z,t.z,
0.0,0.0,0.0,1.0)
return m
示例10: matrix2At
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def matrix2At(self, p):
t = self.rail2.valueAt(p)
u,v,w = self.frame2At(p)
m=FreeCAD.Matrix( u.x,v.x,w.x,t.x,
u.y,v.y,w.y,t.y,
u.z,v.z,w.z,t.z,
0.0,0.0,0.0,1.0)
return m
示例11: execute
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def execute(self, fp):
inner_diameter = fp.module.Value * fp.teeth
outer_diameter = inner_diameter + fp.height.Value * 2
inner_circle = Part.Wire(Part.makeCircle(inner_diameter / 2.))
outer_circle = Part.Wire(Part.makeCircle(outer_diameter / 2.))
inner_circle.reverse()
face = Part.Face([outer_circle, inner_circle])
solid = face.extrude(App.Vector([0., 0., -fp.thickness.Value]))
# cutting obj
alpha_w = np.deg2rad(fp.pressure_angle.Value)
m = fp.module.Value
t = fp.teeth
t_c = t
t_i = fp.other_teeth
rm = inner_diameter / 2
y0 = m * 0.5
y1 = m + y0
y2 = m
r0 = inner_diameter / 2 - fp.height.Value * 0.1
r1 = outer_diameter / 2 + fp.height.Value * 0.3
polies = []
for r_i in np.linspace(r0, r1, fp.num_profiles):
pts = self.profile(m, r_i, rm, t_c, t_i, alpha_w, y0, y1, y2)
poly = Wire(makePolygon(list(map(fcvec, pts))))
polies.append(poly)
loft = makeLoft(polies, True)
rot = App.Matrix()
rot.rotateZ(2 * np.pi / t)
if fp.construct:
cut_shapes = [solid]
for _ in range(t):
loft = loft.transformGeometry(rot)
cut_shapes.append(loft)
fp.Shape = Part.Compound(cut_shapes)
else:
for i in range(t):
loft = loft.transformGeometry(rot)
solid = solid.cut(loft)
fp.Shape = solid
示例12: world_to_local_transform
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def world_to_local_transform(self):
"""
:return: 3d affine transform matrix to convert world coordinates to local coordinates.
:rtype: :class:`cadquery.Matrix`
For matrix structure, see :meth:`from_transform`.
"""
return self.fG
示例13: local_to_world_transform
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def local_to_world_transform(self):
"""
:return: 3d affine transform matrix to convert local coordinates to world coordinates.
:rtype: :class:`cadquery.Matrix`
For matrix structure, see :meth:`from_transform`.
"""
return self.rG
示例14: mat2list
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def mat2list(m, digits=7):
"""Converts FreeCAD.Base.Matrix to a list"""
return [
round(v, digits)
for v in [
m.A11, m.A12, m.A13, m.A14,
m.A21, m.A22, m.A23, m.A24,
m.A31, m.A32, m.A33, m.A34,
m.A41, m.A42, m.A43, m.A44
]
]
示例15: assertMatrixAlmostEquals
# 需要導入模塊: import FreeCAD [as 別名]
# 或者: from FreeCAD import Matrix [as 別名]
def assertMatrixAlmostEquals(self, first, second, places=6):
"""
:param first: matrix
:type first: :class:`FreeCAD.Base.Matrix`
:param second: list of 16 numbers (of a 4x4 matrix)
:type second: :class:`list`
"""
for (a, b) in zip(self.mat2list(first), second):
self.assertAlmostEqual(a, b, places=places)