hxp
2018-09-20 22349866372ce1b603b8eebcf5d43e7772ac0ddb
ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Item/ItemControler.py
@@ -1009,7 +1009,7 @@
#    小心, 小心, 小心, 小心, 小心
#    eggxp
#===============================================================================
    def __PutItemInVPack(self, packIndex, tagItem, event):
    def PutItemInVPack(self, packIndex, tagItem, event=["", False, {}]):
        # 虚拟背包, 默认不做叠加
        curPlayer = self.__Player
        canPutInCnt = 1
@@ -1017,7 +1017,8 @@
        eventName, isForceEvent, addDict = event
        isNeedRecord = isForceEvent or ItemNeedRecord(tagItem)
        if packIndex == ShareDefine.rptRune:
            setItemKeyData = GetRuneItemKeyData(tagItem.GetItemTypeID(), tagItem.GetUserAttr(ShareDefine.Def_IudetRuneLV))
            runeSource = tagItem.GetUserAttr(ShareDefine.Def_IudetRuneSource) or 1
            setItemKeyData = GetRuneItemKeyData(tagItem.GetItemTypeID(), tagItem.GetUserAttr(ShareDefine.Def_IudetRuneLV), source=runeSource)
        refreshPlaceList = []
        for place in xrange(ItemCommon.GetVPackCnt(packIndex)):
@@ -1044,11 +1045,11 @@
            Sync_VPackItem_Refresh(curPlayer, packIndex, refreshPlaceList)
        if tagItem and not tagItem.IsEmpty():
            tagItem.Clear()
            #tagItem.Clear()
            return False
        return True
    
    def __DoTransformItem(self, curPlayer, tagItem):
    def DoTransformItem(self, curPlayer, tagItem):
        ## 将特殊物品转化为对应数值
        itemID = tagItem.GetItemTypeID()
        if itemID not in ChConfig.Def_TransformItemIDList:
@@ -1070,6 +1071,8 @@
        elif itemID == ChConfig.Def_ItemID_BossReborn:
            msgStr = str(itemCount)
            GameWorld.GetPlayerManager().GameServer_QueryPlayerResult(0, 0, 0, 'AddBossRebornPoint', msgStr, len(msgStr))
        elif itemID == ChConfig.Def_ItemID_Ysog:
            PlayerControl.GiveMoney(curPlayer, ShareDefine.TYPE_Price_Ysog, itemCount)
        
        return True
    
@@ -1082,8 +1085,8 @@
    def PutInItem(self, packIndex, tagItem, defaultPile=True, event=["", False, {}]):
        curPlayer = self.__Player
        
        if self.__DoTransformItem(curPlayer, tagItem):
            tagItem.Clear() # 需清除,不然会导致内存泄露
        if packIndex != ShareDefine.rptTreasure and self.DoTransformItem(curPlayer, tagItem):
            tagItem.Clear() # 需清除,不然会导致内存泄露   寻宝仓库可暂存直接转化数值的物品
            return True
        
        isEquip = ItemCommon.CheckItemIsEquip(tagItem)
@@ -1103,7 +1106,7 @@
        
        # 虚拟背包, 默认不做叠加
        if packIndex in ShareDefine.Def_VPack_TypeList:
            return self.__PutItemInVPack(packIndex, tagItem, event)
            return self.PutItemInVPack(packIndex, tagItem, event)
        
        eventName, isForceEvent, addDict = event
@@ -1295,13 +1298,14 @@
        return True, itemIndex
    
#==============================================================================
# 符印物品存储字典数值数据结构: 前5位为物品ID, 6~8位为强化等级, 第10位为是否锁定
def GetRuneItemKeyData(itemID, RuneLV, lockState=0):
# 符印物品存储字典数值数据结构: 前5位为物品ID, 6~8位为强化等级, 第9位为来源(老号0,默认1,合成2),第10位为是否锁定
def GetRuneItemKeyData(itemID, RuneLV, lockState=0, source=1):
    lockState = 1 if lockState > 0 else 0
    return lockState * 1000000000 + min(RuneLV, 999) * 100000 + itemID
    return lockState * 1000000000 + source * 100000000 + min(RuneLV, 999) * 100000 + itemID
def GetRuneItemID(keyData): return keyData % 100000
def GetRuneItemPlusLV(keyData): return keyData % 100000000 / 100000
def GetRuneItemIsLock(keyData): return keyData / 1000000000
def GetRuneItemSource(keyData): return keyData % 1000000000 / 100000000
def IsRuneItemNeedRecord(curItem, plusLV):
    return plusLV > 0 or curItem.GetItemColor() >= ChConfig.Def_Quality_Orange
@@ -1360,7 +1364,7 @@
    DropItemToOtherPack(curPlayer, clientData.SrcBackpack, clientData.DesBackPack, clientData.SrcIndex, clientData.IsAll)
    return
def DropItemToOtherPack(curPlayer, fromPackIndex, toPackIndex, index, isAll=False):
def DropItemToOtherPack(curPlayer, fromPackIndex, desPackIndex, index, isAll=False):
    '''拖动某个背包物品到玩家物品背包
    '''
    movePack = curPlayer.GetItemManager().GetPack(fromPackIndex)
@@ -1371,26 +1375,46 @@
    
    #整个背包转移
    if isAll:
        fullPackList = []
        for itemIndex in xrange(movePack.GetCount()):
            curItem = movePack.GetAt(itemIndex)
            if not curItem or curItem.IsEmpty():
                continue
            toPackIndex = ChConfig.GetItemPackType(curItem.GetType(), desPackIndex)
            if toPackIndex in fullPackList:
                continue
            if not __DoDropItemToOtherPack(curPlayer, itemControl, fromPackIndex, toPackIndex, itemIndex, curItem):
                return
                if toPackIndex not in fullPackList:
                    fullPackList.append(toPackIndex)
        for fullPackIndex in fullPackList:
            PlayerControl.NotifyCode(curPlayer, "GeRen_chenxin_676165", [fullPackIndex])
            
    #单个物品转移
    else:
        curItem = movePack.GetAt(index)
        if not curItem or curItem.IsEmpty():
            return
        toPackIndex = ChConfig.GetItemPackType(curItem.GetType(), desPackIndex)
        __DoDropItemToOtherPack(curPlayer, itemControl, fromPackIndex, toPackIndex, index, curItem)
    return
def __DoDropItemToOtherPack(curPlayer, itemControl, fromPackIndex, toPackIndex, itemIndex, curItem):
    if itemControl.DoTransformItem(curPlayer, curItem):
        curItem.Clear()
        return True
    curItemTypeID = curItem.GetItemTypeID()
    #curItemGUID = curItem.GetGUID()
    curItemCount = curItem.GetCount()
    curItemIsBind = curItem.GetIsBind()
    #toPackIndex = ChConfig.GetItemPackType(curItem.GetType(), toPackIndex)
    # 常规物品转移到虚拟符印背包
    if toPackIndex == ShareDefine.rptRune:
        if not ItemCommon.CheckPackHasSpace(curPlayer, toPackIndex, True):
            return False
        return itemControl.PutItemInVPack(toPackIndex, curItem)
    checkRet, putIndex = itemControl.CanPutInItemEx(toPackIndex, curItemTypeID, curItemCount, curItemIsBind)
    if not checkRet:
        return False
@@ -1571,6 +1595,8 @@
    itemList = []   # 非装备普通物品
    equipGSGreaterList = [] # 属于本职业的高评分装备
    equipGSLesserList = []  # 低评分装备和非本职业
    runeItemList = []   # 符印
    #EquipGSTypeForSort
    equipPack = curPlayer.GetItemManager().GetPack(IPY_GameWorld.rptEquip)
    #组合列表
@@ -1591,7 +1617,9 @@
                equipGS = 1
                cmpEquipGS = 2
                
            if equipGS == 0:
            if tmpItem.GetType() in [ChConfig.Def_ItemType_Rune, ChConfig.Def_ItemType_RuneExp]:
                runeItemList.append(tmpItem)
            elif equipGS == 0:
                itemList.append(tmpItem)
            elif equipGS > cmpEquipGS:
                equipGSGreaterList.append(tmpItem)
@@ -1601,7 +1629,8 @@
    equipGSGreaterList.sort(__CmpRolePack)
    itemList.sort(__CmpRolePack)
    equipGSLesserList.sort(__CmpRolePack)
    runeItemList.sort(__CmpRolePack)
    #===========================================================================
    # GameWorld.DebugLog("equipGSGreaterList")
    # for item in equipGSGreaterList:
@@ -1636,6 +1665,11 @@
    for item in equipGSLesserList:
        curPack.GetAt(putPlace).AssignItem(item, False)
        putPlace += 1
    for item in runeItemList:
        curPack.GetAt(putPlace).AssignItem(item, False)
        putPlace += 1
    return