hxp
2023-11-06 ce6373a4c8a6b213478a42605a67d091aa23b19d
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
#!/usr/bin/python
# -*- coding: GBK -*-
#-------------------------------------------------------------------------------
#
##@package GM.Commands.PrintNPCHurt
#
# @todo:ÏÔʾNPCÉËѪÁбí
# @author hxp
# @date 2017-12-07
# @version 1.0
#
# ÏêϸÃèÊö: ÏÔʾNPCÉËѪÁбí
#
#-------------------------------------------------------------------------------
#"""Version = 2017-12-07 15:00"""
#-------------------------------------------------------------------------------
import GameWorld
import IPY_GameWorld
import FamilyRobBoss
import NPCCommon
import ChConfig
import NPCHurtManager
import NPCHurtMgr
import PlayerTeam
import ShareDefine
import GameObj
 
##²é¿´µãÑ¡µÄNPC³ðºÞÁбí
# @param curPlayer Íæ¼ÒʵÀý
# @param cmdList GMÃüÁî²ÎÊýÁбí
# @return ·µ»ØÖµÎÞÒâÒå
# @remarks GMÃüÁî
def OnExec(curPlayer, cmdList):
    
    if not cmdList:
        GameWorld.DebugAnswer(curPlayer, "PrintNPCHurt objID ÊÇ·ñÅÅÐò(¿ÉÑ¡)")
        return
    
    objID = cmdList[0]
    isSort = cmdList[1] if len(cmdList) > 1 else 0
    curNPC = GameWorld.GetObj(objID, IPY_GameWorld.gotNPC)
    if not curNPC:
        GameWorld.DebugAnswer(curPlayer, "objID(%s) ´íÎó ÕÒ²»µ½¶ÔÓ¦NPC" % objID)
        return
    
    GameWorld.DebugAnswer(curPlayer, "--- %s --- HP: %s / %s" % (GameWorld.GetGameWorld().GetTick() % 1000, GameObj.GetHP(curNPC), GameObj.GetMaxHP(curNPC)))
    GameWorld.DebugAnswer(curPlayer, "ID=%s,team=%s,family=%s" % (curPlayer.GetPlayerID(), curPlayer.GetTeamID(), curPlayer.GetFamilyID()))
    
    # ¹éÊôÏÉÃ˵ģ¬È¡ÏÉÃËÉËѪͳ¼Æ
    if NPCCommon.GetDropOwnerType(curNPC) == ChConfig.DropOwnerType_Family:
        FamilyRobBoss.OnGMPrintFamilyOwnerBossHurt(curPlayer, curNPC)
        return
    
    isAssistHurt = 0
    npcHurtList = NPCHurtManager.GetPlayerHurtList(curNPC)
    if npcHurtList:
        isAssistHurt = 1
    if not npcHurtList:
        npcHurtList = NPCHurtMgr.GetPlayerHurtList(curNPC)
    if not npcHurtList:
        npcHurtList = curNPC.GetPlayerHurtList()
        
    if isSort:
        npcHurtList.Sort()  #sortÒÔºóÉËѪÁбí´Ó´óµ½Ð¡ÅÅÐò
        
    GameWorld.DebugAnswer(curPlayer, "ID=%s,NPCID=%s, ÉËѪÊý=%s,ÅÅÐò=%s,Э=%s" 
                          % (curNPC.GetID(), curNPC.GetNPCID(), npcHurtList.GetHurtCount(), isSort, isAssistHurt))
    if isAssistHurt:
        for playerID, assistPlayerIDList in npcHurtList.GetNoAssitPlayerIDDict().items():
            GameWorld.DebugAnswer(curPlayer, "Íæ¼Ò:%s, Ð­ÖúÍæ¼Ò:%s" % (playerID, assistPlayerIDList))
        for assistPlayerID, tagPlayerID in npcHurtList.GetAssistPlayerIDDict().items():
            GameWorld.DebugAnswer(curPlayer, "ЭÖúÍæ¼Ò:%s, Ä¿±ê:%s" % (assistPlayerID, tagPlayerID))
            
    for index in xrange(npcHurtList.GetHurtCount()):
        #»ñµÃÉËѪ¶ÔÏó
        hurtObj = npcHurtList.GetHurtAt(index)
        hurtType = hurtObj.GetValueType()
        hurtID = hurtObj.GetValueID()
        hurtValue = hurtObj.GetHurtValue()
        if hasattr(hurtObj, "GetHurtValueEx"):
            hurtValue += hurtObj.GetHurtValueEx() * ShareDefine.Def_PerPointValue
        if not hurtID:
            GameWorld.DebugAnswer(curPlayer, "%s ²»´æÔÚ£¡HurtType=%s,ID=%s, V=%s" % (index, hurtType, hurtID, hurtValue))
            continue
        
        if hurtType == ChConfig.Def_NPCHurtTypePlayer:
            hurtPlayer = GameWorld.GetObj(hurtID, IPY_GameWorld.gotPlayer)
            if hurtPlayer == None:
                GameWorld.DebugAnswer(curPlayer, "%s Íæ¼ÒID=%s,²»´æÔÚ, V=%s" % (index, hurtID, hurtValue))
            elif GameObj.GetHP(hurtPlayer) <= 0 :
                GameWorld.DebugAnswer(curPlayer, "%s Íæ¼ÒID=%s,ѪÁ¿Îª0, V=%s" % (index, hurtID, hurtValue))
            else:
                d = GameWorld.GetDist(curNPC.GetPosX(), curNPC.GetPosY(), hurtPlayer.GetPosX(), hurtPlayer.GetPosY())
                GameWorld.DebugAnswer(curPlayer, "%s Íæ¼ÒID=%s,¾àÀë=%s, V=%s" % (index, hurtID, d, hurtValue))
                
            if isAssistHurt:
                playerHurtValue, assistPlayerHurtDict = npcHurtList.GetPlayerHurtDetail(hurtID)
                GameWorld.DebugAnswer(curPlayer, "    ·ÇЭid=%s,v=%s" % (hurtID, playerHurtValue))
                for assistPlayerID, assistHurtValue in assistPlayerHurtDict.items():
                    GameWorld.DebugAnswer(curPlayer, "        Ð­Öúid=%s,v=%s" % (assistPlayerID, assistHurtValue))
                    
        elif hurtType == ChConfig.Def_NPCHurtTypeTeam:
            #»ñµÃµ±Ç°¶ÓÎé
            curTeam = GameWorld.GetTeamManager().FindTeam(hurtID)
            if curTeam == None:
                GameWorld.DebugAnswer(curPlayer, "%s ¶ÓÎéID=%s,²»´æÔÚ, V=%s" % (index, hurtID, hurtValue))
            else:
                GameWorld.DebugAnswer(curPlayer, "%s ¶ÓÎéID=%s,ÈËÊý=%s, V=%s" % (index, hurtID, curTeam.GetMemberCount(), hurtValue))
                
            if isAssistHurt:
                mapTeamPlayerIDList = PlayerTeam.GetMapTeamPlayerIDList(hurtID)
                for teamPlayerID in mapTeamPlayerIDList:
                    if not npcHurtList.IsNoAssistPlayer(teamPlayerID):
                        continue
                    playerHurtValue, assistPlayerHurtDict = npcHurtList.GetPlayerHurtDetail(teamPlayerID)
                    GameWorld.DebugAnswer(curPlayer, "    ·ÇЭid=%s,v=%s" % (teamPlayerID, playerHurtValue))
                    for assistPlayerID, assistHurtValue in assistPlayerHurtDict.items():
                        GameWorld.DebugAnswer(curPlayer, "        Ð­Öúid=%s,v=%s" % (assistPlayerID, assistHurtValue))
                        
        elif hurtType == ChConfig.Def_NPCHurtTypeNPC:
            GameWorld.DebugAnswer(curPlayer, "%s NPC=%s, V=%s" % (index, hurtID, hurtValue))
            
        #Òì³£ÐÅÏ¢,Ìí¼ÓÉËѪÀàÐÍ´íÎó
        else:
            GameWorld.DebugAnswer(curPlayer, "%s Òì³£!Type=%s,ID=%s, V=%s" % (index, hurtType, hurtID, hurtValue))
    return