From db168633a2853111b43c413779a5535228dfe61c Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期一, 09 二月 2026 20:20:24 +0800
Subject: [PATCH] 462 【付费活动】限时冲刺-服务端(轮回殿支持消费货币冲制;)
---
ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/CrossPlayer.py | 35 +++++++++++++++++++++++++++++------
1 files changed, 29 insertions(+), 6 deletions(-)
diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/CrossPlayer.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/CrossPlayer.py
index 4440d86..9271569 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/CrossPlayer.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/CrossPlayer.py
@@ -246,7 +246,9 @@
CrossMsg.SendToClientServer(ShareDefine.C2S_NotifyCode, dataMsg, [mainServerID], playerID)
return
-def FamilyNotify(familyID, msgMark, msgParamList=[], excludeIDList=[]):
+def SendToFamilyPlayer(familyID, msgType, dataMsg, excludeIDList=[], onlyIDList=[], havePlayerCall=None):
+ ## 发送给某个公会所有在线游戏服成员,跨服游戏服通用
+ # @param havePlayerCall: 有curPlayer时回调函数,一般是游戏服时有,直接本服执行 func(curPlayer, familyID, dataMsg)
family = DBDataMgr.GetFamilyMgr().FindFamily(familyID)
if not family:
return
@@ -257,6 +259,8 @@
for index in range(family.GetCount()):
member = family.GetAt(index)
playerID = member.GetPlayerID()
+ if onlyIDList and playerID not in onlyIDList:
+ continue
if excludeIDList and playerID in excludeIDList:
continue
crossPlayer = crossPlayerMgr.FindCrossPlayer(playerID)
@@ -265,7 +269,8 @@
continue
curPlayer = crossPlayer.GetPlayer()
if curPlayer: # 有玩家,一般只有游戏服有,可视为游戏服在线,直接发送
- PlayerControl.NotifyCode(curPlayer, msgMark, msgParamList)
+ if havePlayerCall:
+ havePlayerCall(curPlayer, familyID, dataMsg)
continue
mainServerID = crossPlayer.GetMainServerID()
if mainServerID == curServerID:
@@ -278,8 +283,22 @@
playerIDList.append(playerID)
for mainServerID, playerIDList in crossServerPlayerDict.items():
- dataMsg = {"playerIDList":playerIDList, "msgMark":msgMark, "msgParamList":msgParamList}
- CrossMsg.SendToClientServer(ShareDefine.C2S_NotifyCode, dataMsg, [mainServerID])
+ sendDataMsg = {"playerIDList":playerIDList, "familyID":familyID}
+ sendDataMsg.update(dataMsg)
+ CrossMsg.SendToClientServer(msgType, sendDataMsg, [mainServerID])
+ return
+
+def FamilyNotify(familyID, msgMark, msgParamList=[], excludeIDList=[]):
+ family = DBDataMgr.GetFamilyMgr().FindFamily(familyID)
+ if not family:
+ return
+
+ def havePlayerCall(curPlayer, familyID, dataMsg):
+ PlayerControl.NotifyCode(curPlayer, dataMsg["msgMark"], dataMsg["msgParamList"])
+ return
+
+ dataMsg = {"msgMark":msgMark, "msgParamList":msgParamList}
+ SendToFamilyPlayer(familyID, ShareDefine.C2S_NotifyCode, dataMsg, excludeIDList, havePlayerCall=havePlayerCall)
return
def C2S_NotifyCode(dataMsg):
@@ -360,7 +379,7 @@
return
-def GivePlayerResources(crossPlayer, awardItemList=None, moneyDict=None, eventName="", drDict=None):
+def GivePlayerResources(crossPlayer, awardItemList=None, moneyDict=None, eventName="", drDict=None, isNotifyAward=True):
'''给玩家资源
@param awardItemList: 给物品列表 [[itemID,itemCnt], ...]
@param moneyDict: 给货币 {货币类型:消耗值, ...}
@@ -375,6 +394,8 @@
dataMsg["moneyDict"] = moneyDict
if drDict:
dataMsg["drDict"] = drDict
+ if not isNotifyAward:
+ dataMsg["isNotifyAward"] = isNotifyAward
playerID = crossPlayer.GetPlayerID()
curPlayer = crossPlayer.GetPlayer()
@@ -405,6 +426,7 @@
awardItemList = eventData.get("awardItemList", [])
moneyDict = eventData.get("moneyDict", {})
drDict = eventData.get("drDict", {})
+ isNotifyAward = eventData.get("isNotifyAward", True)
GameWorld.DebugLog("awardItemList=%s" % awardItemList)
if awardItemList:
@@ -418,7 +440,8 @@
for moneyType, moneyValue in moneyDict.items():
PlayerControl.GiveMoney(curPlayer, moneyType, moneyValue, eventName, moneyRDict)
- ItemControler.NotifyGiveAwardInfo(curPlayer, awardItemList, eventName, moneyInfo=moneyDict)
+ if isNotifyAward:
+ ItemControler.NotifyGiveAwardInfo(curPlayer, awardItemList, eventName, moneyInfo=moneyDict)
return
def SetPlayerNomalDict(crossPlayer, setDict, isDayReset=False):
--
Gitblit v1.8.0