mirror of
https://github.com/Sneed-Group/Poodletooth-iLand
synced 2025-01-09 17:53:50 +00:00
103 lines
No EOL
3.7 KiB
Python
103 lines
No EOL
3.7 KiB
Python
from panda3d.core import LVector4f, NodePath, DecalEffect
|
|
import DNAGroup
|
|
import DNAError
|
|
import DNAUtil
|
|
|
|
import random
|
|
|
|
class DNAWindows(DNAGroup.DNAGroup):
|
|
COMPONENT_CODE = 11
|
|
|
|
def __init__(self, name):
|
|
DNAGroup.DNAGroup.__init__(self, name)
|
|
self.code = ''
|
|
self.color = LVector4f(1, 1, 1, 1)
|
|
self.windowCount = 0
|
|
|
|
def setCode(self, code):
|
|
self.code = code
|
|
|
|
def getCode(self):
|
|
return self.code
|
|
|
|
def setColor(self, color):
|
|
self.color = color
|
|
|
|
def getColor(self):
|
|
return self.color
|
|
|
|
def setWindowCount(self, windowCount):
|
|
self.windowCount = windowCount
|
|
|
|
def getWindowCount(self):
|
|
return self.windowCount
|
|
|
|
@staticmethod
|
|
def setupWindows(parentNode, dnaStorage, code, windowCount, color, hpr,
|
|
scale):
|
|
stripped = code[:-1]
|
|
node_r = dnaStorage.findNode(stripped + 'r')
|
|
node_l = dnaStorage.findNode(stripped + 'l')
|
|
if (node_r is None) or (node_l is None):
|
|
raise DNAError.DNAError('DNAWindows code %s not found in'
|
|
'DNAStorage' % code)
|
|
|
|
def makeWindow(x, y, z, parentNode, color, scale, hpr, flip=False):
|
|
node = node_r if not flip else node_l
|
|
window = node.copyTo(parentNode, 0)
|
|
window.setColor(color)
|
|
window.setScale(NodePath(), scale)
|
|
window.setHpr(hpr)
|
|
window.setPos(x, 0, z)
|
|
window.setEffect(DecalEffect.make())
|
|
window.flattenStrong()
|
|
|
|
offset = lambda: random.random() % 0.0375
|
|
if windowCount == 1:
|
|
makeWindow(offset() + 0.5, 0, offset() + 0.5,
|
|
parentNode, color, scale, hpr)
|
|
elif windowCount == 2:
|
|
makeWindow(offset() + 0.33, 0, offset() + 0.5,
|
|
parentNode, color, scale, hpr)
|
|
makeWindow(offset() + 0.66, 0, offset() + 0.5,
|
|
parentNode, color, scale, hpr, True)
|
|
elif windowCount == 3:
|
|
makeWindow(offset() + 0.33, 0, offset() + 0.66,
|
|
parentNode, color, scale, hpr)
|
|
makeWindow(offset() + 0.66, 0, offset() + 0.66,
|
|
parentNode, color, scale, hpr, True)
|
|
makeWindow(offset() + 0.5, 0, offset() + 0.33,
|
|
parentNode, color, scale, hpr)
|
|
elif windowCount == 4:
|
|
makeWindow(offset() + 0.33, 0, offset() + 0.25,
|
|
parentNode, color, scale, hpr)
|
|
makeWindow(offset() + 0.66, 0, offset() + 0.25,
|
|
parentNode, color, scale, hpr, True)
|
|
makeWindow(offset() + 0.33, 0, offset() + 0.66,
|
|
parentNode, color, scale, hpr)
|
|
makeWindow(offset() + 0.66, 0, offset() + 0.66,
|
|
parentNode, color, scale, hpr, True)
|
|
else:
|
|
raise NotImplementedError('Invalid window count ' + str(windowCount))
|
|
|
|
def makeFromDGI(self, dgi):
|
|
DNAGroup.DNAGroup.makeFromDGI(self, dgi)
|
|
self.code = DNAUtil.dgiExtractString8(dgi)
|
|
self.color = DNAUtil.dgiExtractColor(dgi)
|
|
self.windowCount = dgi.getUint8()
|
|
|
|
def traverse(self, nodePath, dnaStorage):
|
|
if self.getWindowCount() == 0:
|
|
return
|
|
parentX = nodePath.getParent().getScale().getX()
|
|
scale = random.random() % 0.0375
|
|
if parentX <= 5.0:
|
|
scale += 1.0
|
|
elif parentX <= 10.0:
|
|
scale += 1.15
|
|
else:
|
|
scale += 1.3
|
|
hpr = (0, 0, 0)
|
|
DNAWindows.setupWindows(nodePath, dnaStorage, self.getCode(),
|
|
self.getWindowCount(), self.getColor(), hpr,
|
|
scale) |