Some pet stuff.

This commit is contained in:
Loudrob 2015-03-29 18:16:26 -04:00
parent 4e50e8a485
commit 47361ccb04
14 changed files with 105 additions and 62 deletions

View file

@ -261,7 +261,7 @@ class TTUFriendsManagerUD(DistributedObjectGlobalUD):
def getPetDetails(self, avId): def getPetDetails(self, avId):
senderId = self.air.getAvatarIdFromSender() senderId = self.air.getAvatarIdFromSender()
def handlePet(dclass, fields): def handlePet(dclass, fields):
if dclass != self.air.dclassesByName['DistributedPetUD']: if dclass != self.air.dclassesByName['DistributedPetAI']:
return return
dna = [fields.get(x, [0])[0] for x in ("setHead", "setEars", "setNose", "setTail", "setBodyTexture", "setColor", dna = [fields.get(x, [0])[0] for x in ("setHead", "setEars", "setNose", "setTail", "setBodyTexture", "setColor",
"setColorScale", "setEyeColor", "setGender")] "setColorScale", "setEyeColor", "setGender")]

View file

@ -956,6 +956,9 @@ class DistributedPetAI(DistributedSmoothNodeAI.DistributedSmoothNodeAI, PetLooke
self.__petMovieStart(avId) self.__petMovieStart(avId)
def enableLockMover(self): def enableLockMover(self):
if not hasattr(self, 'brain'):
return
if self.lockMoverEnabled == 0: if self.lockMoverEnabled == 0:
self.brain._startMovie() self.brain._startMovie()
self.lockMoverEnabled += 1 self.lockMoverEnabled += 1
@ -964,6 +967,9 @@ class DistributedPetAI(DistributedSmoothNodeAI.DistributedSmoothNodeAI, PetLooke
return self.lockMoverEnabled > 0 return self.lockMoverEnabled > 0
def disableLockMover(self): def disableLockMover(self):
if not hasattr(self, 'brain'):
return
if self.lockMoverEnabled > 0: if self.lockMoverEnabled > 0:
self.lockMoverEnabled -= 1 self.lockMoverEnabled -= 1
if self.lockMoverEnabled == 0: if self.lockMoverEnabled == 0:

View file

@ -356,6 +356,7 @@ class DistributedPetProxyAI(DistributedObjectAI.DistributedObjectAI):
def generate(self): def generate(self):
DistributedObjectAI.DistributedObjectAI.generate(self) DistributedObjectAI.DistributedObjectAI.generate(self)
self.traits = PetTraits.PetTraits(self.traitSeed, self.safeZone) self.traits = PetTraits.PetTraits(self.traitSeed, self.safeZone)
print self.traits.traits
for i in xrange(len(self.traitList)): for i in xrange(len(self.traitList)):
value = self.traitList[i] value = self.traitList[i]
if value == 0.0: if value == 0.0:

View file

@ -9,7 +9,6 @@ from direct.actor import Actor
from direct.task import Task from direct.task import Task
from toontown.pets import PetDNA from toontown.pets import PetDNA
from PetDNA import HeadParts, EarParts, NoseParts, TailParts, BodyTypes, BodyTextures, AllPetColors, getColors, ColorScales, PetEyeColors, EarTextures, TailTextures, getFootTexture, getEarTexture, GiraffeTail, LeopardTail, PetGenders from PetDNA import HeadParts, EarParts, NoseParts, TailParts, BodyTypes, BodyTextures, AllPetColors, getColors, ColorScales, PetEyeColors, EarTextures, TailTextures, getFootTexture, getEarTexture, GiraffeTail, LeopardTail, PetGenders
from toontown.toonbase.BitmaskGlobals import PieBitmask
from toontown.toonbase import TTLocalizer from toontown.toonbase import TTLocalizer
from toontown.toonbase import ToontownGlobals from toontown.toonbase import ToontownGlobals
from direct.showbase import PythonUtil from direct.showbase import PythonUtil
@ -30,7 +29,6 @@ Component2IconDict = {'boredom': 'Bored',
from toontown.nametag import * from toontown.nametag import *
from toontown.nametag.NametagGlobals import * from toontown.nametag.NametagGlobals import *
from toontown.nametag.NametagGroup import *
class Pet(Avatar.Avatar): class Pet(Avatar.Avatar):
notify = DirectNotifyGlobal.directNotify.newCategory('Pet') notify = DirectNotifyGlobal.directNotify.newCategory('Pet')
@ -268,7 +266,7 @@ class Pet(Avatar.Avatar):
def initializeBodyCollisions(self, collIdStr): def initializeBodyCollisions(self, collIdStr):
Avatar.Avatar.initializeBodyCollisions(self, collIdStr) Avatar.Avatar.initializeBodyCollisions(self, collIdStr)
if not self.ghostMode: if not self.ghostMode:
self.collNode.setCollideMask(self.collNode.getIntoCollideMask() | PieBitmask) self.collNode.setCollideMask(self.collNode.getIntoCollideMask() | ToontownGlobals.PieBitmask)
def amplifyColor(self, color, scale): def amplifyColor(self, color, scale):
color = color * scale color = color * scale

View file

@ -273,6 +273,8 @@ class PetAvatarPanel(AvatarPanel.AvatarPanel):
self.notify.debug('__fillPetInfo(): doId=%s' % avatar.doId) self.notify.debug('__fillPetInfo(): doId=%s' % avatar.doId)
self.petView = self.frame.attachNewNode('petView') self.petView = self.frame.attachNewNode('petView')
self.petView.setPos(0, 0, 5.4) self.petView.setPos(0, 0, 5.4)
if hasattr(avatar, 'announceGenerate'):
avatar.announceGenerate()
self.petModel = Pet.Pet(forGui=1) self.petModel = Pet.Pet(forGui=1)
self.petModel.setDNA(avatar.getDNA()) self.petModel.setDNA(avatar.getDNA())
self.petModel.fitAndCenterHead(3.575, forGui=1) self.petModel.fitAndCenterHead(3.575, forGui=1)

View file

@ -58,4 +58,5 @@ ZoneToCostRange = {ToontownGlobals.ToontownCentral: (100, 500),
ToontownGlobals.DaisyGardens: (1000, 2500), ToontownGlobals.DaisyGardens: (1000, 2500),
ToontownGlobals.MinniesMelodyland: (1500, 3000), ToontownGlobals.MinniesMelodyland: (1500, 3000),
ToontownGlobals.TheBrrrgh: (2500, 4000), ToontownGlobals.TheBrrrgh: (2500, 4000),
ToontownGlobals.DonaldsDreamland: (3000, 5000)} ToontownGlobals.DonaldsDreamland: (3000, 5000),
ToontownGlobals.FunnyFarm: (3700, 5800)}

View file

@ -1,3 +1,2 @@
if hasattr(simbase, 'wantPets') and simbase.wantPets: if hasattr(simbase, 'wantPets') and simbase.wantPets:
import DistributedPetAI import DistributedPetAI
import DistributedPetUD

View file

@ -2,7 +2,6 @@ from toontown.toon import ToonDNA
from pandac.PandaModules import VBase4 from pandac.PandaModules import VBase4
from toontown.toonbase import TTLocalizer, ToontownGlobals from toontown.toonbase import TTLocalizer, ToontownGlobals
from direct.showbase import PythonUtil from direct.showbase import PythonUtil
import random
NumFields = 9 NumFields = 9
Fields = {'head': 0, Fields = {'head': 0,
'ears': 1, 'ears': 1,
@ -85,7 +84,14 @@ PetRarities = {'body': {ToontownGlobals.ToontownCentral: {'threeStripe': 50,
'tigerStripe': 20, 'tigerStripe': 20,
'turtle': 25, 'turtle': 25,
'giraffe': 20, 'giraffe': 20,
'leopard': 10}}} 'leopard': 10},
ToontownGlobals.FunnyFarm: {'leopard': 20,
'giraffe': 20,
'dots': 10,
'tigerStripe': 25,
'turtle': 25}
}}
BodyTextures = {'dots': 'phase_4/maps/BeanbodyDots6.jpg', BodyTextures = {'dots': 'phase_4/maps/BeanbodyDots6.jpg',
'threeStripe': 'phase_4/maps/Beanbody3stripes6.jpg', 'threeStripe': 'phase_4/maps/Beanbody3stripes6.jpg',
'tigerStripe': 'phase_4/maps/BeanbodyZebraStripes6.jpg', 'tigerStripe': 'phase_4/maps/BeanbodyZebraStripes6.jpg',
@ -180,17 +186,17 @@ PetEyeColors = (VBase4(0.29, 0.29, 0.69, 1.0),
VBase4(0.49, 0.99, 0.49, 1.0)) VBase4(0.49, 0.99, 0.49, 1.0))
PetGenders = [0, 1] PetGenders = [0, 1]
def getRandomPetDNA(seed = 0, zoneId = ToontownGlobals.DonaldsDreamland): def getRandomPetDNA(zoneId = ToontownGlobals.DonaldsDreamland):
random.seed(seed + zoneId) from random import choice
head = random.choice(range(-1, len(HeadParts))) head = choice(range(-1, len(HeadParts)))
ears = random.choice(range(-1, len(EarParts))) ears = choice(range(-1, len(EarParts)))
nose = random.choice(range(-1, len(NoseParts))) nose = choice(range(-1, len(NoseParts)))
tail = random.choice(range(-1, len(TailParts))) tail = choice(range(-1, len(TailParts)))
body = getSpecies(zoneId) body = getSpecies(zoneId)
color = random.choice(range(0, len(getColors(body)))) color = choice(range(0, len(getColors(body))))
colorScale = random.choice(range(0, len(ColorScales))) colorScale = choice(range(0, len(ColorScales)))
eyes = random.choice(range(0, len(PetEyeColors))) eyes = choice(range(0, len(PetEyeColors)))
gender = random.choice(range(0, len(PetGenders))) gender = choice(range(0, len(PetGenders)))
return [head, return [head,
ears, ears,
nose, nose,

View file

@ -2,7 +2,7 @@ from pandac.PandaModules import *
from direct.directnotify import DirectNotifyGlobal from direct.directnotify import DirectNotifyGlobal
from direct.showbase import DirectObject from direct.showbase import DirectObject
from otp.ai.AIZoneData import AIZoneData from otp.ai.AIZoneData import AIZoneData
from toontown.toonbase.BitmaskGlobals import PetLookatPetBitmask, PetLookatNonPetBitmask from toontown.toonbase import ToontownGlobals
from toontown.pets import PetConstants from toontown.pets import PetConstants
def getStartLookingAtOtherEvent(lookingAvId): def getStartLookingAtOtherEvent(lookingAvId):
@ -83,11 +83,11 @@ class PetLookerAI:
lookSphereNode.addSolid(lookSphere) lookSphereNode.addSolid(lookSphere)
lookSphereNode.setFromCollideMask(BitMask32.allOff()) lookSphereNode.setFromCollideMask(BitMask32.allOff())
if isPet: if isPet:
intoCollideMask = PetLookatPetBitmask intoCollideMask = ToontownGlobals.PetLookatPetBitmask
fromCollideMask = PetLookatPetBitmask | PetLookatNonPetBitmask fromCollideMask = ToontownGlobals.PetLookatPetBitmask | ToontownGlobals.PetLookatNonPetBitmask
else: else:
intoCollideMask = PetLookatNonPetBitmask intoCollideMask = ToontownGlobals.PetLookatNonPetBitmask
fromCollideMask = PetLookatPetBitmask fromCollideMask = ToontownGlobals.PetLookatPetBitmask
lookSphereNode.setIntoCollideMask(intoCollideMask) lookSphereNode.setIntoCollideMask(intoCollideMask)
lookSphereNode.setFromCollideMask(fromCollideMask) lookSphereNode.setFromCollideMask(fromCollideMask)
self.lookSphereNodePath = self.__collNode.attachNewNode(lookSphereNode) self.lookSphereNodePath = self.__collNode.attachNewNode(lookSphereNode)

View file

@ -1,10 +1,7 @@
from direct.directnotify import DirectNotifyGlobal
from direct.fsm.FSM import FSM from direct.fsm.FSM import FSM
import PetUtil, PetDNA import PetUtil, PetDNA
from toontown.hood import ZoneUtil from toontown.toonbase import ToontownGlobals
from toontown.building import PetshopBuildingAI from toontown.toonbase import TTLocalizer
from toontown.toonbase import ToontownGlobals, TTLocalizer
import random
import cPickle, time, random, os import cPickle, time, random, os
MINUTE = 60 MINUTE = 60
@ -15,8 +12,9 @@ def getDayId():
return int(time.time() // DAY) return int(time.time() // DAY)
class PetManagerAI: class PetManagerAI:
NUM_DAILY_PETS = 5 NUM_DAILY_PETS = 5 # per hood
cachePath = config.GetString('air-pet-cache', 'astron/databases/air_cache/') cachePath = config.GetString('air-pet-cache', 'astron/databases/air_cache/')
def __init__(self, air): def __init__(self, air):
self.air = air self.air = air
self.cacheFile = '%spets_%d.pets' % (self.cachePath, self.air.districtId) self.cacheFile = '%spets_%d.pets' % (self.cachePath, self.air.districtId)
@ -37,7 +35,8 @@ class PetManagerAI:
self.seeds = {} self.seeds = {}
for hood in (ToontownGlobals.ToontownCentral, ToontownGlobals.DonaldsDock, ToontownGlobals.DaisyGardens, for hood in (ToontownGlobals.ToontownCentral, ToontownGlobals.DonaldsDock, ToontownGlobals.DaisyGardens,
ToontownGlobals.MinniesMelodyland, ToontownGlobals.TheBrrrgh, ToontownGlobals.DonaldsDreamland): ToontownGlobals.MinniesMelodyland, ToontownGlobals.TheBrrrgh, ToontownGlobals.DonaldsDreamland,
ToontownGlobals.FunnyFarm):
self.seeds[hood] = [seeds.pop() for _ in xrange(self.NUM_DAILY_PETS)] self.seeds[hood] = [seeds.pop() for _ in xrange(self.NUM_DAILY_PETS)]
self.seeds['day'] = getDayId() self.seeds['day'] = getDayId()
@ -45,12 +44,11 @@ class PetManagerAI:
with open(self.cacheFile, 'wb') as f: with open(self.cacheFile, 'wb') as f:
f.write(cPickle.dumps(self.seeds)) f.write(cPickle.dumps(self.seeds))
def getAvailablePets(self, seed, safezoneId): def getAvailablePets(self, seed, safezoneId):
if self.seeds.get('day', -1) != getDayId(): if self.seeds.get('day', -1) != getDayId():
self.generateSeeds() self.generateSeeds()
return self.seeds.get(safezoneId, [seed]) return list(set(self.seeds.get(safezoneId, [seed])))
def createNewPetFromSeed(self, avId, seed, nameIndex, gender, safeZoneId): def createNewPetFromSeed(self, avId, seed, nameIndex, gender, safeZoneId):
av = self.air.doId2do[avId] av = self.air.doId2do[avId]
@ -84,3 +82,5 @@ class PetManagerAI:
self.air.doId2do[pet].requestDelete() self.air.doId2do[pet].requestDelete()
av.b_setPetId(0) av.b_setPetId(0)
# XXX to do: check for current pet and destroy it if generated

View file

@ -9,6 +9,8 @@ estateCenter = (0, -40)
houseRadius = 15 houseRadius = 15
houses = ((60, 10), (42, 75), (-37, 35), (80, -80), (-70, -120), (-55, -40)) houses = ((60, 10), (42, 75), (-37, 35), (80, -80), (-70, -120), (-55, -40))
dist = 2
def inCircle(x, y, c=estateCenter, r=estateRadius): def inCircle(x, y, c=estateCenter, r=estateRadius):
center_x, center_y = c center_x, center_y = c
square_dist = (center_x - x) ** 2 + (center_y - y) ** 2 square_dist = (center_x - x) ** 2 + (center_y - y) ** 2
@ -78,6 +80,15 @@ def generatePath(start, end):
points.append(end) points.append(end)
return points return points
def angle(A, B):
ax = A.getX()
ay = A.getY()
bx = B.getX()
by = B.getY()
return math.atan2(by-ay, bx-ax)
class PetMoverAI(FSM): class PetMoverAI(FSM):
def __init__(self, pet): def __init__(self, pet):
self.pet = pet self.pet = pet
@ -97,9 +108,6 @@ class PetMoverAI(FSM):
def __moveFromStill(self, task=None): def __moveFromStill(self, task=None):
choices = ["Wander"] choices = ["Wander"]
# if self.pet._getNearbyAvatarDict():
# choices.append("Chase")
nextState = random.choice(choices) nextState = random.choice(choices)
self.request(nextState) self.request(nextState)
@ -113,9 +121,9 @@ class PetMoverAI(FSM):
def walkToPoint(self, target): def walkToPoint(self, target):
here = self.pet.getPos() here = self.pet.getPos()
dist = Vec3((here - target)).length() dist = Vec3(here - target).length()
dist = dist * 0.9
self.__seq = Sequence(Func(self.pet.lookAt, target), self.pet.posInterval(dist / self.fwdSpeed, target, here), self.__seq = Sequence(Func(self.pet.lookAt, target), Func(self.pet.setP, 0), self.pet.posInterval(dist / self.fwdSpeed, target, here),
Func(self.__stateComplete)) Func(self.__stateComplete))
self.__seq.start() self.__seq.start()
@ -156,8 +164,12 @@ class PetMoverAI(FSM):
target = hidden.attachNewNode('target') target = hidden.attachNewNode('target')
target.setPos(self.getPoint()) target.setPos(self.getPoint())
self.walkToPoint(target.getPos()) pos = target.getPos()
theta = angle(self.pet.getPos(), pos) * (math.pi / 180)
dx = dist * math.cos(theta)
dy = dist * math.sin(theta)
self.walkToPoint(Point3(pos.getX() - dx, pos.getY() - dy, pos.getZ()))
def exitChase(self): def exitChase(self):
if self.__chaseCallback: if self.__chaseCallback:

View file

@ -120,7 +120,8 @@ class PetTraits:
ToontownGlobals.DaisyGardens: (0.4, 0.75), ToontownGlobals.DaisyGardens: (0.4, 0.75),
ToontownGlobals.MinniesMelodyland: (0.5, 0.8), ToontownGlobals.MinniesMelodyland: (0.5, 0.8),
ToontownGlobals.TheBrrrgh: (0.6, 0.85), ToontownGlobals.TheBrrrgh: (0.6, 0.85),
ToontownGlobals.DonaldsDreamland: (0.7, 0.9)} ToontownGlobals.DonaldsDreamland: (0.7, 0.9),
ToontownGlobals.FunnyFarm: (0.8, 0.9)}
class StdDecDistrib(TraitDistribution): class StdDecDistrib(TraitDistribution):
TraitType = TraitDistribution.TraitTypes.DECREASING TraitType = TraitDistribution.TraitTypes.DECREASING
@ -129,7 +130,8 @@ class PetTraits:
ToontownGlobals.DaisyGardens: (0.25, 0.6), ToontownGlobals.DaisyGardens: (0.25, 0.6),
ToontownGlobals.MinniesMelodyland: (0.2, 0.5), ToontownGlobals.MinniesMelodyland: (0.2, 0.5),
ToontownGlobals.TheBrrrgh: (0.15, 0.4), ToontownGlobals.TheBrrrgh: (0.15, 0.4),
ToontownGlobals.DonaldsDreamland: (0.1, 0.3)} ToontownGlobals.DonaldsDreamland: (0.1, 0.3),
ToontownGlobals.FunnyFarm: (0.05, 0.2)}
class ForgetfulnessDistrib(TraitDistribution): class ForgetfulnessDistrib(TraitDistribution):
TraitType = TraitDistribution.TraitTypes.DECREASING TraitType = TraitDistribution.TraitTypes.DECREASING
@ -138,7 +140,8 @@ class PetTraits:
ToontownGlobals.DaisyGardens: (0.0, 0.8), ToontownGlobals.DaisyGardens: (0.0, 0.8),
ToontownGlobals.MinniesMelodyland: (0.0, 0.7), ToontownGlobals.MinniesMelodyland: (0.0, 0.7),
ToontownGlobals.TheBrrrgh: (0.0, 0.6), ToontownGlobals.TheBrrrgh: (0.0, 0.6),
ToontownGlobals.DonaldsDreamland: (0.0, 0.5)} ToontownGlobals.DonaldsDreamland: (0.0, 0.5),
ToontownGlobals.FunnyFarm: (0.0, 0.4)}
TraitDescs = (('forgetfulness', ForgetfulnessDistrib(), True), TraitDescs = (('forgetfulness', ForgetfulnessDistrib(), True),
('boredomThreshold', StdIncDistrib(), True), ('boredomThreshold', StdIncDistrib(), True),

View file

@ -1,12 +1,16 @@
from toontown.pets import PetDNA, PetTraits, PetConstants from toontown.pets import PetDNA, PetTraits, PetConstants
from toontown.toonbase import TTLocalizer
from direct.showbase import PythonUtil from direct.showbase import PythonUtil
from toontown.toonbase import TTLocalizer
import random
def getPetInfoFromSeed(seed, safezoneId): def getPetInfoFromSeed(seed, safezoneId):
dnaArray = PetDNA.getRandomPetDNA(seed, safezoneId) S = random.getstate()
random.seed(seed)
dnaArray = PetDNA.getRandomPetDNA(safezoneId)
gender = PetDNA.getGender(dnaArray) gender = PetDNA.getGender(dnaArray)
nameString = TTLocalizer.getRandomPetName(gender=gender, seed=seed) nameString = TTLocalizer.getRandomPetName(gender=gender, seed=seed)
traitSeed = PythonUtil.randUint31() traitSeed = PythonUtil.randUint31()
random.setstate(S)
return (nameString, dnaArray, traitSeed) return (nameString, dnaArray, traitSeed)

View file

@ -1,22 +1,23 @@
from direct.directnotify import DirectNotifyGlobal
from direct.gui.DirectGui import * from direct.gui.DirectGui import *
from direct.showbase.DirectObject import DirectObject
from pandac.PandaModules import * from pandac.PandaModules import *
import random from direct.directnotify import DirectNotifyGlobal
import string from direct.showbase.DirectObject import DirectObject
from toontown.toonbase import ToontownGlobals
from toontown.toonbase import TTLocalizer
from toontown.toonbase import ToontownTimer
from direct.task import Task
from otp.namepanel import NameTumbler
from otp.otpbase import OTPGlobals
from otp.otpbase import OTPLocalizer
from toontown.fishing import FishSellGUI from toontown.fishing import FishSellGUI
from toontown.hood import ZoneUtil
from toontown.pets import Pet, PetConstants from toontown.pets import Pet, PetConstants
from toontown.pets import PetDNA from toontown.pets import PetDNA
from toontown.pets import PetUtil
from toontown.pets import PetDetail from toontown.pets import PetDetail
from toontown.pets import PetTraits from toontown.pets import PetTraits
from toontown.pets import PetUtil from toontown.hood import ZoneUtil
from toontown.toonbase import TTLocalizer import string
from toontown.toonbase import ToontownGlobals import random
from toontown.toonbase import ToontownTimer
Dialog_MainMenu = 0 Dialog_MainMenu = 0
Dialog_AdoptPet = 1 Dialog_AdoptPet = 1
Dialog_ChoosePet = 2 Dialog_ChoosePet = 2
@ -46,6 +47,7 @@ class PetshopGUI(DirectObject):
self.bNo = DirectButton(self, image=(buttons.find('**/CloseBtn_UP'), buttons.find('**/CloseBtn_DN'), buttons.find('**/CloseBtn_Rllvr')), relief=None, text=TTLocalizer.TutorialNo, text_scale=0.05, text_pos=(0.0, -0.1), pos=(0.15, 0.0, -0.1), command=lambda : messenger.send(doneEvent, [0])) self.bNo = DirectButton(self, image=(buttons.find('**/CloseBtn_UP'), buttons.find('**/CloseBtn_DN'), buttons.find('**/CloseBtn_Rllvr')), relief=None, text=TTLocalizer.TutorialNo, text_scale=0.05, text_pos=(0.0, -0.1), pos=(0.15, 0.0, -0.1), command=lambda : messenger.send(doneEvent, [0]))
buttons.removeNode() buttons.removeNode()
gui.removeNode() gui.removeNode()
return
class NamePicker(DirectFrame): class NamePicker(DirectFrame):
notify = DirectNotifyGlobal.directNotify.newCategory('PetshopGUI.NamePicker') notify = DirectNotifyGlobal.directNotify.newCategory('PetshopGUI.NamePicker')
@ -91,6 +93,7 @@ class PetshopGUI(DirectObject):
cancelIcon = model.find('**/CancelIcon') cancelIcon = model.find('**/CancelIcon')
self.cancelButton = DirectButton(parent=self, relief=None, pos=(-0.04, 0, -0.47), image=cancelImageList, geom=cancelIcon, scale=modelScale, pressEffect=False, command=lambda : messenger.send(doneEvent, [-1])) self.cancelButton = DirectButton(parent=self, relief=None, pos=(-0.04, 0, -0.47), image=cancelImageList, geom=cancelIcon, scale=modelScale, pressEffect=False, command=lambda : messenger.send(doneEvent, [-1]))
self.randomName() self.randomName()
return
def destroy(self): def destroy(self):
self.petModel.delete() self.petModel.delete()
@ -192,6 +195,7 @@ class PetshopGUI(DirectObject):
if not base.localAvatar.hasPet(): if not base.localAvatar.hasPet():
self.returnPetButton['state'] = DGG.DISABLED self.returnPetButton['state'] = DGG.DISABLED
model.removeNode() model.removeNode()
return
class AdoptPetDlg(DirectFrame): class AdoptPetDlg(DirectFrame):
notify = DirectNotifyGlobal.directNotify.newCategory('PetshopGUI.AdoptPetDlg') notify = DirectNotifyGlobal.directNotify.newCategory('PetshopGUI.AdoptPetDlg')
@ -224,6 +228,7 @@ class PetshopGUI(DirectObject):
self.cancelButton = DirectButton(parent=self, relief=None, image=cancelImageList, geom=cancelIcon, scale=modelScale, text=('', TTLocalizer.PetshopGoBack), text_pos=(-5.8, 4.4), text_scale=0.7, pressEffect=False, command=lambda : messenger.send(doneEvent, [0])) self.cancelButton = DirectButton(parent=self, relief=None, image=cancelImageList, geom=cancelIcon, scale=modelScale, text=('', TTLocalizer.PetshopGoBack), text_pos=(-5.8, 4.4), text_scale=0.7, pressEffect=False, command=lambda : messenger.send(doneEvent, [0]))
self.okButton = DirectButton(parent=self, relief=None, image=okImageList, geom=checkIcon, scale=modelScale, text=('', TTLocalizer.PetshopAdopt), text_pos=(5.8, 4.4), text_scale=0.7, pressEffect=False, command=lambda : messenger.send(doneEvent, [1])) self.okButton = DirectButton(parent=self, relief=None, image=okImageList, geom=checkIcon, scale=modelScale, text=('', TTLocalizer.PetshopAdopt), text_pos=(5.8, 4.4), text_scale=0.7, pressEffect=False, command=lambda : messenger.send(doneEvent, [1]))
model.removeNode() model.removeNode()
return
def destroy(self): def destroy(self):
self.ignore(localAvatar.uniqueName('moneyChange')) self.ignore(localAvatar.uniqueName('moneyChange'))
@ -276,6 +281,7 @@ class PetshopGUI(DirectObject):
self.PetPanel = None self.PetPanel = None
self.petModel.delete() self.petModel.delete()
DirectFrame.destroy(self) DirectFrame.destroy(self)
return
class ChoosePetDlg(DirectFrame): class ChoosePetDlg(DirectFrame):
notify = DirectNotifyGlobal.directNotify.newCategory('PetshopGUI.ChoosePetDlg') notify = DirectNotifyGlobal.directNotify.newCategory('PetshopGUI.ChoosePetDlg')
@ -309,6 +315,7 @@ class PetshopGUI(DirectObject):
self.petSeeds = petSeeds self.petSeeds = petSeeds
self.makePetList() self.makePetList()
self.showPet() self.showPet()
return
def makePetList(self): def makePetList(self):
self.numPets = len(self.petSeeds) self.numPets = len(self.petSeeds)
@ -317,7 +324,7 @@ class PetshopGUI(DirectObject):
self.petName = [] self.petName = []
self.petDesc = [] self.petDesc = []
self.petCost = [] self.petCost = []
for i in xrange(self.numPets): for i in range(self.numPets):
random.seed(self.petSeeds[i]) random.seed(self.petSeeds[i])
zoneId = ZoneUtil.getCanonicalSafeZoneId(base.localAvatar.getZoneId()) zoneId = ZoneUtil.getCanonicalSafeZoneId(base.localAvatar.getZoneId())
name, dna, traitSeed = PetUtil.getPetInfoFromSeed(self.petSeeds[i], zoneId) name, dna, traitSeed = PetUtil.getPetInfoFromSeed(self.petSeeds[i], zoneId)
@ -372,6 +379,7 @@ class PetshopGUI(DirectObject):
self.okButton['state'] = DGG.DISABLED self.okButton['state'] = DGG.DISABLED
else: else:
self.okButton['state'] = DGG.NORMAL self.okButton['state'] = DGG.NORMAL
return
def __moneyChange(self, money): def __moneyChange(self, money):
self.moneyDisplay['text'] = str(base.localAvatar.getTotalMoney()) self.moneyDisplay['text'] = str(base.localAvatar.getTotalMoney())
@ -393,6 +401,7 @@ class PetshopGUI(DirectObject):
self.timer.posInTopRightCorner() self.timer.posInTopRightCorner()
self.timer.countdown(PetConstants.PETCLERK_TIMER, self.__timerExpired) self.timer.countdown(PetConstants.PETCLERK_TIMER, self.__timerExpired)
self.doDialog(Dialog_MainMenu) self.doDialog(Dialog_MainMenu)
return
def __timerExpired(self): def __timerExpired(self):
messenger.send(self.eventDict['guiDone'], [True]) messenger.send(self.eventDict['guiDone'], [True])
@ -413,6 +422,7 @@ class PetshopGUI(DirectObject):
if self.dialog != None: if self.dialog != None:
self.dialog.destroy() self.dialog.destroy()
self.dialog = None self.dialog = None
return
def popDialog(self): def popDialog(self):
self.dialogStack.pop() self.dialogStack.pop()
@ -495,6 +505,7 @@ class PetshopGUI(DirectObject):
self.notify.warning('Tried to go home, but place is None.') self.notify.warning('Tried to go home, but place is None.')
return return
place.goHomeNow(base.localAvatar.lastHood) place.goHomeNow(base.localAvatar.lastHood)
return
def __handleReturnPetDlg(self, exitVal): def __handleReturnPetDlg(self, exitVal):
if exitVal == 0: if exitVal == 0: