From 6fcf3513ccde191e067c8dfd8279cccedf95eb77 Mon Sep 17 00:00:00 2001
From: hch <305670599@qq.com>
Date: 星期五, 17 五月 2019 19:22:25 +0800
Subject: [PATCH] 6603 【后端】【2.0】增加新版的sp和被动技能 - 新版
---
ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Event/EventSrc/Operate_EquipStar.py | 48 ++++++++++++++++++++++++++++--------------------
1 files changed, 28 insertions(+), 20 deletions(-)
diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Event/EventSrc/Operate_EquipStar.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Event/EventSrc/Operate_EquipStar.py
index 993d160..83a3a01 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Event/EventSrc/Operate_EquipStar.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Event/EventSrc/Operate_EquipStar.py
@@ -24,6 +24,7 @@
import DataRecordPack
import IpyGameDataPY
import GameWorld
+import EventShell
import ChConfig
import ChEquip
#-------------------------------------------------------------------------------------------
@@ -92,7 +93,7 @@
if updPartStar in IpyGameDataPY.GetFuncEvalCfg('EquipPartStarNotify'):
PlayerControl.WorldNotify(0, "StarLevelUp", [curPlayer.GetPlayerName(), curEquip.GetItemTypeID(), updPartStar])
- #EventShell.EventRespons_EquipPlus(curPlayer)
+ EventShell.EventRespons_EquipStarUp(curPlayer)
return
@@ -112,27 +113,34 @@
return result
costEquipPlaceList = ipyData.GetCostEquipPlace()
costEquipColorList = ipyData.GetCostEquipColor()
+ isJobLimit = ipyData.GetIsJobLimit()
suitTotalRate = ipyData.GetSuitTotalRate()
- singleSuitRate = float(suitTotalRate) / costEquipCnt
- curRate = 0 #成功概率
- delEquipIndexList = []
itemPack = curPlayer.GetItemManager().GetPack(IPY_GameWorld.rptItem)
- for i, index in enumerate(clientData.CostEquipIndex):
- costEquip = itemPack.GetAt(index)
- if not costEquip or costEquip.IsEmpty():
- return result
- equipID = costEquip.GetItemTypeID()
- if equipID != clientData.CostEquipID[i]:
- GameWorld.ErrLog(' 装备升星 客户端发的物品索引与实际物品ID不对应 index=%s,eatItemID=%s,wantEatItemID=%s' % (index, equipID, clientData.CostEquipID[i]))
- return result
- if costEquip.GetItemColor() not in costEquipColorList:
- return result
- if costEquip.GetEquipPlace() not in costEquipPlaceList:
- return result
- delEquipIndexList.append(index)
- isSuite = costEquip.GetSuiteID()
- addRate = singleSuitRate if isSuite else singleSuitRate / 2
- curRate += addRate
+ delEquipIndexList = []
+ if not costEquipCnt:
+ curRate = suitTotalRate / 2
+ else:
+ singleSuitRate = float(suitTotalRate) / costEquipCnt
+ curRate = 0 #成功概率
+
+ for i, index in enumerate(clientData.CostEquipIndex):
+ costEquip = itemPack.GetAt(index)
+ if not costEquip or costEquip.IsEmpty():
+ return result
+ equipID = costEquip.GetItemTypeID()
+ if equipID != clientData.CostEquipID[i]:
+ GameWorld.ErrLog(' 装备升星 客户端发的物品索引与实际物品ID不对应 index=%s,eatItemID=%s,wantEatItemID=%s' % (index, equipID, clientData.CostEquipID[i]))
+ return result
+ if costEquip.GetItemColor() not in costEquipColorList:
+ return result
+ if costEquip.GetEquipPlace() not in costEquipPlaceList:
+ return result
+ if isJobLimit and not ItemCommon.CheckJob(curPlayer, costEquip):
+ return result
+ delEquipIndexList.append(index)
+ isSuite = costEquip.GetSuiteID()
+ addRate = singleSuitRate if isSuite else singleSuitRate / 2
+ curRate += addRate
if curRate <= 0:
GameWorld.Log('装备升星异常 概率为0!!equipPackIndex=%s'%equipPackIndex)
return result
--
Gitblit v1.8.0