From faf986a85304e980f9eb621b4e788fc942441d7f Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期二, 15 一月 2019 22:29:40 +0800
Subject: [PATCH] 5722 【后端】【1.5】跨服BOSS开发(增加跨服地图中进入副本限制提示、组队相关操作提示、传送限制提示)

---
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/FBProcess/GameLogic_GatherSoul.py |   55 ++++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 36 insertions(+), 19 deletions(-)

diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/FBProcess/GameLogic_GatherSoul.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/FBProcess/GameLogic_GatherSoul.py
index 6d7f110..8c624ad 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/FBProcess/GameLogic_GatherSoul.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/FBProcess/GameLogic_GatherSoul.py
@@ -153,6 +153,7 @@
     else:
         return
     DoFBHelp(curPlayer, tick)
+    curPlayer.SetFaction(ShareDefine.CampType_Justice)
     return
 
 
@@ -196,8 +197,8 @@
         guardDict[npcid] = gameFB.GetGameFBDictByKey(FBPlayerDict_GuardNPCCnt%npcid)
     hasRefreshBoss = gameFB.GetGameFBDictByKey(FBPlayerDict_HasRefreshBoss)
     isAutoBoss = gameFB.GetGameFBDictByKey(FBPlayerDict_AutoBoss)
-
-    itemDict = PyGameData.g_gathersoulfbAwardDict.get(curPlayer.GetID(), {})
+    lineID = GameWorld.GetGameWorld().GetLineID()
+    itemDict = PyGameData.g_gathersoulfbAwardDict.get(lineID, {})
     helpItemInfo = {}
     for wheel, itemList in itemDict.items():
         helpItemInfo[str(wheel)] = FBCommon.GetJsonItemList(itemList)
@@ -539,12 +540,13 @@
     ##掉落奖励 {wheel:[[itemid,itemCnt,isBind]]}
     gameFB = GameWorld.GetGameFB()
     curWheel = gameFB.GetGameFBDictByKey(FBPlayerDict_CurWheel) + 1
-    ownerID = gameFB.GetGameFBDictByKey(ChConfig.Def_FB_SingleFBPlayerID)
-    if ownerID not in PyGameData.g_gathersoulfbAwardDict:
-        PyGameData.g_gathersoulfbAwardDict[ownerID] = {}
-    if curWheel not in PyGameData.g_gathersoulfbAwardDict[ownerID]:
-        PyGameData.g_gathersoulfbAwardDict[ownerID][curWheel] = []
-    PyGameData.g_gathersoulfbAwardDict[ownerID][curWheel].append([itemID, itemCnt, isBind])
+    #ownerID = gameFB.GetGameFBDictByKey(ChConfig.Def_FB_SingleFBPlayerID)
+    lineID = GameWorld.GetGameWorld().GetLineID()
+    if lineID not in PyGameData.g_gathersoulfbAwardDict:
+        PyGameData.g_gathersoulfbAwardDict[lineID] = {}
+    if curWheel not in PyGameData.g_gathersoulfbAwardDict[lineID]:
+        PyGameData.g_gathersoulfbAwardDict[lineID][curWheel] = []
+    PyGameData.g_gathersoulfbAwardDict[lineID][curWheel].append([itemID, itemCnt, isBind])
     curPlayer = FBCommon.GetCurSingleFBPlayer()
     if curPlayer:
         DoFBHelp(curPlayer, 0)
@@ -560,7 +562,8 @@
     # 进入离开阶段
     FBCommon.SetFBStep(FB_Step_Over, tick)
     ownerID = gameFB.GetGameFBDictByKey(ChConfig.Def_FB_SingleFBPlayerID)
-    itemDict = PyGameData.g_gathersoulfbAwardDict.pop(ownerID, {})
+    lineID = GameWorld.GetGameWorld().GetLineID()
+    itemDict = PyGameData.g_gathersoulfbAwardDict.pop(lineID, {})
     totalItemList = []
     for itemList in itemDict.values():
         totalItemList += itemList
@@ -568,20 +571,34 @@
     curPlayer = FBCommon.GetCurSingleFBPlayer()
     if not curPlayer:
         #奖励直接发邮件
-        PlayerControl.SendMailByKey('JHBagFull2', [ownerID], totalItemList)
+        if totalItemList:
+            PlayerControl.SendMailByKey('JHBagFull2', [ownerID], totalItemList)
         
         GameWorldProcess.CloseFB(tick)
         return
-    needSpace = len(totalItemList)
-    emptySpace = ItemCommon.GetItemPackSpace(curPlayer, ShareDefine.rptGatherSoul, needSpace)
-    isSendMail = int(needSpace > emptySpace) # 是否发送邮件
-    if isSendMail:
-        PlayerControl.SendMailByKey('JHBagFull2', [curPlayer.GetPlayerID()], totalItemList)
-        GameWorld.DebugLog("背包空间不够,发送邮件: mailItemList=%s" % str(totalItemList), curPlayer.GetPlayerID())
-    else:
+    if totalItemList:
+        needPackSpaceDict = {}
         for itemID, itemCnt, isBind in totalItemList:
-            ItemControler.GivePlayerItem(curPlayer, itemID, itemCnt, isBind, [ShareDefine.rptGatherSoul],
-                                            event=["GatherSoulFB", False, {}])
+            curItem = GameWorld.GetGameData().GetItemByTypeID(itemID)
+            if not curItem:
+                return
+            packType = ChConfig.GetItemPackType(curItem.GetType())
+            needSpace = ItemControler.GetItemNeedPackCount(packType, curItem, itemCnt)
+            needPackSpaceDict[packType] = needPackSpaceDict.get(packType, 0) + needSpace
+            
+        isSendMail = False #是否背包不足
+        for packType, needSpace in needPackSpaceDict.items():
+            if needSpace > ItemCommon.GetItemPackSpace(curPlayer, packType, needSpace):
+                isSendMail = True
+                break
+    
+        if isSendMail:
+            PlayerControl.SendMailByKey('JHBagFull2', [curPlayer.GetPlayerID()], totalItemList)
+            GameWorld.DebugLog("背包空间不够,发送邮件: mailItemList=%s" % str(totalItemList), curPlayer.GetPlayerID())
+        else:
+            for itemID, itemCnt, isBind in totalItemList:
+                ItemControler.GivePlayerItem(curPlayer, itemID, itemCnt, isBind, [],
+                                                event=["GatherSoulFB", False, {}])
             
     fbCfg = GetGatherSoulFBCfg()
     costTime = tick - GameWorld.GetGameWorld().GetOpenFBTick()

--
Gitblit v1.8.0