From f2cf64ffabcd15d5497aee8914b8d37d8b9a88b0 Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期六, 07 二月 2026 15:39:43 +0800
Subject: [PATCH] 66 【公会】基础主体-服务端(公会GM命令支持跨服 CreateFamily、Family、Zhenbaoge;跨服公会聊天支持,包含公会聊天缓存;查看玩家A705回包增加公会所在服务器ID信息;)

---
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py |  149 ++++++++++---------------------------------------
 1 files changed, 32 insertions(+), 117 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 0ef20d0..824ef4f 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py
@@ -25,6 +25,7 @@
 import traceback
 import random
 import ReadChConfig
+import PlayerActivity
 import ChPyNetSendPack
 import NetPackCommon
 import PlayerXiangong
@@ -32,7 +33,6 @@
 import PlayerGubao
 import PyGameData
 import PlayerHero
-import ObjPool
 
 import math
 import time
@@ -483,6 +483,12 @@
     
     itemType = curItem.GetType()
     itemID = curItem.GetItemTypeID()
+    
+    if itemType in IpyGameDataPY.GetFuncEvalCfg("ItemRecordRule", 4) \
+        or itemID in IpyGameDataPY.GetFuncEvalCfg("ItemRecordRule", 5):
+        #GameWorld.DebugLog("不需要记录的物品类型或ID! itemType=%s,itemID=%s" % (itemType, itemID))
+        return False
+    
     itemTypeMinColorDict = IpyGameDataPY.GetFuncEvalCfg("ItemRecordRule", 1)
     if itemType in itemTypeMinColorDict:
         minColor = itemTypeMinColorDict[itemType]
@@ -496,11 +502,6 @@
         or itemID in IpyGameDataPY.GetFuncEvalCfg("ItemRecordRule", 3):
         #GameWorld.DebugLog("需要记录的物品类型或ID! itemType=%s,itemID=%s" % (itemType, itemID))
         return True
-    
-    if itemType in IpyGameDataPY.GetFuncEvalCfg("ItemRecordRule", 4) \
-        or itemID in IpyGameDataPY.GetFuncEvalCfg("ItemRecordRule", 5):
-        #GameWorld.DebugLog("不需要记录的物品类型或ID! itemType=%s,itemID=%s" % (itemType, itemID))
-        return False
     
     #if itemType == ChConfig.Def_ItemType_Rune:
     #    return IsRuneItemNeedRecord(curItem, curItem.GetUserAttr(ShareDefine.Def_IudetRuneLV))
@@ -854,39 +855,6 @@
             return True
         if itemID not in ChConfig.Def_TransformItemIDList:
             return False
-        if itemID == ChConfig.Def_ItemID_SilverMoney:
-            PlayerControl.GiveMoney(curPlayer, IPY_GameWorld.TYPE_Price_Silver_Money, itemCount)
-        elif itemID == ChConfig.Def_ItemID_SP:
-            PlayerControl.PlayerAddZhenQi(curPlayer, itemCount)
-        elif itemID == ChConfig.Def_ItemID_GoldPaper:
-            PlayerControl.GiveMoney(curPlayer, IPY_GameWorld.TYPE_Price_Gold_Paper, itemCount, moneyEventName, addDict)
-        elif itemID == ChConfig.Def_ItemID_RealmPoint:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_RealmPoint, itemCount)
-        elif itemID == ChConfig.Def_ItemID_BossReborn:
-            msgStr = str(itemCount)
-            GameWorld.GetPlayerManager().GameServer_QueryPlayerResult(0, 0, 0, 'AddBossRebornPoint', msgStr, len(msgStr))
-        elif itemID == ChConfig.Def_ItemID_Ysog:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_Ysog, itemCount)
-        elif itemID == ChConfig.Def_ItemID_SoulDust:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_SoulDust, itemCount)
-        elif itemID == ChConfig.Def_ItemID_SoulSplinters:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_SoulSplinters, itemCount)
-        elif itemID == ChConfig.Def_ItemID_SoulCore:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_SoulCore, itemCount)
-        elif itemID == ChConfig.Def_ItemID_Honor:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_Honor, itemCount)
-        elif itemID == ChConfig.Def_ItemID_GoldMoney:
-            PlayerControl.GiveMoney(curPlayer, IPY_GameWorld.TYPE_Price_Gold_Money, itemCount, moneyEventName, addDict)
-        elif itemID == ChConfig.Def_ItemID_FuncSysPrivilege:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_FuncSysPrivilege, itemCount)
-        elif itemID == ChConfig.Def_ItemID_BTGMPoint:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_BTGMPoint, itemCount)
-        elif itemID == ChConfig.Def_ItemID_GuShenMoney:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_GuShenMoney, itemCount)
-        elif itemID == ChConfig.Def_ItemID_GongdePoint:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_GongdePoint, itemCount)
-        elif itemID == ChConfig.Def_ItemID_FamilyFlagWarPoint:
-            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_FamilyFlagWarPoint, itemCount)
         return True
     
     def __CrossServerPutInItem(self, packIndex, tagItem, event=["", False, {}]):
@@ -899,6 +867,18 @@
         itemData = [tagItem.GetItemTypeID(), tagItem.GetCount(), tagItem.GetIsBind(), tagItem.GetUserData()]
         itemMsg = {"PlayerID":curPlayer.GetPlayerID(), "ItemData":itemData, "PackIndex":packIndex, "Event":event}
         GameWorld.SendMsgToClientServer(ShareDefine.CrossServerMsg_PutInItem, itemMsg, [serverGroupID])
+        return
+    
+    def __autoUseByEffectID(self, curPlayer, tagItem, itemEff, itemID, itemCount):
+        effectID = itemEff.GetEffectID()
+        
+        # 物品碎片
+        if effectID == ChConfig.Def_Effect_ItemCount:
+            SetItemCountByID(curPlayer, itemID, GetItemCountByID(curPlayer, itemID) + itemCount)
+        # 活跃度
+        elif effectID == ChConfig.Def_Effect_AddActivity:
+            PlayerActivity.DoAddActivity(curPlayer, itemCount)
+            
         return
     
     ## 放入物品 
@@ -939,11 +919,11 @@
         #    tagItem.Clear()
         #    return True
         itemEff = tagItem.GetEffectByIndex(0)
-        #物品碎片
-        if itemEff.GetEffectID() == ChConfig.Def_Effect_ItemCount:
-            SetItemCountByID(curPlayer, itemID, GetItemCountByID(curPlayer, itemID) + tagItemCount)
+        if itemEff.GetEffectID() in ChConfig.AutoUseItemEffectIDList:
+            self.__autoUseByEffectID(curPlayer, tagItem, itemEff, itemID, tagItemCount)
             tagItem.Clear()
             return True
+        
         #气运
         if itemEff.GetEffectID() == ChConfig.Def_Effect_TiandaoQiyun:
             isAutoUse = itemEff.GetEffectValue(1)
@@ -998,7 +978,7 @@
         #itemFactory = GameWorld.GetItemFactory()
         #isBind = tagItem.GetIsBind()
         # 目前暂只记录放入背包的
-        if not isNeedRecord and packIndex in [IPY_GameWorld.rptItem, ShareDefine.rptTreasure, ShareDefine.rptRune, ShareDefine.rptGatherSoul, ShareDefine.rptDogzItem]:
+        if not isNeedRecord and packIndex in ShareDefine.NeedRecordRPType:
             isNeedRecord = ItemNeedRecord(tagItem) or isForceEvent
         putResult = False
         
@@ -1251,7 +1231,7 @@
         itemCount = GetItemCountByID(curPlayer, itemID)
         if not itemCount and not force:
             continue
-        countInfo = ObjPool.GetPoolMgr().acquire(ChPyNetSendPack.tagMCAutoItemCount)
+        countInfo = ChPyNetSendPack.tagMCAutoItemCount()
         countInfo.Clear()
         countInfo.ItemID = itemID
         countInfo.ItemCount = itemCount
@@ -1260,7 +1240,7 @@
     if not itemCountList:
         return
     
-    clientPack = ObjPool.GetPoolMgr().acquire(ChPyNetSendPack.tagMCAutoItemCountRefresh)
+    clientPack = ChPyNetSendPack.tagMCAutoItemCountRefresh()
     clientPack.Clear()
     clientPack.ItemCountList = itemCountList
     clientPack.Count = len(clientPack.ItemCountList)
@@ -1690,74 +1670,9 @@
     return
 
 def ResetHeroPack(curPlayer, curPack, beingIndex, endIndex):
-    itemList = []
-    for i in range(beingIndex, endIndex + 1):
-        curRoleItem = curPack.GetAt(i)
-        if curRoleItem.IsEmpty():
-            continue
-        curItem = curRoleItem.GetItem() 
-        itemList.append(curItem)
-    itemList.sort(__CmpHeroPack)
-    
-    curPack.WipePack(beingIndex, endIndex)
-    putPlace = beingIndex
-    for item in itemList:
-        curPack.GetAt(putPlace).AssignItem(item, False)
-        putPlace += 1
-        
+    ## 前端自行排序
     return
 
-def __CmpHeroPack(item1, item2):
-    '''排序规则:上阵武将排前,未上阵武将排后,再各自按照以下规则排序
-    武将等级>突破等级>武将星级>武将品质>武将ID
-    '''
-    
-    posNum1, posNum2 = 0, 0
-    for lpIndex in range(item1.GetUserAttrCount(ShareDefine.Def_IudetHeroLineup)):
-        lineupValue = item1.GetUserAttrByIndex(ShareDefine.Def_IudetHeroLineup, lpIndex)
-        lineupID, _, posNum = PlayerHero.GetLineupValue(lineupValue)
-        if lineupID != ShareDefine.Lineup_Main:
-            continue
-        posNum1 = posNum
-        break
-        
-    for lpIndex in range(item2.GetUserAttrCount(ShareDefine.Def_IudetHeroLineup)):
-        lineupValue = item2.GetUserAttrByIndex(ShareDefine.Def_IudetHeroLineup, lpIndex)
-        lineupID, _, posNum = PlayerHero.GetLineupValue(lineupValue)
-        if lineupID != ShareDefine.Lineup_Main:
-            continue
-        posNum2 = posNum
-        break
-    
-    if (posNum1 and posNum2) or (not posNum1 and not posNum2):
-        lv1 = item1.GetUserAttr(ShareDefine.Def_IudetHeroLV)
-        lv2 = item2.GetUserAttr(ShareDefine.Def_IudetHeroLV)
-        if lv1 == lv2:
-            bLV1 = item1.GetUserAttr(ShareDefine.Def_IudetHeroBreakLV)
-            bLV2 = item2.GetUserAttr(ShareDefine.Def_IudetHeroBreakLV)
-            if bLV1 == bLV2:
-                star1 = item1.GetUserAttr(ShareDefine.Def_IudetHeroStar)
-                star2 = item2.GetUserAttr(ShareDefine.Def_IudetHeroStar)
-                if star1 == star2:
-                    heroID1 = item1.GetItemTypeID()
-                    heroID2 = item2.GetItemTypeID()
-                    ipyData1 = IpyGameDataPY.GetIpyGameData("Hero", heroID1)
-                    ipyData2 = IpyGameDataPY.GetIpyGameData("Hero", heroID2)
-                    quality1 = ipyData1.GetQuality() if ipyData1 else 0
-                    quality2 = ipyData2.GetQuality() if ipyData2 else 0
-                    if quality1 == quality2:
-                        return cmp(heroID1, heroID2)
-                    return -cmp(quality1, quality2)
-                return -cmp(star1, star2)
-            return -cmp(bLV1, bLV2)
-        return -cmp(lv1, lv2)
-    elif posNum1:
-        return -1
-    elif posNum2:
-        return 1
-    else:
-        return cmp(item1.GetItemTypeID(), item2.GetItemTypeID())
-    
 #===============================================================================
 #Python 版重整物品
 # def ResetItem(curPlayer, curPackIndex, tick):
@@ -1992,11 +1907,11 @@
         return False
     
     if isAuctionItem:
-        ipyData = None #IpyGameDataPY.GetIpyGameData("AuctionItem", itemID)
-        if not ipyData:
-            GameWorld.ErrLog("非拍卖物品,默认转为非拍品! itemID=%s,itemCount=%s,isAuctionItem=%s" 
-                             % (itemID, itemCount, isAuctionItem), curPlayer.GetPlayerID())
-            isAuctionItem = 0
+        #ipyData = None #IpyGameDataPY.GetIpyGameData("AuctionItem", itemID)
+        #if not ipyData:
+        #    GameWorld.ErrLog("非拍卖物品,默认转为非拍品! itemID=%s,itemCount=%s,isAuctionItem=%s" 
+        #                     % (itemID, itemCount, isAuctionItem), curPlayer.GetPlayerID())
+        isAuctionItem = 0
     
     defaultPack = IPY_GameWorld.rptItem if not packIndexList else packIndexList[0]
     packIndex = ChConfig.GetItemPackType(curItemData, defaultPack)
@@ -2179,7 +2094,7 @@
     if itemData.GetItemTypeID() in ChConfig.Def_TransformItemIDList or itemData.GetType() == ChConfig.Def_ItemType_AutoUseMoney:
         return True
     itemEff = itemData.GetEffectByIndex(0)
-    if itemEff.GetEffectID() == ChConfig.Def_Effect_ItemCount:
+    if itemEff.GetEffectID() in ChConfig.AutoUseItemEffectIDList:
         return True
     return False
 

--
Gitblit v1.8.0