From 9d5f1996ab520ab5ede2b153a15c3b8b74be662e Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期五, 29 三月 2019 17:19:17 +0800
Subject: [PATCH] 3040 【BUG】【1.6】跨服pk,快速点击购买次数,可以超出上限

---
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py |   62 ++++++-------------------------
 1 files changed, 12 insertions(+), 50 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 5613819..591fedb 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py
@@ -31,6 +31,7 @@
 import ChPyNetSendPack
 import NetPackCommon
 import Operate_EquipStone
+import PlayerMagicWeapon
 import IpyGameDataPY
 import DataRecordPack
 import EventShell
@@ -113,7 +114,7 @@
     for i in range(0, curPack.GetCount()):
         item = curPack.GetAt(i)
         
-        if not ItemCommon.CheckItemCanUse(item):
+        if not ItemCommon.CheckItemCanUse(item) or GetIsAuctionItem(item):
             continue
         
         if item.GetItemTypeID() == id:
@@ -133,7 +134,7 @@
     for i in range(0, curPack.GetCount()):
         item = curPack.GetAt(i)
         
-        if not ItemCommon.CheckItemCanUse(item):
+        if not ItemCommon.CheckItemCanUse(item) or GetIsAuctionItem(item):
             continue
         
         if item.GetItemTypeID() == id:
@@ -152,7 +153,7 @@
     for i in range(0, curPack.GetCount()):
         item = curPack.GetAt(i)
         
-        if not ItemCommon.CheckItemCanUse(item):
+        if not ItemCommon.CheckItemCanUse(item) or GetIsAuctionItem(item):
             continue
         
         effect = item.GetEffectByIndex(0)
@@ -273,7 +274,7 @@
     for i in range(0, curPack.GetCount()):
         
         item = curPack.GetAt(i)
-        if not ItemCommon.CheckItemCanUse(item):
+        if not ItemCommon.CheckItemCanUse(item) or GetIsAuctionItem(item):
             continue
         
         if item.GetItemTypeID() != id:
@@ -478,40 +479,6 @@
         #GameWorld.DebugLog("不需要记录的物品类型或ID! itemType=%s,itemID=%s" % (itemType, itemID))
         return True
     return False
-
-#物品属性判断------------------------------------------------------------------
-## 使用物品检查是否满足属性
-#  @param curPlayer 当前玩家
-#  @param curItem 当前物品
-#  @return False or True
-def CheckItemAttrLimit(curPlayer, curItem):
-    # 取消限制的物品
-    if curItem.GetUserAttr(ShareDefine.Def_IudetCancelUseLimit) == 1:
-        return True
-    #智力为基础限制
-    if curItem.GetLimitPNE() > curPlayer.GetPNE():
-        return False
-    
-    #由于可变属性强化表加载问题, 暂时不处理强化表的属性点限制,以物品表为主,如有需要再开启此判断 20151210 by hxp
-    # 从强化表中获得数据,装备强化限制力量 敏捷
-#    if curItem.GetType() in ReadChConfig.GetEvalChConfig("EquipPlus_EquipType"):
-#        plusInfo = ...
-#        
-#        if plusInfo is None:
-#            GameWorld.ErrLog("tagItemPlus.txt can't find equip:%s" % curItem.GetItemTypeID())
-#            return False
-#             
-#        limitSTR, limitPHY = plusInfo.GetLimitSTR(), plusInfo.GetLimitPHY()
-#    
-#    # 物品表中获得信息
-#    else:
-    limitSTR, limitPHY = curItem.GetLimitSTR(), curItem.GetLimitPHY()
-    
-    if limitSTR > curPlayer.GetSTR() or limitPHY > curPlayer.GetPHY():
-        return False
-    
-    return True
-
 
 #物品使用等级判断----------------------------------------------------------------
 ## 物品使用等级判断
@@ -776,7 +743,7 @@
 #            return False
         
         #职业检查
-        if not ItemCommon.JobUseable(curPlayer, curItem):
+        if not ItemCommon.CheckJob(curPlayer, curItem):
             if needNotify:
                 PlayerControl.NotifyCode(curPlayer, "GeRen_lhs_31379")
 
@@ -794,13 +761,7 @@
         #等级检查
         if not CheckItemUseLV(curPlayer, curItem, needNotify):
             return False
-
-        #使用物品检查是否满足属性
-        if not CheckItemAttrLimit(curPlayer, curItem):
-            if needNotify:
-                PlayerControl.NotifyCode(curPlayer, "itemuse_andyshao_671654")
-            return False
-    
+        
         #=======================================================================
         # #马匹检查
         # if curItem.GetType() == ChConfig.Def_Item_Type_Horse and not CheckCanEquipHorse(curPlayer):
@@ -1124,7 +1085,7 @@
         packIndex = ChConfig.GetItemPackType(curItemData.GetType(), packIndex)
         
         tagItemCount = GetItemCount(tagItem)
-        isAuctionItem = tagItem.GetIsBind()
+        isAuctionItem = GetIsAuctionItem(tagItem)
         if not self.CanPutInItem(packIndex, tagItem.GetItemTypeID(), tagItemCount, isAuctionItem, defaultPile):
             GameWorld.DebugLog("背包满,不能放入物品 count = %d"%GetItemCount(tagItem))
             tagItem.Clear()
@@ -1134,7 +1095,8 @@
         itemID = tagItem.GetItemTypeID()
         #激活成就的道具
         if tagItem.GetType() == ChConfig.Def_ItemType_SuccessItem:
-            PlayerSuccess.DoAddSuccessProgress(curPlayer, ShareDefine.SuccType_GetSpecialItem, 1, [tagItem.GetEffectByIndex(0).GetEffectValue(0)])
+            PlayerMagicWeapon.DoActiveMW(curPlayer, tagItem.GetEffectByIndex(0).GetEffectValue(0))
+            tagItem.Clear()
             return True
         if itemID in ChConfig.Def_TransformItemIDList:
             # 直接转化为对应货币的物品仅在放入背包时直接转化,否则还是以真实物品的形式存在,但堆叠上限需要做特殊处理
@@ -1552,7 +1514,7 @@
     #curItemGUID = curItem.GetGUID()
     curItemCount = curItem.GetCount()
     #curItemIsBind = curItem.GetIsBind()
-    isAuctionItem = curItem.GetIsBind()
+    isAuctionItem = GetIsAuctionItem(curItem)
     #toPackIndex = ChConfig.GetItemPackType(curItem.GetType(), toPackIndex)
     
     # 常规物品转移到虚拟符印背包
@@ -2409,7 +2371,7 @@
     '''获取生成到装备上的传奇属性
     @return: None 或者 [[传奇属性效果ID列表], [属性值列表]]
     '''
-    if curItem.GetIsBind():
+    if GetIsAuctionItem(curItem):
         #GameWorld.DebugLog("拍品无法生成传奇属性!")
         return
     itemID = curItem.GetItemTypeID()

--
Gitblit v1.8.0