From 12af2492b41c1946ec7a977db64ea516b0ba4135 Mon Sep 17 00:00:00 2001
From: xdh <xiefantasy@qq.com>
Date: 星期二, 15 一月 2019 19:15:20 +0800
Subject: [PATCH] 5866 【后端】【1.5】线上服务器更新到1.5版本中级神兵石替换方案
---
ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py | 52 +++++++++++++++++++++++++++++++++++++++++++++++++++-
ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/ChPlayer.py | 3 ++-
2 files changed, 53 insertions(+), 2 deletions(-)
diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py
index 3784ef1..b222ccb 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py
@@ -1125,7 +1125,9 @@
self.__CrossServerPutInItem(packIndex, tagItem, event)
tagItem.Clear()
return True
-
+ if CheckChangeOldItem(curPlayer, tagItem):
+ tagItem.Clear()
+ return True
packIndex = ChConfig.GetItemPackType(curItemData.GetType(), packIndex)
if not self.CanPutInItem(packIndex, tagItem.GetItemTypeID(), GetItemCount(tagItem), tagItem.GetIsBind(), defaultPile):
@@ -2627,3 +2629,51 @@
return
+def CheckChangeOldItem(curPlayer, tagItem):
+ ##替换旧物品
+ itemID = tagItem.GetItemTypeID()
+ changeOldItemDict = IpyGameDataPY.GetFuncEvalCfg('ChangeOldItem', 1, {})
+ if itemID not in changeOldItemDict:
+ return
+ itemCnt = GetItemCount(tagItem)
+ isBind = tagItem.GetIsBind()
+ toItemID, toCnt, mailKey = changeOldItemDict[itemID]
+ giveCnt = itemCnt * toCnt
+ PlayerControl.SendMailByKey(mailKey, [curPlayer.GetPlayerID()], [[toItemID, giveCnt, isBind]])
+ return True
+
+def LoginCheckChangeOldItem(curPlayer):
+ ##登录检查替换旧物品
+ giveItemDict = {}
+ mailDict = {}
+ for packIndex in [IPY_GameWorld.rptItem, IPY_GameWorld.rptWarehouse]:
+ curPack = curPlayer.GetItemManager().GetPack(packIndex)
+ for i in xrange(curPack.GetCount()):
+ curItem = curPack.GetAt(i)
+ if not curItem:
+ continue
+ itemID = curItem.GetItemTypeID()
+ changeOldItemDict = IpyGameDataPY.GetFuncEvalCfg('ChangeOldItem', 1, {})
+ if itemID not in changeOldItemDict:
+ continue
+ isBind = curItem.GetIsBind()
+ itemCount = curItem.GetCount()
+ toItemID, toCnt, mailKey = changeOldItemDict[itemID]
+ giveCnt = itemCount * toCnt
+ keyStr = '%s_%s'%(toItemID, isBind)
+ giveItemDict[keyStr] = giveItemDict.get(keyStr, 0) + giveCnt
+ ItemCommon.DelItem(curPlayer, curItem, itemCount, False, "ChangeOldItem")
+ if mailKey not in mailDict:
+ mailDict[mailKey] = [keyStr]
+ if keyStr not in mailDict[mailKey]:
+ mailDict[mailKey].append(keyStr)
+ for mailKey, keyStrList in mailDict.items():
+ itemList = []
+ for keyStr in keyStrList:
+ if keyStr not in giveItemDict:
+ continue
+ giveCnt = giveItemDict[keyStr]
+ itemID, isBind = keyStr.split('_')
+ itemList.append([int(itemID), giveCnt, int(isBind)])
+ PlayerControl.SendMailByKey(mailKey, [curPlayer.GetID()], itemList)
+ return
\ No newline at end of file
diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/ChPlayer.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/ChPlayer.py
index 454db42..3e66e3c 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/ChPlayer.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/ChPlayer.py
@@ -430,7 +430,8 @@
#通知玩家技能信息
__Sync_ClientSkill(curPlayer)
-
+ #替换旧物品
+ ItemControler.LoginCheckChangeOldItem(curPlayer)
#清除生产采集Buff
#PlayerControl.DelProduceBuff(curPlayer, tick)
#清除国家答题Buff
--
Gitblit v1.8.0