Added Vector.angle method

Inverted MeshData.cylinder normals
This commit is contained in:
Luke Campagnola 2014-02-11 13:59:09 -05:00
parent d45467e4cb
commit 79af643955
2 changed files with 17 additions and 6 deletions

View File

@ -67,4 +67,19 @@ class Vector(QtGui.QVector3D):
yield(self.x()) yield(self.x())
yield(self.y()) yield(self.y())
yield(self.z()) yield(self.z())
def angle(self, a):
"""Returns the angle in degrees between this vector and the vector a."""
n1 = self.length()
n2 = a.length()
if n1 == 0. or n2 == 0.:
return None
## Probably this should be done with arctan2 instead..
ang = np.arccos(np.clip(QtGui.QVector3D.dotProduct(self, a) / (n1 * n2), -1.0, 1.0)) ### in radians
# c = self.crossProduct(a)
# if c > 0:
# ang *= -1.
return ang * 180. / np.pi

View File

@ -242,7 +242,6 @@ class MeshData(object):
v = self.vertexes(indexed='faces') v = self.vertexes(indexed='faces')
self._faceNormals = np.cross(v[:,1]-v[:,0], v[:,2]-v[:,0]) self._faceNormals = np.cross(v[:,1]-v[:,0], v[:,2]-v[:,0])
if indexed is None: if indexed is None:
return self._faceNormals return self._faceNormals
elif indexed == 'faces': elif indexed == 'faces':
@ -519,20 +518,17 @@ class MeshData(object):
return MeshData(vertexes=verts, faces=faces) return MeshData(vertexes=verts, faces=faces)
@staticmethod @staticmethod
def cylinder(rows, cols, radius=[1.0, 1.0], length=1.0, offset=False, ends=False): def cylinder(rows, cols, radius=[1.0, 1.0], length=1.0, offset=False):
""" """
Return a MeshData instance with vertexes and faces computed Return a MeshData instance with vertexes and faces computed
for a cylindrical surface. for a cylindrical surface.
The cylinder may be tapered with different radii at each end (truncated cone) The cylinder may be tapered with different radii at each end (truncated cone)
ends are open if ends = False
No closed ends implemented yet...
The easiest way may be to add a vertex at the top and bottom in the center of the face?
""" """
verts = np.empty((rows+1, cols, 3), dtype=float) verts = np.empty((rows+1, cols, 3), dtype=float)
if isinstance(radius, int): if isinstance(radius, int):
radius = [radius, radius] # convert to list radius = [radius, radius] # convert to list
## compute vertexes ## compute vertexes
th = ((np.arange(cols) * 2 * np.pi / cols).reshape(1, cols)) # angle around th = np.linspace(2 * np.pi, 0, cols).reshape(1, cols)
r = (np.linspace(radius[0],radius[1],num=rows+1, endpoint=True)).reshape(rows+1, 1) # radius as a function of z r = (np.linspace(radius[0],radius[1],num=rows+1, endpoint=True)).reshape(rows+1, 1) # radius as a function of z
verts[...,2] = np.linspace(-length/2.0, length/2.0, num=rows+1, endpoint=True).reshape(rows+1, 1) # z verts[...,2] = np.linspace(-length/2.0, length/2.0, num=rows+1, endpoint=True).reshape(rows+1, 1) # z
if offset: if offset: