| | |
| | | # BYTE EquipIndex; //神兽装备背包中索引
|
| | | # BYTE IndexCount; //材料所在神兽物品背包索引的数量
|
| | | # BYTE IndexList[IndexCount]; //材料所在神兽物品背包索引列表
|
| | | # BYTE IndexUseCountList[IndexCount]; //材料所在神兽物品背包索引对应使用个数列表
|
| | | # BYTE IsDouble; //是否双倍强化
|
| | | #};
|
| | | def OnDogzEquipPlus(index, clientData, tick):
|
| | |
| | | playerID = curPlayer.GetPlayerID()
|
| | | equipIndex = clientData.EquipIndex
|
| | | indexList = clientData.IndexList
|
| | | indexUseCountList = clientData.IndexUseCountList
|
| | | isDouble = clientData.IsDouble
|
| | | GameWorld.DebugLog("神兽装备强化: equipIndex=%s,indexList=%s,isDouble=%s" % (equipIndex, indexList, isDouble), playerID)
|
| | | GameWorld.DebugLog("神兽装备强化: equipIndex=%s,indexList=%s,indexUseCountList=%s,isDouble=%s" |
| | | % (equipIndex, indexList, indexUseCountList, isDouble), playerID)
|
| | | |
| | | if len(indexList) != len(indexUseCountList):
|
| | | GameWorld.DebugLog(" 指定消耗的个数数据长度错误!")
|
| | | return
|
| | |
|
| | | dogzEquipPack = curPlayer.GetItemManager().GetPack(ShareDefine.rptDogzEquip)
|
| | | curEquip = dogzEquipPack.GetAt(equipIndex)
|
| | |
| | | GameWorld.ErrLog("神兽背包物品无经验效果,无法强化!i=%s,itemID=%s" % (i, curItem.GetItemTypeID()), playerID)
|
| | | return
|
| | |
|
| | | delCount = max(1, min(curItem.GetCount(), indexUseCountList[i]))
|
| | | baseExp = effect.GetEffectValue(0)
|
| | | doubleCostGold = effect.GetEffectValue(1)
|
| | |
|
| | | addExp = baseExp
|
| | | addExp = baseExp * delCount
|
| | | plusInfoCount = curItem.GetUserAttrCount(ShareDefine.Def_IudetDogzEquipPlus)
|
| | | if not plusInfoCount:
|
| | | if isDouble and doubleCostGold:
|
| | | addExp = (baseExp * 2)
|
| | | costGoldTotal += doubleCostGold
|
| | | GameWorld.DebugLog(" 强化: addExp=%s,baseExp=%s,isDouble=%s,doubleCostGold=%s,costGoldTotal=%s" |
| | | % (addExp, baseExp, isDouble, doubleCostGold, costGoldTotal), playerID)
|
| | | addExp = (baseExp * 2 * delCount)
|
| | | costGoldTotal += doubleCostGold * delCount
|
| | | GameWorld.DebugLog(" 强化: addExp=%s,delCount=%s,baseExp=%s,isDouble=%s,doubleCostGold=%s,costGoldTotal=%s" |
| | | % (addExp, delCount, baseExp, isDouble, doubleCostGold, costGoldTotal), playerID)
|
| | | else:
|
| | | #plusLV = curItem.GetUserAttrByIndex(ShareDefine.Def_IudetDogzEquipPlus, 0)
|
| | | plusExpTotal = curItem.GetUserAttrByIndex(ShareDefine.Def_IudetDogzEquipPlus, 1)
|
| | | addExp += plusExpTotal
|
| | | GameWorld.DebugLog(" 强化: addExp=%s,baseExp=%s,plusExpTotal=%s" % (addExp, baseExp, plusExpTotal), playerID)
|
| | | GameWorld.DebugLog(" 强化: addExp=%s,delCount=%s,baseExp=%s,plusExpTotal=%s" % (addExp, delCount, baseExp, plusExpTotal), playerID)
|
| | | addExpTotal += addExp
|
| | | delItemList.append(curItem)
|
| | | delItemList.append([curItem, delCount])
|
| | |
|
| | | if not delItemList:
|
| | | GameWorld.DebugLog(" 没有材料可强化!", playerID)
|
| | |
| | | ChConfig.Def_Cost_DogzEquipPlus, infoDict):
|
| | | return
|
| | |
|
| | | for delItem in delItemList:
|
| | | ItemCommon.DelItem(curPlayer, delItem, curItem.GetCount(), False, ChConfig.ItemDel_DogzEquipPlus, infoDict)
|
| | | for delItem, delCount in delItemList:
|
| | | ItemCommon.DelItem(curPlayer, delItem, delCount, False, ChConfig.ItemDel_DogzEquipPlus, infoDict)
|
| | |
|
| | | updPlusLV = curPlusLV
|
| | | doCount, maxDoCount = 0, maxPlusLV * 2
|