hxp
2019-12-10 43e5e84170e91ca2bc4c26d289a8bc5a891d06d0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
#!/usr/bin/python
# -*- coding: GBK -*-
#-------------------------------------------------------------------------------
#
##@package Player.PlayerAssist
#
# @todo:ЭÖúϵͳ
# @author hxp
# @date 2019-12-06
# @version 1.0
#
# ÏêϸÃèÊö: Ð­Öúϵͳ
#
#-------------------------------------------------------------------------------
#"""Version = 2019-12-06 21:00"""
#-------------------------------------------------------------------------------
 
import GameWorld
import IpyGameDataPY
import PlayerControl
import NPCHurtManager
import IPY_GameWorld
 
import ChConfig
 
#// B0 10 ÇëÇóЭÖúBoss #tagCMRequestAssistBoss
#
#struct    tagCMRequestAssistBoss
#
#{
#    tagHead        Head;
#    DWORD        ObjID;
#    DWORD        NPCID;
#};
def OnRequestAssistBoss(index, clientData, tick):
    curPlayer = GameWorld.GetPlayerManager().GetPlayerByIndex(index)
    playerID = curPlayer.GetPlayerID()
    objID = clientData.ObjID
    npcID = clientData.NPCID
    
    if not curPlayer.GetFamilyID():
        GameWorld.DebugLog("ûÓÐÏÉÃ˲»ÄÜÇëÇóЭÖú!", playerID)
        return
    
    curNPC = GameWorld.FindNPCByNPCID(npcID)
    if not curNPC or curNPC.GetID() != objID:
        GameWorld.DebugLog("ЭÖúNPC²»´æÔÚÎÞ·¨Ð­Öú!", playerID)
        return
    
    ipyData = IpyGameDataPY.GetIpyGameDataNotLog('BOSSInfo', npcID)
    if not ipyData or not ipyData.GetCanAssist():
        GameWorld.DebugLog("¸ÃNPC²»ÄÜЭÖú!npcID=%s" % npcID, playerID)
        return
    
    hurtList = NPCHurtManager.GetPlayerHurtList(curNPC)
    if not hurtList.IsNoAssistPlayer(playerID):
        GameWorld.DebugLog("²»ÊǸÃbossµÄ·ÇÖúÕ½ÉËÑªÍæ¼Ò£¬ÎÞ·¨·¢ÆðЭÖú!npcID=%s" % npcID, playerID)
        return
    
    if not GameWorld.SetPlayerTickTime(curPlayer, ChConfig.TYPE_Player_Tick_RequestAssist, tick):
        GameWorld.DebugLog("ÇëÇóЭÖúCDÖÐ!npcID=%s" % npcID, playerID)
        return
    
    mapID = curPlayer.GetMapID()
    lineID = 0
    if GameWorld.GetMap().GetMapFBType() != IPY_GameWorld.fbtNull: # ¸±±¾ÐÍboss£¬Èç·âħ̳
        lineID = PlayerControl.GetFBFuncLineID(curPlayer)
    queryData = [mapID, lineID, npcID, objID]
    QueryGameServer_PlayerAssist(playerID, "RequestAssistBoss", queryData)
    return
 
 
#// B0 11 ÇëÇóЭÖú×é¶Ó¸±±¾ #tagCMRequestAssistTeamFB
#
#struct    tagCMRequestAssistTeamFB
#
#{
#    tagHead        Head;
#    WORD        MapID;
#    WORD        LineID;
#};
def OnRequestAssistTeamFB(index, clientData, tick):
    curPlayer = GameWorld.GetPlayerManager().GetPlayerByIndex(index)
    playerID = curPlayer.GetPlayerID()
    mapID = clientData.MapID
    lineID = clientData.LineID
    
    if not curPlayer.GetFamilyID():
        GameWorld.DebugLog("ûÓÐÏÉÃ˲»ÄÜÇëÇóЭÖú!", playerID)
        return
    
    if GameWorld.GetMap().GetMapFBTypeByMapID(mapID) != IPY_GameWorld.fbtTeam:
        GameWorld.DebugLog("·Ç×é¶Ó¸±±¾²»ÄÜÇëÇóЭÖú!mapID=%s" % mapID, playerID)
        return
    
    if not GameWorld.SetPlayerTickTime(curPlayer, ChConfig.TYPE_Player_Tick_RequestAssist, tick):
        GameWorld.DebugLog("ÇëÇóЭÖúCDÖÐ!mapID=%s,lineID=%s" % (mapID, lineID), playerID)
        return
    
    queryData = [mapID, lineID]
    QueryGameServer_PlayerAssist(playerID, "RequestAssistTeamFB", queryData)
    return
 
def OnStartAssistTeamFB(playerID, mapID, lineID, tagPlayerID):
    ## ¿ªÊ¼Ð­Öú×é¶Ó¸±±¾£¬Ð­ÖúÍæ¼Ò½øÈ븱±¾µ÷ÓÃ
    queryData = [mapID, lineID, tagPlayerID]
    QueryGameServer_PlayerAssist(playerID, "OnStartAssistTeamFB", queryData)
    return
 
def QueryGameServer_PlayerAssist(playerID, queryType, queryData):
    msgInfo = str([queryType, queryData])
    GameWorld.GetPlayerManager().GameServer_QueryPlayerResult(playerID, 0, 0, "PlayerAssist", msgInfo, len(msgInfo))
    GameWorld.DebugLog("ЭÖúÐÅÏ¢·¢ËÍ GameServer: playerID=%s,queryType=%s,queryData=%s" % (playerID, queryType, queryData))
    return
 
def QueryResult_PlayerAssist(curPlayer, resultList):
    ## Ð­ÖúÐÅÏ¢GameServer·µ»Ø´¦Àí
    if len(resultList) != 3:
        return
    #queryType, queryData, result = resultList
    
    return
 
def GameServer_AssistBossMsg(assistData):
    ## GameServerÍÆË͵½Ö¸¶¨bossµØÍ¼µÄÐÅÏ¢
    
    GameWorld.DebugLog("GameServerͬ²½BossЭÖúÐÅÏ¢: %s" % assistData)
    
    msgType = assistData[0]
    
    # ¿ªÊ¼Ð­Öú
    if msgType == "Start":
        assistGUID, assistPlayerID, assistPlayerName, tagPlayerID, tagPlayerName, tagTeamID, lineID, objID, npcID = assistData[1:]
        npchurtList = NPCHurtManager.GetPlayerHurtListEx(lineID, objID, npcID)
        if not npchurtList:
            return
        
        npchurtList.AddAssistPlayer(assistPlayerID, assistPlayerName, tagPlayerID, tagPlayerName, tagTeamID)
        QueryGameServer_PlayerAssist(0, "AddAssistBossPlayerOK", [assistGUID, assistPlayerID])
        
    # È¡ÏûЭÖú
    elif msgType == "Cancel":
        assistPlayerID, lineID, objID, npcID = assistData[1:]
        npchurtList = NPCHurtManager.GetPlayerHurtListEx(lineID, objID, npcID)
        if not npchurtList:
            return
        npchurtList.DelHurtPlayer(assistPlayerID, "Cancel", isMapServerDel=False)
        
    return