From 931a2cbb88495db317e9a0ad68a9073a1dc98dc1 Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期一, 31 五月 2021 18:23:46 +0800
Subject: [PATCH] 8921 【主干】【BT2】【后端】H.活动-节日活动-垃圾分类(增加垃圾分类结果封包通知 AA57, 去除分类结果系统提示)

---
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActGarbageSorting.py |   24 ++++----
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py                |   70 ++++++++++++----------
 ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py                                     |   70 ++++++++++++----------
 3 files changed, 88 insertions(+), 76 deletions(-)

diff --git a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py
index ea699ce..78a2257 100644
--- a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py
+++ b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py
@@ -24723,17 +24723,23 @@
 
 
 #------------------------------------------------------
-# AA 56 垃圾收集活动任务进度信息 #tagMCActGarbageTaskInfo
+# AA 57 垃圾收集活动分类结果 #tagMCActGarbageSortingResult
 
-class  tagMCActGarbageTaskItem(Structure):
+class  tagMCActGarbageSortingResult(Structure):
     _pack_ = 1
     _fields_ = [
-                  ("ItemID", c_int),    
-                  ("ItemCount", c_ushort),    
+                  ("Cmd", c_ubyte),
+                  ("SubCmd", c_ubyte),
+                  ("ActNum", c_ubyte),    #活动编号
+                  ("GarbageSortingType", c_ubyte),    #垃圾分类类型
+                  ("IsRight", c_ubyte),    #是否正确
+                  ("AddEnvValue", c_ushort),    #增加环保值
                   ]
 
     def __init__(self):
         self.Clear()
+        self.Cmd = 0xAA
+        self.SubCmd = 0x57
         return
 
     def ReadData(self, stringData, _pos=0, _len=0):
@@ -24742,27 +24748,46 @@
         return _pos + self.GetLength()
 
     def Clear(self):
-        self.ItemID = 0
-        self.ItemCount = 0
+        self.Cmd = 0xAA
+        self.SubCmd = 0x57
+        self.ActNum = 0
+        self.GarbageSortingType = 0
+        self.IsRight = 0
+        self.AddEnvValue = 0
         return
 
     def GetLength(self):
-        return sizeof(tagMCActGarbageTaskItem)
+        return sizeof(tagMCActGarbageSortingResult)
 
     def GetBuffer(self):
         return string_at(addressof(self), self.GetLength())
 
     def OutputString(self):
-        DumpString = '''// AA 56 垃圾收集活动任务进度信息 //tagMCActGarbageTaskInfo:
-                                ItemID:%d,
-                                ItemCount:%d
+        DumpString = '''// AA 57 垃圾收集活动分类结果 //tagMCActGarbageSortingResult:
+                                Cmd:%s,
+                                SubCmd:%s,
+                                ActNum:%d,
+                                GarbageSortingType:%d,
+                                IsRight:%d,
+                                AddEnvValue:%d
                                 '''\
                                 %(
-                                self.ItemID,
-                                self.ItemCount
+                                self.Cmd,
+                                self.SubCmd,
+                                self.ActNum,
+                                self.GarbageSortingType,
+                                self.IsRight,
+                                self.AddEnvValue
                                 )
         return DumpString
 
+
+m_NAtagMCActGarbageSortingResult=tagMCActGarbageSortingResult()
+ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCActGarbageSortingResult.Cmd,m_NAtagMCActGarbageSortingResult.SubCmd))] = m_NAtagMCActGarbageSortingResult
+
+
+#------------------------------------------------------
+# AA 56 垃圾收集活动任务进度信息 #tagMCActGarbageTaskInfo
 
 class  tagMCActGarbageTask(Structure):
     _pack_ = 1
@@ -24812,8 +24837,6 @@
     ActNum = 0    #(BYTE ActNum)// 活动编号
     GarbageTaskCount = 0    #(BYTE GarbageTaskCount)//任务数
     GarbageTaskList = list()    #(vector<tagMCActGarbageTask> GarbageTaskList)//任务信息列表
-    TaskItemCount = 0    #(BYTE TaskItemCount)//本次获得的垃圾收集任务奖励物品个数,可能为0
-    GarbageTaskItemList = list()    #(vector<tagMCActGarbageTaskItem> GarbageTaskItemList)
     data = None
 
     def __init__(self):
@@ -24831,11 +24854,6 @@
             temGarbageTaskList = tagMCActGarbageTask()
             _pos = temGarbageTaskList.ReadData(_lpData, _pos)
             self.GarbageTaskList.append(temGarbageTaskList)
-        self.TaskItemCount,_pos = CommFunc.ReadBYTE(_lpData, _pos)
-        for i in range(self.TaskItemCount):
-            temGarbageTaskItemList = tagMCActGarbageTaskItem()
-            _pos = temGarbageTaskItemList.ReadData(_lpData, _pos)
-            self.GarbageTaskItemList.append(temGarbageTaskItemList)
         return _pos
 
     def Clear(self):
@@ -24846,8 +24864,6 @@
         self.ActNum = 0
         self.GarbageTaskCount = 0
         self.GarbageTaskList = list()
-        self.TaskItemCount = 0
-        self.GarbageTaskItemList = list()
         return
 
     def GetLength(self):
@@ -24857,9 +24873,6 @@
         length += 1
         for i in range(self.GarbageTaskCount):
             length += self.GarbageTaskList[i].GetLength()
-        length += 1
-        for i in range(self.TaskItemCount):
-            length += self.GarbageTaskItemList[i].GetLength()
 
         return length
 
@@ -24870,9 +24883,6 @@
         data = CommFunc.WriteBYTE(data, self.GarbageTaskCount)
         for i in range(self.GarbageTaskCount):
             data = CommFunc.WriteString(data, self.GarbageTaskList[i].GetLength(), self.GarbageTaskList[i].GetBuffer())
-        data = CommFunc.WriteBYTE(data, self.TaskItemCount)
-        for i in range(self.TaskItemCount):
-            data = CommFunc.WriteString(data, self.GarbageTaskItemList[i].GetLength(), self.GarbageTaskItemList[i].GetBuffer())
         return data
 
     def OutputString(self):
@@ -24880,16 +24890,12 @@
                                 Head:%s,
                                 ActNum:%d,
                                 GarbageTaskCount:%d,
-                                GarbageTaskList:%s,
-                                TaskItemCount:%d,
-                                GarbageTaskItemList:%s
+                                GarbageTaskList:%s
                                 '''\
                                 %(
                                 self.Head.OutputString(),
                                 self.ActNum,
                                 self.GarbageTaskCount,
-                                "...",
-                                self.TaskItemCount,
                                 "..."
                                 )
         return DumpString
diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py
index ea699ce..78a2257 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py
@@ -24723,17 +24723,23 @@
 
 
 #------------------------------------------------------
-# AA 56 垃圾收集活动任务进度信息 #tagMCActGarbageTaskInfo
+# AA 57 垃圾收集活动分类结果 #tagMCActGarbageSortingResult
 
-class  tagMCActGarbageTaskItem(Structure):
+class  tagMCActGarbageSortingResult(Structure):
     _pack_ = 1
     _fields_ = [
-                  ("ItemID", c_int),    
-                  ("ItemCount", c_ushort),    
+                  ("Cmd", c_ubyte),
+                  ("SubCmd", c_ubyte),
+                  ("ActNum", c_ubyte),    #活动编号
+                  ("GarbageSortingType", c_ubyte),    #垃圾分类类型
+                  ("IsRight", c_ubyte),    #是否正确
+                  ("AddEnvValue", c_ushort),    #增加环保值
                   ]
 
     def __init__(self):
         self.Clear()
+        self.Cmd = 0xAA
+        self.SubCmd = 0x57
         return
 
     def ReadData(self, stringData, _pos=0, _len=0):
@@ -24742,27 +24748,46 @@
         return _pos + self.GetLength()
 
     def Clear(self):
-        self.ItemID = 0
-        self.ItemCount = 0
+        self.Cmd = 0xAA
+        self.SubCmd = 0x57
+        self.ActNum = 0
+        self.GarbageSortingType = 0
+        self.IsRight = 0
+        self.AddEnvValue = 0
         return
 
     def GetLength(self):
-        return sizeof(tagMCActGarbageTaskItem)
+        return sizeof(tagMCActGarbageSortingResult)
 
     def GetBuffer(self):
         return string_at(addressof(self), self.GetLength())
 
     def OutputString(self):
-        DumpString = '''// AA 56 垃圾收集活动任务进度信息 //tagMCActGarbageTaskInfo:
-                                ItemID:%d,
-                                ItemCount:%d
+        DumpString = '''// AA 57 垃圾收集活动分类结果 //tagMCActGarbageSortingResult:
+                                Cmd:%s,
+                                SubCmd:%s,
+                                ActNum:%d,
+                                GarbageSortingType:%d,
+                                IsRight:%d,
+                                AddEnvValue:%d
                                 '''\
                                 %(
-                                self.ItemID,
-                                self.ItemCount
+                                self.Cmd,
+                                self.SubCmd,
+                                self.ActNum,
+                                self.GarbageSortingType,
+                                self.IsRight,
+                                self.AddEnvValue
                                 )
         return DumpString
 
+
+m_NAtagMCActGarbageSortingResult=tagMCActGarbageSortingResult()
+ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCActGarbageSortingResult.Cmd,m_NAtagMCActGarbageSortingResult.SubCmd))] = m_NAtagMCActGarbageSortingResult
+
+
+#------------------------------------------------------
+# AA 56 垃圾收集活动任务进度信息 #tagMCActGarbageTaskInfo
 
 class  tagMCActGarbageTask(Structure):
     _pack_ = 1
@@ -24812,8 +24837,6 @@
     ActNum = 0    #(BYTE ActNum)// 活动编号
     GarbageTaskCount = 0    #(BYTE GarbageTaskCount)//任务数
     GarbageTaskList = list()    #(vector<tagMCActGarbageTask> GarbageTaskList)//任务信息列表
-    TaskItemCount = 0    #(BYTE TaskItemCount)//本次获得的垃圾收集任务奖励物品个数,可能为0
-    GarbageTaskItemList = list()    #(vector<tagMCActGarbageTaskItem> GarbageTaskItemList)
     data = None
 
     def __init__(self):
@@ -24831,11 +24854,6 @@
             temGarbageTaskList = tagMCActGarbageTask()
             _pos = temGarbageTaskList.ReadData(_lpData, _pos)
             self.GarbageTaskList.append(temGarbageTaskList)
-        self.TaskItemCount,_pos = CommFunc.ReadBYTE(_lpData, _pos)
-        for i in range(self.TaskItemCount):
-            temGarbageTaskItemList = tagMCActGarbageTaskItem()
-            _pos = temGarbageTaskItemList.ReadData(_lpData, _pos)
-            self.GarbageTaskItemList.append(temGarbageTaskItemList)
         return _pos
 
     def Clear(self):
@@ -24846,8 +24864,6 @@
         self.ActNum = 0
         self.GarbageTaskCount = 0
         self.GarbageTaskList = list()
-        self.TaskItemCount = 0
-        self.GarbageTaskItemList = list()
         return
 
     def GetLength(self):
@@ -24857,9 +24873,6 @@
         length += 1
         for i in range(self.GarbageTaskCount):
             length += self.GarbageTaskList[i].GetLength()
-        length += 1
-        for i in range(self.TaskItemCount):
-            length += self.GarbageTaskItemList[i].GetLength()
 
         return length
 
@@ -24870,9 +24883,6 @@
         data = CommFunc.WriteBYTE(data, self.GarbageTaskCount)
         for i in range(self.GarbageTaskCount):
             data = CommFunc.WriteString(data, self.GarbageTaskList[i].GetLength(), self.GarbageTaskList[i].GetBuffer())
-        data = CommFunc.WriteBYTE(data, self.TaskItemCount)
-        for i in range(self.TaskItemCount):
-            data = CommFunc.WriteString(data, self.GarbageTaskItemList[i].GetLength(), self.GarbageTaskItemList[i].GetBuffer())
         return data
 
     def OutputString(self):
@@ -24880,16 +24890,12 @@
                                 Head:%s,
                                 ActNum:%d,
                                 GarbageTaskCount:%d,
-                                GarbageTaskList:%s,
-                                TaskItemCount:%d,
-                                GarbageTaskItemList:%s
+                                GarbageTaskList:%s
                                 '''\
                                 %(
                                 self.Head.OutputString(),
                                 self.ActNum,
                                 self.GarbageTaskCount,
-                                "...",
-                                self.TaskItemCount,
                                 "..."
                                 )
         return DumpString
diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActGarbageSorting.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActGarbageSorting.py
index 9fbfda5..b7977b6 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActGarbageSorting.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActGarbageSorting.py
@@ -182,7 +182,7 @@
     
     ItemControler.GivePlayerItemOrMail(curPlayer, giveItemList)
     
-    Sync_GarbageTaskInfo(curPlayer, actNum, taskID, giveItemList)
+    Sync_GarbageTaskInfo(curPlayer, actNum, taskID)
     return True
 
 #// AA 14 垃圾分类活动分类垃圾 #tagCMActGarbageSorting
@@ -205,6 +205,7 @@
     
     GameWorld.DebugLog("垃圾分类投放: sortingType=%s,itemIndexList=%s" % (sortingType, itemIndexList), playerID)
     
+    isRight = 1
     environmentValueInfo = IpyGameDataPY.GetFuncEvalCfg("GarbageSorting", 2)
     addEnvValueTotal = 0
     garbagePack = curPlayer.GetItemManager().GetPack(ShareDefine.rptGarbage)
@@ -219,11 +220,10 @@
         if sortingType == itemSortingType:
             delCount = curItem.GetCount()
             addEnvValue = environmentValueInfo[0] * delCount
-            PlayerControl.NotifyCode(curPlayer, "GarbageSortingRight", [addEnvValue])
         else:
             delCount = 1 # 错误只扣除1一个
             addEnvValue = environmentValueInfo[1] * delCount
-            PlayerControl.NotifyCode(curPlayer, "GarbageSortingWrong", [addEnvValue])
+            isRight = 0
             
         ItemControler.SetItemCount(curItem, max(0, curItem.GetCount() - delCount))
         addEnvValueTotal += addEnvValue
@@ -240,6 +240,14 @@
                        % (addEnvValueTotal, actEnvValueTotal, PlayerControl.GetMoney(curPlayer, ShareDefine.TYPE_Price_Environment)), playerID)
     
     PlayerBillboard.UpdatePlayerBillboard(curPlayer, ShareDefine.Def_BT_Environment, actEnvValueTotal)
+    
+    # 通知结果
+    clientPack = ChPyNetSendPack.tagMCActGarbageSortingResult()
+    clientPack.ActNum = actNum
+    clientPack.GarbageSortingType = sortingType
+    clientPack.IsRight = isRight
+    clientPack.AddEnvValue = addEnvValueTotal
+    NetPackCommon.SendFakePack(curPlayer, clientPack)
     return
 
 
@@ -258,7 +266,7 @@
     __DoCheckFinishGarbageTask(curPlayer, actNum, taskID)
     return
 
-def Sync_GarbageTaskInfo(curPlayer, actNum, taskID=0, awardItemList=None):
+def Sync_GarbageTaskInfo(curPlayer, actNum, taskID=0):
     ## 通知垃圾收集任务信息
     syncTaskIDList = [taskID] if taskID else ChConfig.GarbageTaskList
     clientPack = ChPyNetSendPack.tagMCActGarbageTaskInfo()
@@ -271,14 +279,6 @@
         task.GarbageTaskFinishCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_GarbageTaskFinishCount % (actNum, taskID))
         clientPack.GarbageTaskList.append(task)
     clientPack.GarbageTaskCount = len(clientPack.GarbageTaskList)
-    
-    if awardItemList:
-        for itemID, itemCount, _ in awardItemList:
-            item = ChPyNetSendPack.tagMCActGarbageTaskItem()
-            item.ItemID = itemID
-            item.ItemCount = itemCount
-            clientPack.GarbageTaskItemList.append(item)
-        clientPack.TaskItemCount = len(clientPack.GarbageTaskItemList)
     NetPackCommon.SendFakePack(curPlayer, clientPack)
     return
 

--
Gitblit v1.8.0