Group Manager

This commit is contained in:
John 2015-08-01 17:08:37 +03:00
parent e3c34e4fe8
commit d4557e69fa
17 changed files with 134 additions and 456 deletions

View file

@ -230,7 +230,6 @@ from toontown.estate import DistributedHouse/AI
from toontown.estate import DistributedHouseInterior/AI from toontown.estate import DistributedHouseInterior/AI
from toontown.estate import DistributedGarden/AI from toontown.estate import DistributedGarden/AI
from toontown.shtiker import DeleteManager/AI from toontown.shtiker import DeleteManager/AI
from toontown.groups import GroupManager/AI/UD
from toontown.ai import NewsManager/AI from toontown.ai import NewsManager/AI
from toontown.shtiker import PurchaseManager/AI from toontown.shtiker import PurchaseManager/AI
from toontown.shtiker import NewbiePurchaseManager/AI from toontown.shtiker import NewbiePurchaseManager/AI
@ -556,6 +555,7 @@ dclass ToontownDistrictStats : DistributedObject {
setDistrictId(uint32) broadcast required ram; setDistrictId(uint32) broadcast required ram;
setAvatarCount(uint32) broadcast required ram; setAvatarCount(uint32) broadcast required ram;
setInvasionStatus(uint8) broadcast required ram; setInvasionStatus(uint8) broadcast required ram;
setGroupAvCount(uint32[]) broadcast required ram;
}; };
dclass DistributedAnimatedProp : DistributedObject { dclass DistributedAnimatedProp : DistributedObject {
@ -1471,23 +1471,6 @@ dclass DeleteManager : DistributedObject {
setInventory(blob) airecv clsend; setInventory(blob) airecv clsend;
}; };
dclass GroupManager : DistributedObject {
setChildId() clsend airecv;
isPlayerGrouped(uint32);
isInGroup(uint32, uint32);
updateInfo() clsend airecv;
requestInfo() broadcast ram;
getTypeFromId(uint32);
setGroups(string) broadcast ram;
getGroups();
setGroupPlayers(string) broadcast ram;
getGroupPlayers(uint32);
createGroup(uint32, string) clsend airecv;
closeGroup(uint32) clsend airecv;
addPlayerToGroup(uint32, uint32) clsend airecv;
removePlayerFromGroup(uint32, uint32) clsend airecv;
};
dclass NewsManager : DistributedObject { dclass NewsManager : DistributedObject {
startHoliday(uint8) broadcast; startHoliday(uint8) broadcast;
endHoliday(uint8) broadcast; endHoliday(uint8) broadcast;

View file

@ -1,6 +1,5 @@
from direct.directnotify.DirectNotifyGlobal import directNotify from direct.directnotify.DirectNotifyGlobal import directNotify
from direct.distributed.DistributedObjectAI import DistributedObjectAI from direct.distributed.DistributedObjectAI import DistributedObjectAI
from toontown.toonbase import ToontownGlobals
class DistributedDistrictAI(DistributedObjectAI): class DistributedDistrictAI(DistributedObjectAI):
notify = directNotify.newCategory('DistributedDistrictAI') notify = directNotify.newCategory('DistributedDistrictAI')
@ -8,16 +7,6 @@ class DistributedDistrictAI(DistributedObjectAI):
name = 'District' name = 'District'
available = 0 available = 0
def announceGenerate(self):
DistributedObjectAI.announceGenerate(self)
doId = self.doId - (self.doId % 100000000 % 1000000)
self.air.groupManager.shardGroups[doId] = {
ToontownGlobals.SellbotHQ: ['VP Group', []],
ToontownGlobals.CashbotHQ: ['CFO Group', []],
ToontownGlobals.LawbotHQ: ['CJ Group', []],
ToontownGlobals.BossbotHQ: ['CEO Group', []],
}
def setName(self, name): def setName(self, name):
self.name = name self.name = name

View file

@ -1071,7 +1071,7 @@ class OTPClientRepository(ClientRepositoryBase):
for s in self.activeDistrictMap.values(): for s in self.activeDistrictMap.values():
if s.available: if s.available:
list.append((s.doId, s.name, s.avatarCount, s.invasionStatus)) list.append((s.doId, s.name, s.avatarCount, s.invasionStatus, s.groupAvCount))
return list return list

View file

@ -3,7 +3,6 @@ OTP_DO_ID_FRIEND_MANAGER = 4501
OTP_DO_ID_TOONTOWN = 1337 OTP_DO_ID_TOONTOWN = 1337
OTP_DO_ID_CLIENT_SERVICES_MANAGER = 4665 OTP_DO_ID_CLIENT_SERVICES_MANAGER = 4665
OTP_DO_ID_TTS_FRIENDS_MANAGER = 4666 OTP_DO_ID_TTS_FRIENDS_MANAGER = 4666
OPT_DO_ID_GROUP_MANAGER = 4667
OTP_DO_ID_GLOBAL_PARTY_MANAGER = 4477 OTP_DO_ID_GLOBAL_PARTY_MANAGER = 4477
OTP_DO_ID_GLOBAL_LOBBY_MANAGER = 4478 OTP_DO_ID_GLOBAL_LOBBY_MANAGER = 4478
OTP_DO_ID_CHAT_MANAGER = 4681 OTP_DO_ID_CHAT_MANAGER = 4681

View file

@ -46,7 +46,6 @@ from toontown.racing.LeaderboardMgrAI import LeaderboardMgrAI
from toontown.pets.PetManagerAI import PetManagerAI from toontown.pets.PetManagerAI import PetManagerAI
from toontown.safezone.SafeZoneManagerAI import SafeZoneManagerAI from toontown.safezone.SafeZoneManagerAI import SafeZoneManagerAI
from toontown.suit.SuitInvasionManagerAI import SuitInvasionManagerAI from toontown.suit.SuitInvasionManagerAI import SuitInvasionManagerAI
from toontown.groups.GroupManagerAI import GroupManagerAI
from toontown.toon import NPCToons from toontown.toon import NPCToons
from toontown.toonbase import ToontownGlobals from toontown.toonbase import ToontownGlobals
from toontown.tutorial.TutorialManagerAI import TutorialManagerAI from toontown.tutorial.TutorialManagerAI import TutorialManagerAI
@ -72,7 +71,6 @@ class ToontownAIRepository(ToontownInternalRepository):
self.mintMgr = None self.mintMgr = None
self.lawOfficeMgr = None self.lawOfficeMgr = None
self.countryClubMgr = None self.countryClubMgr = None
self.groupManager = GroupManagerAI(self)
self.zoneAllocator = UniqueIdAllocator(ToontownGlobals.DynamicZonesBegin, self.zoneAllocator = UniqueIdAllocator(ToontownGlobals.DynamicZonesBegin,
ToontownGlobals.DynamicZonesEnd) ToontownGlobals.DynamicZonesEnd)
@ -121,7 +119,6 @@ class ToontownAIRepository(ToontownInternalRepository):
self.codeRedemptionMgr.generateWithRequired(2) self.codeRedemptionMgr.generateWithRequired(2)
self.buildingQueryMgr = DistributedBuildingQueryMgrAI(self) self.buildingQueryMgr = DistributedBuildingQueryMgrAI(self)
self.buildingQueryMgr.generateWithRequired(2) self.buildingQueryMgr.generateWithRequired(2)
self.groupManager.generateWithRequired(2)
if self.wantTopToons: if self.wantTopToons:
self.topToonsMgr = TopToonsManagerAI(self) self.topToonsMgr = TopToonsManagerAI(self)
if self.wantKarts: if self.wantKarts:

View file

@ -10,3 +10,4 @@ class ToontownDistrict(DistributedDistrict.DistributedDistrict):
self.avatarCount = 0 self.avatarCount = 0
self.invasionStatus = 0 self.invasionStatus = 0
self.suitStatus = '' self.suitStatus = ''
self.groupAvCount = []

View file

@ -75,7 +75,14 @@ class ToontownDistrictStats(DistributedObject.DistributedObject):
def setAvatarCount(self, avatarCount): def setAvatarCount(self, avatarCount):
if self.districtId in self.cr.activeDistrictMap: if self.districtId in self.cr.activeDistrictMap:
self.cr.activeDistrictMap[self.districtId].avatarCount = avatarCount self.cr.activeDistrictMap[self.districtId].avatarCount = avatarCount
messenger.send('shardInfoUpdated')
def setInvasionStatus(self, invasionStatus): def setInvasionStatus(self, invasionStatus):
if self.districtId in self.cr.activeDistrictMap: if self.districtId in self.cr.activeDistrictMap:
self.cr.activeDistrictMap[self.districtId].invasionStatus = invasionStatus self.cr.activeDistrictMap[self.districtId].invasionStatus = invasionStatus
messenger.send('shardInfoUpdated')
def setGroupAvCount(self, groupAvCount):
if self.districtId in self.cr.activeDistrictMap:
self.cr.activeDistrictMap[self.districtId].groupAvCount = groupAvCount=
messenger.send('shardInfoUpdated')

View file

@ -1,5 +1,7 @@
from direct.directnotify.DirectNotifyGlobal import directNotify from direct.directnotify.DirectNotifyGlobal import directNotify
from direct.distributed.DistributedObjectAI import DistributedObjectAI from direct.distributed.DistributedObjectAI import DistributedObjectAI
from toontown.toonbase import ToontownGlobals
from toontown.toon import DistributedToonAI
class ToontownDistrictStatsAI(DistributedObjectAI): class ToontownDistrictStatsAI(DistributedObjectAI):
notify = directNotify.newCategory('ToontownDistrictStatsAI') notify = directNotify.newCategory('ToontownDistrictStatsAI')
@ -7,13 +9,19 @@ class ToontownDistrictStatsAI(DistributedObjectAI):
districtId = 0 districtId = 0
avatarCount = 0 avatarCount = 0
invasionStatus = 0 invasionStatus = 0
groupAvCount = [0] * len(ToontownGlobals.GROUP_ZONES)
def announceGenerate(self): def announceGenerate(self):
DistributedObjectAI.announceGenerate(self) DistributedObjectAI.announceGenerate(self)
# We want to handle shard status queries so that a ShardStatusReceiver # We want to handle shard status queries so that a ShardStatusReceiver
# being created after we're generated will know where we're at: # being created after we're generated will know where we're at:
self.air.accept('shardStatus', self.handleShardStatusQuery) self.air.accept('queryShardStatus', self.handleShardStatusQuery)
taskMgr.doMethodLater(15, self.__countGroups, self.uniqueName('countGroups'))
def delete(self):
taskMgr.remove(self.uniqueName('countGroups'))
DistributedObjectAI.delete(self)
def handleShardStatusQuery(self): def handleShardStatusQuery(self):
# Send a shard status update containing our population: # Send a shard status update containing our population:
@ -62,3 +70,27 @@ class ToontownDistrictStatsAI(DistributedObjectAI):
def getInvasionStatus(self): def getInvasionStatus(self):
return self.invasionStatus return self.invasionStatus
def setGroupAvCount(self, groupAvCount):
self.groupAvCount = groupAvCount
def d_setGroupAvCount(self, groupAvCount):
self.sendUpdate('setGroupAvCount', [groupAvCount])
def b_setGroupAvCount(self, groupAvCount):
self.setGroupAvCount(groupAvCount)
self.d_setGroupAvCount(groupAvCount)
def getGroupAvCount(self):
return self.groupAvCount
def __countGroups(self, task):
zones = ToontownGlobals.GROUP_ZONES
self.groupAvCount = [0] * len(zones)
for av in self.air.doId2do.values():
if isinstance(av, DistributedToonAI.DistributedToonAI) and av.isPlayerControlled() and av.zoneId in zones:
self.groupAvCount[zones.index(av.zoneId)] += 1
taskMgr.doMethodLater(15, self.__countGroups, self.uniqueName('countGroups'))
self.b_setGroupAvCount(self.groupAvCount)

View file

@ -1,20 +0,0 @@
class GlobalGroup:
def __init__(self, groupType, groupId):
self.activePlayers = []
self.groupType = groupType
self.groupId = groupId
def getGroupPlayers(self):
return self.activePlayers
def isInGroup(self, avId):
if avId in self.activePlayers:
return True
return False
def addPlayerToGroup(self, avId):
self.activePlayers.append(avId)
def removePlayerFromGroup(self, avId):
self.activePlayers.remove(avId)

View file

@ -1,78 +0,0 @@
from panda3d.core import *
from direct.distributed import DistributedObject
from direct.directnotify import DirectNotifyGlobal
from toontown.toonbase.ToontownGlobals import *
class GroupManager(DistributedObject.DistributedObject):
notify = DirectNotifyGlobal.directNotify.newCategory('GroupManager')
neverDisable = 1
def __init__(self, cr):
DistributedObject.DistributedObject.__init__(self, cr)
self.shardGroups = {}
self.groupPlayers = {}
self.id2type = {
SellbotHQ: 'VP',
CashbotHQ: 'CFO',
LawbotHQ: 'CJ',
BossbotHQ: 'CEO',
}
def announceGenerate(self):
DistributedObject.DistributedObject.announceGenerate(self)
self.cr.groupManager = self
self.d_setChildId()
def delete(self):
DistributedObject.DistributedObject.delete(self)
self.cr.groupManager = None
def d_setChildId(self):
self.sendUpdate('setChildId', [])
def isPlayerGrouped(self, avId):
for group in self.groupPlayers.values():
if avId in group:
return True
return False
def isInGroup(self, avId, groupId):
group = self.groupPlayers.get(groupId)
if group is None:
return False
if avId in group:
return True
return False
def requestInfo(self):
self.sendUpdate('updateInfo', [])
def getTypeFromId(self, groupId):
return self.id2type.get(groupId)
def setGroups(self, shardGroups):
self.shardGroups = eval(shardGroups)
def getGroups(self):
return self.shardGroups
def setGroupPlayers(self, groupPlayers):
self.groupPlayers = eval(groupPlayers)
def getGroupPlayers(self, groupId):
group = self.groupPlayers.get(groupId)
if group is None:
return []
return group
def d_createGroup(self, groupId, groupType):
self.sendUpdate('createGroup', [groupId, groupType])
def d_closeGroup(self, groupId):
self.sendUpdate('closeGroup', [groupId])
def d_addPlayerToGroup(self, groupId, avId):
self.sendUpdate('addPlayerToGroup', [groupId, avId])
def d_removePlayerFromGroup(self, groupId, avId):
self.sendUpdate('removePlayerFromGroup', [groupId, avId])

View file

@ -1,129 +0,0 @@
from panda3d.core import *
from direct.task import Task
from direct.distributed import DistributedObjectAI
from direct.directnotify import DirectNotifyGlobal
from toontown.toonbase.ToontownGlobals import *
from GlobalGroup import GlobalGroup
class GroupManagerAI(DistributedObjectAI.DistributedObjectAI):
notify = DirectNotifyGlobal.directNotify.newCategory('GroupManagerAI')
def __init__(self, air):
DistributedObjectAI.DistributedObjectAI.__init__(self, air)
self.sellGroup = GlobalGroup('VP', SellbotHQ)
self.cashGroup = GlobalGroup('CFO', CashbotHQ)
self.lawGroup = GlobalGroup('CJ', LawbotHQ)
self.bossGroup = GlobalGroup('CEO', BossbotHQ)
self.shardGroups = {
SellbotHQ: self.sellGroup,
CashbotHQ: self.cashGroup,
LawbotHQ: self.lawGroup,
BossbotHQ: self.bossGroup,
}
self.groupPlayers = {
SellbotHQ: [],
CashbotHQ: [],
LawbotHQ: [],
BossbotHQ: [],
}
self.id2type = {
SellbotHQ: 'VP',
CashbotHQ: 'CFO',
LawbotHQ: 'CJ',
BossbotHQ: 'CEO',
}
self.childId = None
def announceGenerate(self):
DistributedObjectAI.DistributedObjectAI.announceGenerate(self)
self.air.groupManager = self
self.confirmActiveToons = taskMgr.doMethodLater(45, self.confirmToonsInGroup, 'confirmActiveToons')
def delete(self):
DistributedObjectAI.DistributedObjectAI.delete(self)
taskMgr.remove('confirmActiveToons')
self.air.groupManager = None
def setChildId(self):
doId = self.air.getAvatarIdFromSender()
self.childId = doId
self.sendUpdateToAvatarId(self.childId, 'requestInfo', [])
def isPlayerGrouped(self, avId):
for group in self.shardGroups.values():
if avId in group.getGroupPlayers():
return True
return False
def isInGroup(self, avId, groupId):
group = self.shardGroups.get(groupId)
if group is None:
return False
if avId in group.getGroupPlayers():
return True
return False
def confirmToonsInGroup(self, task):
for groupId, group in self.groupPlayers.items():
for player in group:
toon = simbase.air.doId2do.get(player)
if (toon.zoneId != groupId) or (toon.zoneId + 100 != groupId):
self.removePlayerFromGroup(groupId, player)
return task.again
def updateInfo(self):
self.d_setGroupPlayers(str(self.groupPlayers))
self.d_setGroups(str(self.id2type))
def getTypeFromId(self, groupId):
return self.id2type.get(groupId)
def d_setGroups(self, shardGroups):
self.sendUpdateToAvatarId(self.childId, 'setGroups', [shardGroups])
def getGroups(self):
return self.shardGroups
def d_setGroupPlayers(self, groupPlayers):
self.sendUpdateToAvatarId(self.childId, 'setGroupPlayers', [groupPlayers])
def getGroupPlayers(self, groupId):
group = self.shardGroups.get(groupId)
if group is None:
return []
players = group.getGroupPlayers()
return players
def createGroup(self, groupId, groupType):
group = self.shardGroups.get(groupId)
if group is not None:
newGroup = DistributedGlobalGroupAI(self.air, groupType, groupId)
self.shardGroups.update(groupId, newGroup)
players = {groupId: self.getGroupPlayers(groupId)}
self.groupPlayers.update(players)
self.updateInfo()
def closeGroup(self, groupId):
group = self.shardGroups.get(groupId)
if group is not None:
self.shardGroups.pop(groupId)
self.groupPlayers.pop(groupId)
self.updateInfo()
def addPlayerToGroup(self, groupId, avId):
group = self.shardGroups.get(groupId)
if group is not None:
if not group.isInGroup(avId):
group.addPlayerToGroup(avId)
players = {groupId: self.getGroupPlayers(groupId)}
self.groupPlayers.update(players)
self.updateInfo()
def removePlayerFromGroup(self, groupId, avId):
group = self.shardGroups.get(groupId)
if group is not None:
if group.isInGroup(avId):
group.removePlayerFromGroup(avId)
players = {groupId: self.getGroupPlayers(groupId)}
self.groupPlayers.update(players)
self.updateInfo()

View file

@ -1,14 +0,0 @@
from direct.distributed import DistributedObjectUD
from direct.directnotify import DirectNotifyGlobal
class GroupManagerUD(DistributedObjectUD.DistributedObjectUD):
notify = DirectNotifyGlobal.directNotify.newCategory('GroupManagerUD')
def __init__(self, air):
DistributedObjectUD.DistributedObjectUD.__init__(self, air)
def announceGenerate(self):
DistributedObjectUD.DistributedObjectUD.announceGenerate(self)
def delete(self):
DistributedObjectUD.DistributedObjectUD.delete(self)

View file

@ -82,8 +82,9 @@ class ShardPage(ShtikerPage.ShtikerPage):
self.showPop = config.GetBool('show-population', 0) self.showPop = config.GetBool('show-population', 0)
self.showTotalPop = config.GetBool('show-total-population', 0) self.showTotalPop = config.GetBool('show-total-population', 0)
self.noTeleport = config.GetBool('shard-page-disable', 0) self.noTeleport = config.GetBool('shard-page-disable', 0)
self.shardGroups = None self.shardGroups = []
self.currentGroupJoined = None self.shardText = []
self.groupDialog = None
def load(self): def load(self):
main_text_scale = 0.06 main_text_scale = 0.06
@ -117,7 +118,7 @@ class ShardPage(ShtikerPage.ShtikerPage):
curShardTuples.sort(compareShardTuples) curShardTuples.sort(compareShardTuples)
actualShardId = base.localAvatar.defaultShard actualShardId = base.localAvatar.defaultShard
for i in xrange(len(curShardTuples)): for i in xrange(len(curShardTuples)):
shardId, name, pop, invasionStatus = curShardTuples[i] shardId, name, pop, invasionStatus, groupAvCount = curShardTuples[i]
if shardId == actualShardId: if shardId == actualShardId:
self.currentBTP = buttonTuple[0] self.currentBTP = buttonTuple[0]
self.currentBTL = buttonTuple[1] self.currentBTL = buttonTuple[1]
@ -126,7 +127,7 @@ class ShardPage(ShtikerPage.ShtikerPage):
self.currentO = [pop, name, shardId] self.currentO = [pop, name, shardId]
self.currentBTL['state'] = DGG.DISABLED self.currentBTL['state'] = DGG.DISABLED
self.currentBTR['state'] = DGG.DISABLED self.currentBTR['state'] = DGG.DISABLED
self.reloadRightBrain(pop, name, shardId, buttonTuple) self.reloadRightBrain(pop, name, groupAvCount, shardId, buttonTuple)
def unload(self): def unload(self):
self.gui.removeNode() self.gui.removeNode()
@ -165,7 +166,7 @@ class ShardPage(ShtikerPage.ShtikerPage):
taskMgr.doMethodLater(self.ShardInfoUpdateInterval, self.askForShardInfoUpdate, 'ShardPageUpdateTask-doLater') taskMgr.doMethodLater(self.ShardInfoUpdateInterval, self.askForShardInfoUpdate, 'ShardPageUpdateTask-doLater')
return Task.done return Task.done
def makeShardButton(self, shardId, shardName, shardPop): def makeShardButton(self, shardId, groupAvCount, shardName, shardPop):
shardButtonParent = DirectFrame() shardButtonParent = DirectFrame()
shardButtonL = DirectButton(parent=shardButtonParent, relief=None, text=shardName, text_scale=0.06, text_align=TextNode.ALeft, text_fg=Vec4(0, 0, 0, 1), text3_fg=self.textDisabledColor, text1_bg=self.textDownColor, text2_bg=self.textRolloverColor, textMayChange=0, command=self.reloadRightBrain) shardButtonL = DirectButton(parent=shardButtonParent, relief=None, text=shardName, text_scale=0.06, text_align=TextNode.ALeft, text_fg=Vec4(0, 0, 0, 1), text3_fg=self.textDisabledColor, text1_bg=self.textDownColor, text2_bg=self.textRolloverColor, textMayChange=0, command=self.reloadRightBrain)
popText = str(shardPop) popText = str(shardPop)
@ -191,59 +192,62 @@ class ShardPage(ShtikerPage.ShtikerPage):
invasionMarker.reparentTo(shardButtonParent) invasionMarker.reparentTo(shardButtonParent)
buttonTuple = (shardButtonParent, shardButtonR, shardButtonL, invasionMarker) buttonTuple = (shardButtonParent, shardButtonR, shardButtonL, invasionMarker)
shardButtonL['extraArgs'] = extraArgs=[shardPop, shardName, shardId, buttonTuple] shardButtonL['extraArgs'] = extraArgs=[shardPop, shardName, groupAvCount, shardId, buttonTuple]
shardButtonR['extraArgs'] = extraArgs=[shardPop, shardName, shardId, buttonTuple] shardButtonR['extraArgs'] = extraArgs=[shardPop, shardName, groupAvCount, shardId, buttonTuple]
return buttonTuple return buttonTuple
def makeGroupButton(self, groupId, groupType): def makeGroupButton(self, shardId, group, population):
groupPop = len(base.cr.groupManager.getGroupPlayers(groupId))
groupButtonParent = DirectFrame() groupButtonParent = DirectFrame()
groupButtonL = DirectButton(parent=groupButtonParent, relief=None, text=groupType, text_pos=(0.0, -0.0225), text_scale=0.06, text_align=TextNode.ALeft, text_fg=Vec4(0, 0, 0, 1), text3_fg=self.textDisabledColor, text1_bg=self.textDownColor, text2_bg=self.textRolloverColor, textMayChange=0, command=self.joinGroup) groupButtonL = DirectButton(parent=groupButtonParent, relief=None, text=TTLocalizer.GlobalStreetNames[group][-1], text_pos=(0.0, -0.0225), text_scale=0.048, text_align=TextNode.ALeft, text_fg=Vec4(0, 0, 0, 1), text3_fg=self.textDisabledColor, text1_bg=self.textDownColor, text2_bg=self.textRolloverColor, command=self.joinGroup, extraArgs=[group, shardId])
popText = str(groupPop)
if popText is None:
return
model = loader.loadModel('phase_3.5/models/gui/matching_game_gui')
button = model.find('**/minnieCircle')
groupButtonR = DirectButton(parent=groupButtonParent, relief=None, groupButtonR = DirectButton(parent=groupButtonParent, relief=None,
image=button,
image_scale=(0.3, 1, 0.3),
image2_scale=(0.35, 1, 0.35),
image_color=Vec4(0, 0.8, 0, 1),
pos=(0.58, 0, -0.0125), pos=(0.58, 0, -0.0125),
text=popText, text=str(population),
text_scale=0.055, text_scale=0.055,
text_align=TextNode.ACenter, text_align=TextNode.ACenter,
text_pos=(-0.00575, -0.0125), text_fg=Vec4(0, 0, 0, 1), text3_fg=Vec4(0, 0, 0, 1), text1_bg=self.textRolloverColor, text2_bg=self.textRolloverColor, textMayChange=1) command=self.joinGroup,
extraArgs=[group, shardId],
text_pos=(-0.00575, -0.0125), text_fg=Vec4(0, 0, 0, 1), text3_fg=Vec4(0, 0, 0, 1), text1_bg=self.textRolloverColor, text2_bg=self.textRolloverColor)
leaveButton = DirectButton(parent=groupButtonParent, relief=None, return (groupButtonParent, groupButtonL, groupButtonR)
image=button,
image_scale=(0.3, 1, 0.3),
image2_scale=(0.35, 1, 0.35),
image_color=Vec4(0, 0.8, 0, 1),
pos=(0.50, 0, -0.0125),
text='Leave',
text_scale=0.055,
text_align=TextNode.ACenter,
text_pos=(-0.00575, -0.0125),
text_fg=Vec4(0, 0, 0, 0),
text2_fg=Vec4(0, 0, 0, 1),
command=self.leaveGroup)
leaveButton.hide() def joinGroup(self, group, shardId):
model.removeNode() canonicalHoodId = ZoneUtil.getCanonicalHoodId(group)
button.removeNode() shardName = base.cr.activeDistrictMap[shardId].name
hoodName = TTLocalizer.GlobalStreetNames[canonicalHoodId]
teleportAccess = base.localAvatar.hasTeleportAccess(canonicalHoodId)
buttonTuple = (groupButtonParent, groupButtonR, groupButtonL, leaveButton) if teleportAccess:
groupButtonL['extraArgs'] = [groupId, buttonTuple] message = TTLocalizer.GroupAskAccess
leaveButton['extraArgs'] = [groupId, buttonTuple] elif base.localAvatar.defaultShard == shardId:
return buttonTuple self.acceptOnce('groupDialogDone', self.cleanupGroupDialog)
self.groupDialog = TTDialog.TTGlobalDialog(style=TTDialog.Acknowledge, text=TTLocalizer.GroupAskNoAccessSame % (hoodName[0], hoodName[-1]), doneEvent='groupDialogDone')
self.groupDialog.show()
return
else:
message = TTLocalizer.GroupAskNoAccess
self.acceptOnce('groupDialogDone', self.__handleGroupDialog, extraArgs=[canonicalHoodId if teleportAccess else base.localAvatar.lastHood, shardId])
self.groupDialog = TTDialog.TTGlobalDialog(style=TTDialog.TwoChoice, text=message % (hoodName[0], hoodName[-1], shardName), doneEvent='groupDialogDone')
self.groupDialog.show()
def cleanupGroupDialog(self):
self.ignore('groupDialogDone')
self.groupDialog.cleanup()
del self.groupDialog
def __handleGroupDialog(self, canonicalHoodId, shardId):
response = self.groupDialog.doneStatus
self.cleanupGroupDialog()
if response == 'ok':
self.requestTeleport(canonicalHoodId, shardId)
def removeRightBrain(self): def removeRightBrain(self):
self.districtInfo.find('**/*district-info').removeNode() self.districtInfo.find('**/*district-info').removeNode()
def reloadRightBrain(self, shardPop, shardName, shardId, buttonTuple): def reloadRightBrain(self, shardPop, shardName, groupAvCount, shardId, buttonTuple):
self.currentRightBrain = (shardPop, shardName, shardId, buttonTuple) self.currentRightBrain = (shardPop, shardName, shardId, buttonTuple)
if self.districtInfo.find('**/*district-info'): if self.districtInfo.find('**/*district-info'):
self.removeRightBrain() self.removeRightBrain()
@ -272,36 +276,31 @@ class ShardPage(ShtikerPage.ShtikerPage):
if shardId == base.localAvatar.defaultShard: if shardId == base.localAvatar.defaultShard:
self.shardTeleportButton['state'] = DGG.DISABLED self.shardTeleportButton['state'] = DGG.DISABLED
if self.shardGroups is not None: for button in self.shardGroups + self.shardText:
for button in self.shardGroups: button.removeNode()
button.detachNode()
self.shardGroups = [] self.shardGroups = []
self.shardText = []
for gid, gtype in base.cr.groupManager.id2type.items(): for i, group in enumerate(ToontownGlobals.GROUP_ZONES):
btuple = self.makeGroupButton(gid, gtype) btuple = self.makeGroupButton(shardId, group, groupAvCount[i])
if base.cr.groupManager.isInGroup(base.localAvatar.doId, gid): if ZoneUtil.getCanonicalHoodId(base.localAvatar.zoneId) == ZoneUtil.getCanonicalHoodId(group):
btuple[1]['state'] = DGG.DISABLED btuple[1]['state'] = DGG.DISABLED
btuple[2]['state'] = DGG.DISABLED btuple[2]['state'] = DGG.DISABLED
btuple[3].show()
self.shardGroups.append(btuple[0]) self.shardGroups.append(btuple[0])
self.shardText.append(btuple[2])
buttonImage = (self.gui.find('**/FndsLst_ScrollUp'), self.gui.find('**/FndsLst_ScrollDN'), self.gui.find('**/FndsLst_ScrollUp_Rllvr'), self.gui.find('**/FndsLst_ScrollUp'))
self.districtGroups = DirectScrolledList(parent=districtInfoNode, relief=None, self.districtGroups = DirectScrolledList(parent=districtInfoNode, relief=None,
pos=(0.38, 0, -0.34), pos=(0.38, 0, -0.34),
incButton_image=(self.gui.find('**/FndsLst_ScrollUp'), incButton_image=buttonImage,
self.gui.find('**/FndsLst_ScrollDN'),
self.gui.find('**/FndsLst_ScrollUp_Rllvr'),
self.gui.find('**/FndsLst_ScrollUp')),
incButton_relief=None, incButton_relief=None,
incButton_scale=(self.arrowButtonScale, incButton_scale=(self.arrowButtonScale,
self.arrowButtonScale, self.arrowButtonScale,
-self.arrowButtonScale), -self.arrowButtonScale),
incButton_pos=(self.buttonXstart + 0.005, 0, -0.125), incButton_pos=(self.buttonXstart + 0.005, 0, -0.125),
incButton_image3_color=Vec4(1, 1, 1, 0.2), incButton_image3_color=Vec4(1, 1, 1, 0.2),
decButton_image=(self.gui.find('**/FndsLst_ScrollUp'), decButton_image=buttonImage,
self.gui.find('**/FndsLst_ScrollDN'),
self.gui.find('**/FndsLst_ScrollUp_Rllvr'),
self.gui.find('**/FndsLst_ScrollUp')),
decButton_relief=None, decButton_relief=None,
decButton_scale=(self.arrowButtonScale, decButton_scale=(self.arrowButtonScale,
self.arrowButtonScale, self.arrowButtonScale,
@ -317,103 +316,10 @@ class ShardPage(ShtikerPage.ShtikerPage):
(self.listZorigin + self.listFrameSizeZ)/2.1), (self.listZorigin + self.listFrameSizeZ)/2.1),
itemFrame_frameColor=(0.85, 0.95, 1, 1), itemFrame_frameColor=(0.85, 0.95, 1, 1),
itemFrame_borderWidth=(0.01, 0.01), itemFrame_borderWidth=(0.01, 0.01),
numItemsVisible=15, numItemsVisible=7,
forceHeight=0.065, forceHeight=0.065,
items=self.shardGroups) items=self.shardGroups)
def joinGroup(self, groupId, buttonTuple):
self.acceptOnce('confJoin', self.confirmJoinGroup, extraArgs=[groupId, buttonTuple])
self.joinDialog = TTDialog.TTGlobalDialog(message='Would you like to join this group?', doneEvent='confJoin', style=4)
def rejectGroup(self, reason, suitType=0):
self.acceptOnce('remRjD', self.doneReject)
if reason == 1:
self.rejectDialog = TTDialog.TTGlobalDialog(message='You need more suit parts!', doneEvent='remRjD', style=1)
elif reason == 2:
if suitType == 0:
meritType = 'Stock Options'
elif suitType == 1:
meritType = 'Merits'
elif suitType == 2:
meritType = 'Cogbucks'
elif suitType == 3:
meritType = 'Notices'
self.rejectDialog = TTDialog.TTGlobalDialog(message='You need more %s!'%meritType, doneEvent='remRjD', style=1)
elif reason == 3:
self.rejectDialog = TTDialog.TTGlobalDialog(message='That group is full!', doneEvent='remRjD', style=1)
elif reason == 4:
self.rejectDialog = TTDialog.TTGlobalDialog(message='You\'re already in a group!', doneEvent='remRjD', style=1)
elif reason == 5:
self.rejectDialog = TTDialog.TTGlobalDialog(message='You can\'t leave the district while you\'re in a group!', doneEvent='remRjD', style=1)
def doneReject(self):
self.rejectDialog.cleanup()
del self.rejectDialog
def confirmJoinGroup(self, groupId, buttonTuple):
doneStatus = self.joinDialog.doneStatus
self.joinDialog.cleanup()
del self.joinDialog
if doneStatus is not 'ok':
return
for gid in base.cr.groupManager.id2type.keys():
if base.cr.groupManager.isInGroup(base.localAvatar.doId, gid):
self.rejectGroup(4)
return
#if len(base.cr.groupManager.getGroupPlayers(groupId)) >= 8:
# self.rejectGroup(3)
# return
suitIdx = -1
gids = {10000:0, 11000:1, 12000:2, 13000:3}
suitIdx = gids.get(groupId)
if suitIdx is not None:
merits = base.localAvatar.cogMerits[suitIdx]
if CogDisguiseGlobals.getTotalMerits(base.localAvatar, suitIdx) > merits:
self.rejectGroup(2, suitIdx)
return
parts = base.localAvatar.getCogParts()
if not CogDisguiseGlobals.isSuitComplete(parts, suitIdx):
self.rejectGroup(1)
return
base.cr.groupManager.d_addPlayerToGroup(groupId, base.localAvatar.doId)
self.currentGroupJoined = groupId
try:
place = base.cr.playGame.getPlace()
except:
try:
place = base.cr.playGame.hood.loader.place
except:
place = base.cr.playGame.hood.place
place.requestTeleport(groupId, groupId, base.localAvatar.defaultShard, -1)
def leaveGroup(self, groupId, buttonTuple):
self.acceptOnce('confLeave', self.confirmLeaveGroup, extraArgs=[groupId, buttonTuple])
self.joinDialog = TTDialog.TTGlobalDialog(message='Are you sure you want to leave this group?', doneEvent='confLeave', style=4)
def confirmLeaveGroup(self, groupId, buttonTuple):
doneStatus = self.joinDialog.doneStatus
self.joinDialog.cleanup()
del self.joinDialog
if doneStatus is not 'ok':
return
if not base.cr.groupManager.isInGroup(base.localAvatar.doId, groupId):
return
base.cr.groupManager.d_removePlayerFromGroup(groupId, base.localAvatar.doId)
self.currentGroupJoined = None
try:
place = base.cr.playGame.getPlace()
except:
try:
place = base.cr.playGame.hood.loader.place
except:
place = base.cr.playGame.hood.place
hoodId = -1
gids = {10000:1000, 11000:5000, 12000:9000, 13000:3000}
hoodId = gids.get(groupId)
if hoodId is None:
return
place.requestTeleport(hoodId, hoodId, base.localAvatar.defaultShard, -1)
def getPopColor(self, pop): def getPopColor(self, pop):
if pop <= self.lowPop: if pop <= self.lowPop:
newColor = POP_COLORS[0] newColor = POP_COLORS[0]
@ -483,7 +389,7 @@ class ShardPage(ShtikerPage.ShtikerPage):
for i in xrange(len(curShardTuples)): for i in xrange(len(curShardTuples)):
shardId, name, pop, invasionStatus = curShardTuples[i] shardId, name, pop, invasionStatus, groupAvCount = curShardTuples[i]
if shardId == actualShardId: if shardId == actualShardId:
actualShardName = name actualShardName = name
@ -493,16 +399,19 @@ class ShardPage(ShtikerPage.ShtikerPage):
buttonTuple = self.shardButtonMap.get(shardId) buttonTuple = self.shardButtonMap.get(shardId)
if buttonTuple == None: if buttonTuple == None:
buttonTuple = self.makeShardButton(shardId, name, pop) buttonTuple = self.makeShardButton(shardId, groupAvCount, name, pop)
self.shardButtonMap[shardId] = buttonTuple self.shardButtonMap[shardId] = buttonTuple
anyChanges = 1 anyChanges = 1
else: else:
buttonTuple[1]['image_color'] = self.getPopColor(pop) buttonTuple[1]['image_color'] = self.getPopColor(pop)
buttonTuple[1]['text'] = str(pop) buttonTuple[1]['text'] = str(pop)
buttonTuple[1]['command'] = self.reloadRightBrain buttonTuple[1]['command'] = self.reloadRightBrain
buttonTuple[1]['extraArgs'] = [pop, name, shardId, buttonTuple] buttonTuple[1]['extraArgs'] = [pop, name, groupAvCount, shardId, buttonTuple]
buttonTuple[2]['command'] = self.reloadRightBrain buttonTuple[2]['command'] = self.reloadRightBrain
buttonTuple[2]['extraArgs'] = [pop, name, shardId, buttonTuple] buttonTuple[2]['extraArgs'] = [pop, name, groupAvCount, shardId, buttonTuple]
for i, button in enumerate(self.shardText):
button['text'] = str(groupAvCount[i])
self.shardButtons.append(buttonTuple[0]) self.shardButtons.append(buttonTuple[0])
@ -563,16 +472,12 @@ class ShardPage(ShtikerPage.ShtikerPage):
del self.confirm del self.confirm
def choseShard(self, shardId): def choseShard(self, shardId):
zoneId = self.getCurrentZoneId() if not base.localAvatar.defaultShard == shardId:
canonicalHoodId = ZoneUtil.getCanonicalHoodId(base.localAvatar.lastHood) self.requestTeleport(base.localAvatar.lastHood, shardId)
currentShardId = base.localAvatar.defaultShard
def requestTeleport(self, hood, shardId):
canonicalHoodId = ZoneUtil.getCanonicalHoodId(hood)
if self.currentGroupJoined:
self.rejectGroup(5)
return
if shardId == currentShardId:
return
else:
try: try:
place = base.cr.playGame.getPlace() place = base.cr.playGame.getPlace()
except: except:
@ -580,4 +485,5 @@ class ShardPage(ShtikerPage.ShtikerPage):
place = base.cr.playGame.hood.loader.place place = base.cr.playGame.hood.loader.place
except: except:
place = base.cr.playGame.hood.place place = base.cr.playGame.hood.place
place.requestTeleport(canonicalHoodId, canonicalHoodId, shardId, -1) place.requestTeleport(canonicalHoodId, canonicalHoodId, shardId, -1)

View file

@ -95,23 +95,23 @@ GlobalStreetNames = {20000: ('to', 'on', 'Tutorial Terrace'),
9100: ('to', 'on', 'Lullaby Lane'), 9100: ('to', 'on', 'Lullaby Lane'),
9200: ('to', 'on', 'Pajama Place'), 9200: ('to', 'on', 'Pajama Place'),
9300: ('to', 'on', 'Bedtime Boulevard'), 9300: ('to', 'on', 'Bedtime Boulevard'),
10000: ('to', 'in', 'Bossbot HQ Country Club'), 10000: ('to the', 'in the', 'Bossbot HQ Country Club'),
10100: ('to the', 'in the', 'Bossbot HQ Lobby'), 10100: ('to the', 'in the', 'Bossbot HQ Lobby'),
10200: ('to the', 'in the', 'The Clubhouse'), 10200: ('to', 'in', 'The Clubhouse'),
10500: ('to the', 'in the', 'The Front Three'), 10500: ('to', 'in', 'The Front Three'),
10600: ('to the', 'in the', 'The Middle Six'), 10600: ('to', 'in', 'The Middle Six'),
10700: ('to the', 'in the', 'The Back Nine'), 10700: ('to', 'in', 'The Back Nine'),
11000: ('to the', 'in the', 'Sellbot HQ Courtyard'), 11000: ('to the', 'in the', 'Sellbot HQ Courtyard'),
11100: ('to the', 'in the', 'Sellbot HQ Lobby'), 11100: ('to the', 'in the', 'Sellbot HQ Lobby'),
11200: ('to the', 'in the', 'Sellbot Factory'), 11200: ('to the', 'in the', 'Sellbot Factory'),
11500: ('to the', 'in the', 'Sellbot Factory'), 11500: ('to the', 'in the', 'Sellbot Factory'),
11600: ('to the', 'in the', 'Sellbot Megacorp'), 11600: ('to the', 'in the', 'Sellbot Megacorp'),
12000: ('to', 'in', 'Cashbot Train Yard'), 12000: ('to the', 'in the', 'Cashbot Train Yard'),
12100: ('to the', 'in the', 'Cashbot HQ Lobby'), 12100: ('to the', 'in the', 'Cashbot HQ Lobby'),
12500: ('to the', 'in the', 'Cashbot Coin Mint'), 12500: ('to the', 'in the', 'Cashbot Coin Mint'),
12600: ('to the', 'in the', 'Cashbot Dollar Mint'), 12600: ('to the', 'in the', 'Cashbot Dollar Mint'),
12700: ('to the', 'in the', 'Cashbot Bullion Mint'), 12700: ('to the', 'in the', 'Cashbot Bullion Mint'),
13000: ('to', 'in', 'Lawbot HQ Courtyard'), 13000: ('to the', 'in the', 'Lawbot HQ Courtyard'),
13100: ('to the', 'in the', 'Courthouse Lobby'), 13100: ('to the', 'in the', 'Courthouse Lobby'),
13200: ('to the', 'in the', "DA's Office Lobby"), 13200: ('to the', 'in the', "DA's Office Lobby"),
13300: ('to the', 'in the', 'Lawbot A Office'), 13300: ('to the', 'in the', 'Lawbot A Office'),
@ -8671,6 +8671,10 @@ FriendSecretEnteredSecretSelf = 'You just typed in your own True Friend Code!'
FriendSecretTooFast = 'You are redeeming codes too fast! Please wait a few seconds.' FriendSecretTooFast = 'You are redeeming codes too fast! Please wait a few seconds.'
FriendSecretNowFriends = 'You are now True Friends with %s!' FriendSecretNowFriends = 'You are now True Friends with %s!'
GroupAskNoAccess = 'Sorry, but you have no teleport access %s %s.\n\nWould you still like to teleport to %s?'
GroupAskNoAccessSame = 'Sorry, but you have no teleport access %s %s.'
GroupAskAccess = 'Would you like to teleport %s %s in %s?'
Blacklist = [ Blacklist = [
"$1ut", "$1ut",
"$h1t", "$h1t",

View file

@ -1685,3 +1685,5 @@ TF_FRIENDS_LIST_FULL_HIM = 5
TF_ALREADY_FRIENDS = 6 TF_ALREADY_FRIENDS = 6
TF_ALREADY_FRIENDS_NAME = 7 TF_ALREADY_FRIENDS_NAME = 7
TF_SUCCESS = 8 TF_SUCCESS = 8
GROUP_ZONES = [11000, 11100, 11200, 12000, 12100, 13000, 13100, 13200, 10000, 10100]

View file

@ -39,7 +39,6 @@ class ToontownUberRepository(ToontownInternalRepository):
self.chatAgent = simbase.air.generateGlobalObject(OTP_DO_ID_CHAT_MANAGER, 'ChatAgent') self.chatAgent = simbase.air.generateGlobalObject(OTP_DO_ID_CHAT_MANAGER, 'ChatAgent')
self.friendsManager = simbase.air.generateGlobalObject(OTP_DO_ID_TTS_FRIENDS_MANAGER, 'TTSFriendsManager') self.friendsManager = simbase.air.generateGlobalObject(OTP_DO_ID_TTS_FRIENDS_MANAGER, 'TTSFriendsManager')
self.globalPartyMgr = simbase.air.generateGlobalObject(OTP_DO_ID_GLOBAL_PARTY_MANAGER, 'GlobalPartyManager') self.globalPartyMgr = simbase.air.generateGlobalObject(OTP_DO_ID_GLOBAL_PARTY_MANAGER, 'GlobalPartyManager')
self.groupManager = simbase.air.generateGlobalObject(OPT_DO_ID_GROUP_MANAGER, 'GroupManager')
if self.wantTopToons: if self.wantTopToons:
self.topToonsMgr = TopToonsManagerUD(self) self.topToonsMgr = TopToonsManagerUD(self)