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


Python Vector.copyVector方法代碼示例

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


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

示例1: __init__

# 需要導入模塊: import Vector [as 別名]
# 或者: from Vector import copyVector [as 別名]
class DendriteTip:
    def __init__(heading, headingRange, stepSize, resources, maxResources,
                 startThickness, endThickness, startPosition,
                 cellCenter, neuron):

        self.heading        = heading
        self.headingRange   = headingRange
        self.stepSize       = stepSize
        self.resources      = resources
        self.maxResources   = maxResources
        self.startThickness = startThickness
        self.endThickness   = endThickness
        self.cellCenter     = cellCenter
        self.neuron         = neuron

        self.p1 = startPosition
        self.p2 = None
        self.v1 = None
        self.v2 = None
        self.v3 = None
        self.v4 = None

        self.growing = True

        self.points     = []
        self.vertices   = []

    def isGrowing(self):
        return self.growing

    def grow(self, stepSize=None, heading=None, headingRange=None):
        if self.growing:
            if heading==None:       heading         = self.heading
            if headingRange==None:  headingRange    = self.headingRange
            if stepSize==None:      stepSize        = self.stepSize

            if self.p2 == None:
                initializeGrowth(stepSize, heading, headingRange)
            else:
                regularGrowth(stepSize, heading, headingRange)

    def initializeGrowth(self, stepSize, heading, headingRange):        
        self.p2     = Vector()
        self.p2.x   = m.cos(m.radians(heading)) * stepSize + self.p1.x
        self.p2.y   = m.sin(m.radians(heading)) * stepSize + self.p1.y
        
        thickness = (self.resources/self.maxResources) * (self.startThickness - self.endThickness) + self.endThickness
        halfThickness = thickness / 2.0

        t           = self.p1 - self.cellCenter
        leftPerp    = t.leftXYPerpendicular().normalize()
        rightPerp   = t.rightXYPerpendicular().normalize()
        self.v1     = leftPerp * halfThickness + self.p1
        self.v4     = rightPerp * halfThickness + self.p1

        t           = self.p2 - self.p1
        leftPerp    = t.leftXYPerpendicular().normalize()
        rightPerp   = t.rightXYPerpendicular().normalize()
        self.v2     = leftPerp * halfThickness + self.p2
        self.v3     = rightPerp * halfThickness + self.p2

        self.vertices   = self.vertices + [self.v1] + [self.v2] + [self.v3] + [self.v4]
        self.points     = self.points + [self.p1] + [self.p2]
        
        self.resources -= stepSize
        if self.resources <= 0: self.growing = False


    def regularGrowth(self, stepSize=None, heading=None, headingRange=None):
        # Start growing from the last dendrite points (deep copies)
        self.p1 = self.p2.copyVector()
        self.v1 = self.v2.copyVector()
        self.v4 = self.v3.copyVector()

        # Unlink any references that exist
        self.p2 = Vector()
        self.v2 = Vector()
        self.v3 = Vector()
        
        # Map the resources remaining into the range of thickness values to obtain the current thickness
        thickness       = remap(self.resources, 0.0, self.maxResources, self.startThickness, self.endThickness)
        halfThickness   = thickness / 2.0

        # Generate a random heading
        heading += r.uniform(-self.headingRange, self.headingRange)

        # Find p2 by moving in the heading direction
        self.p2.x = self.p1.x + m.cos(m.radians(heading)) * stepSize
        self.p2.y = self.p1.y + m.sin(m.radians(heading)) * stepSize

        # Calculate the new vertices of the quad (adding thickness relative to p2)
        t           = self.p2 - self.p1
        leftPerp    = t.leftXYPerpendicular().normalize()
        rightPerp   = t.rightXYPerpendicular().normalize()
        self.v2     = leftPerp * halfThickness + self.p2
        self.v3     = rightPerp * halfThickness + self.p2

        # Store the new vertices and the new point
        self.vertices   = self.vertices + [self.v2] + [self.v3]
        self.points     = self.points + [self.p2]
#.........這裏部分代碼省略.........
開發者ID:mikewesthad,項目名稱:LitWithinBlender,代碼行數:103,代碼來源:BranchTip.py


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