| | |
| | | ipyData = IpyGameDataPY.GetIpyGameData("HeroQualityBreak", quality, breakLV)
|
| | | if not ipyData:
|
| | | return
|
| | | LVMax = ipyData.GetLVMax()
|
| | | if heroLV < LVMax:
|
| | | GameWorld.DebugLog("未满级,无法突破: heroLV=%s < %s" % (heroLV, LVMax), playerID)
|
| | | UPLVNeed = ipyData.GetUPLVNeed()
|
| | | if heroLV < UPLVNeed:
|
| | | GameWorld.DebugLog("武将等级不足,无法突破: heroLV=%s < %s" % (heroLV, UPLVNeed), playerID)
|
| | | return
|
| | | nextBreakLV = breakLV + 1
|
| | | if not IpyGameDataPY.GetIpyGameData("HeroQualityBreak", quality, nextBreakLV):
|
| | | GameWorld.DebugLog("突破等级已满级: quality=%s,breakLV=%s" % (quality, breakLV), playerID)
|
| | | return
|
| | | costItemInfo = ipyData.GetUPCostItem()
|
| | | if not costItemInfo:
|
| | | return
|
| | | costItemID, costItemCount = costItemInfo
|
| | | if not costItemID or not costItemCount:
|
| | | costItemList = ipyData.GetUPCostItemList()
|
| | | if not costItemList:
|
| | | return
|
| | | itemPack = curPlayer.GetItemManager().GetPack(IPY_GameWorld.rptItem)
|
| | | hasEnough, itemIndexList = ItemCommon.GetItem_FromPack_ByID(costItemID, itemPack, costItemCount)
|
| | | if not hasEnough:
|
| | | GameWorld.DebugLog("材料不足,武将无法突破! costItemID=%s, costItemCount=%s" % (costItemID, costItemCount))
|
| | | lackItemDict, delInfoDict = ItemCommon.GetCostItemIndexList(costItemList, itemPack)
|
| | | if lackItemDict:
|
| | | GameWorld.DebugLog("材料不足,武将无法突破! quality=%s,breakLV=%s,lackItemDict=%s" % (quality, breakLV, lackItemDict), playerID)
|
| | | return
|
| | | ItemCommon.ReduceItem(curPlayer, itemPack, itemIndexList, costItemCount, True, "HeroBreak")
|
| | | ItemCommon.DelCostItem(curPlayer, itemPack, delInfoDict, "HeroBreak")
|
| | | |
| | | GameWorld.DebugLog("武将突破: itemIndex=%s,heroID=%s,nextBreakLV=%s" % (itemIndex, heroID, nextBreakLV), playerID)
|
| | | SetHeroBreakLV(curPlayer, heroItem, nextBreakLV)
|
| | |
|