當前位置: 首頁>>代碼示例>>Python>>正文


Python Vector.y方法代碼示例

本文整理匯總了Python中Vector.y方法的典型用法代碼示例。如果您正苦於以下問題:Python Vector.y方法的具體用法?Python Vector.y怎麽用?Python Vector.y使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Vector的用法示例。


在下文中一共展示了Vector.y方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: createDendrites

# 需要導入模塊: import Vector [as 別名]
# 或者: from Vector import y [as 別名]
    def createDendrites(self):
        angle           = 360.0/self.branches
        startDist       = 0.95 * self.somaSize
        endDist         = startDist + self.stepDist
        halfThickness   = self.dendriteThickness/2.0
        
        a = 0.0
        while a<360.0:
            
            # Define the points that the dendrite would follow if it were a line (i.e. no thickness)
            initialResources = self.maxRadius 
            p1, p2 = Vector(), Vector()
            p1.x = m.cos(m.radians(a)) * startDist + self.center.x
            p1.y = m.sin(m.radians(a)) * startDist + self.center.y
            p2.x = m.cos(m.radians(a)) * endDist + self.center.x
            p2.y = m.sin(m.radians(a)) * endDist + self.center.y
            remainingResources = initialResources - p1.distance(p2)

            # Find the first and last vertex of the quad (moving perpendicular from p1 to create thickness)
            t = p1 - self.center
            leftPerp    = t.leftXYPerpendicular().normalize()
            rightPerp   = t.rightXYPerpendicular().normalize()
            v1 = leftPerp * halfThickness + p1
            v4 = rightPerp * halfThickness + p1

            # Find the second and third vertex of the quad (moving perpendicular from p2 to create thickness)
            t = p2 - p1
            leftPerp    = t.leftXYPerpendicular().normalize()
            rightPerp   = t.rightXYPerpendicular().normalize()
            v2 = leftPerp * halfThickness + p2
            v3 = rightPerp * halfThickness + p2

            # Find the vertex index of the newly added vertices
            startVertexNumber = len(self.verts)
            v1Number = startVertexNumber
            v2Number = startVertexNumber + 1
            v3Number = startVertexNumber + 2
            v4Number = startVertexNumber + 3

            # Add the vertices
            self.verts = self.verts + [v1.toList(), v2.toList(), v3.toList(), v4.toList()]

            # Add a properly ordered face
            face = self.createOrderedQuad(v1, v2, v3, v4, v1Number, v2Number, v3Number, v4Number)
            self.faces.append(face)

            # Store some information about the current dendrite branch
            self.dendrites.append([[a,initialResources,p1,[v1,v1Number],[v4,v4Number]],
                                   [a,remainingResources,p2,[v2,v2Number],[v3,v3Number]]])
            self.lineSegments.append([p1, (p1+p2)/2.0, p2])
            self.updateRadius(v1, v2, v3, v4)
            a += angle
開發者ID:mikewesthad,項目名稱:LitWithinBlender,代碼行數:54,代碼來源:Neuron.py

示例2: growDendrite

# 需要導入模塊: import Vector [as 別名]
# 或者: from Vector import y [as 別名]
    def growDendrite(self, i):
        dendrite        = self.dendrites[i]
        step            = self.stepDist
        halfThickness   = self.dendriteThickness/2.0

        # Load this dendrite's information
        heading         = dendrite[-1][0]
        resources       = dendrite[-1][1]
        p1              = dendrite[-1][2]
        v1, v1Number    = dendrite[-1][3]
        v4, v4Number    = dendrite[-1][4]

        thickness = resources/self.maxRadius * (self.dendriteThickness - self.minDendriteThickness) + self.minDendriteThickness
        halfThickness = thickness / 2.0

        # Generate a random heading in order to create p2
        heading += r.uniform(-self.headingRange, self.headingRange)
        p2      = Vector()
        p2.x    = p1.x + m.cos(m.radians(heading)) * step
        p2.y    = p1.y + m.sin(m.radians(heading)) * step
        resources = resources - p1.distance(p2)

        # Calculate the new vertices of the quad (adding thickness)
        t = p2 - p1
        leftPerp    = t.leftXYPerpendicular().normalize()
        rightPerp   = t.rightXYPerpendicular().normalize()
        v2 = leftPerp * halfThickness + p2
        v3 = rightPerp * halfThickness + p2
        
        # Find the vertex index of the newly added vertices
        startVertexNumber = len(self.verts)
        v2Number = startVertexNumber
        v3Number = startVertexNumber + 1
        
        # Add the vertices
        self.verts = self.verts + [v2.toList(), v3.toList()]
        
        # Add a properly ordered face
        face = self.createOrderedQuad(v1, v2, v3, v4, v1Number, v2Number, v3Number, v4Number)
        self.faces.append(face)

        # Store some information about the current dendrite branch
        self.dendrites[i].append([heading, resources, p2, [v2,v2Number], [v3,v3Number]])
        self.lineSegments.append([p1, (p1+p2)/2.0, p2])
        self.updateRadius(v1, v2, v3, v4)
開發者ID:mikewesthad,項目名稱:LitWithinBlender,代碼行數:47,代碼來源:Neuron.py


注:本文中的Vector.y方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。