當前位置: 首頁>>代碼示例>>Python>>正文


Python QVector.contains方法代碼示例

本文整理匯總了Python中pyqtcore.QVector.contains方法的典型用法代碼示例。如果您正苦於以下問題:Python QVector.contains方法的具體用法?Python QVector.contains怎麽用?Python QVector.contains使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在pyqtcore.QVector的用法示例。


在下文中一共展示了QVector.contains方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: cellsInRegion

# 需要導入模塊: from pyqtcore import QVector [as 別名]
# 或者: from pyqtcore.QVector import contains [as 別名]
def cellsInRegion(list, r):
    cells = QVector()
    for tilelayer in list:
        for rect in r.rects():
            for x in range(rect.left(), rect.right()+1):
                for y in range(rect.top(), rect.bottom()+1):
                    cell = tilelayer.cellAt(x, y)
                    if (not cells.contains(cell)):
                        cells.append(cell)

    return cells
開發者ID:theall,項目名稱:Python-Tiled,代碼行數:13,代碼來源:automapper.py

示例2: TileStampManager

# 需要導入模塊: from pyqtcore import QVector [as 別名]
# 或者: from pyqtcore.QVector import contains [as 別名]
class TileStampManager(QObject):
    setStamp = pyqtSignal(TileStamp)

    def __init__(self, toolManager, parent = None):
        super().__init__(parent)
        
        self.mStampsByName = QMap()
        self.mQuickStamps = QVector()
        for i in range(TileStampManager.quickStampKeys().__len__()):
            self.mQuickStamps.append(0)
        
        self.mTileStampModel = TileStampModel(self)
        self.mToolManager = toolManager

        prefs = preferences.Preferences.instance()
        prefs.stampsDirectoryChanged.connect(self.stampsDirectoryChanged)
        self.mTileStampModel.stampAdded.connect(self.stampAdded)
        self.mTileStampModel.stampRenamed.connect(self.stampRenamed)
        self.mTileStampModel.stampChanged.connect(self.saveStamp)
        self.mTileStampModel.stampRemoved.connect(self.deleteStamp)
        self.loadStamps()

    def __del__(self):
        # needs to be over here where the TileStamp type is complete
        pass
        
    ##
    # Returns the keys used for quickly accessible tile stamps.
    # Note: To store a tile layer <Ctrl> is added. The given keys will work
    # for recalling the stored values.
    ##
    def quickStampKeys():
        keys=[Qt.Key_1, Qt.Key_2, Qt.Key_3, Qt.Key_4, Qt.Key_5, Qt.Key_6, Qt.Key_7, Qt.Key_8, Qt.Key_9]
        return keys
        
    def tileStampModel(self):
        return self.mTileStampModel
        
    def createStamp(self):
        stamp = self.tampFromContext(self.mToolManager.selectedTool())
        if (not stamp.isEmpty()):
            self.mTileStampModel.addStamp(stamp)
        return stamp
    
    def addVariation(self, targetStamp):
        stamp = stampFromContext(self.mToolManager.selectedTool())
        if (stamp.isEmpty()):
            return
        if (stamp == targetStamp): # avoid easy mistake of adding duplicates
            return
        for variation in stamp.variations():
            self.mTileStampModel.addVariation(targetStamp, variation)

    def selectQuickStamp(self, index):
        stamp = self.mQuickStamps.at(index)
        if (not stamp.isEmpty()):
            self.setStamp.emit(stamp)
    
    def createQuickStamp(self, index):
        stamp = stampFromContext(self.mToolManager.selectedTool())
        if (stamp.isEmpty()):
            return
        self.setQuickStamp(index, stamp)
    
    def extendQuickStamp(self, index):
        quickStamp = self.mQuickStamps[index]
        if (quickStamp.isEmpty()):
            self.createQuickStamp(index)
        else:
            self.addVariation(quickStamp)
    
    def stampsDirectoryChanged(self):
        # erase current stamps
        self.mQuickStamps.fill(TileStamp())
        self.mStampsByName.clear()
        self.mTileStampModel.clear()
        self.loadStamps()

    def eraseQuickStamp(self, index):
        stamp = self.mQuickStamps.at(index)
        if (not stamp.isEmpty()):
            self.mQuickStamps[index] = TileStamp()
            if (not self.mQuickStamps.contains(stamp)):
                self.mTileStampModel.removeStamp(stamp)

    def setQuickStamp(self, index, stamp):
        stamp.setQuickStampIndex(index)
        # make sure existing quickstamp is removed from stamp model
        self.eraseQuickStamp(index)
        self.mTileStampModel.addStamp(stamp)
        self.mQuickStamps[index] = stamp
    
    def loadStamps(self):
        prefs = preferences.Preferences.instance()
        stampsDirectory = prefs.stampsDirectory()
        stampsDir = QDir(stampsDirectory)
        iterator = QDirIterator(stampsDirectory,
                              ["*.stamp"],
                              QDir.Files | QDir.Readable)
        while (iterator.hasNext()):
#.........這裏部分代碼省略.........
開發者ID:theall,項目名稱:Python-Tiled,代碼行數:103,代碼來源:tilestampmanager.py

示例3: compareLayerTo

# 需要導入模塊: from pyqtcore import QVector [as 別名]
# 或者: from pyqtcore.QVector import contains [as 別名]
def compareLayerTo(setLayer, listYes, listNo, ruleRegion, offset):
    if (listYes.isEmpty() and listNo.isEmpty()):
        return False
    cells = QVector()
    if (listYes.isEmpty()):
        cells = cellsInRegion(listNo, ruleRegion)
    if (listNo.isEmpty()):
        cells = cellsInRegion(listYes, ruleRegion)
    for rect in ruleRegion.rects():
        for x in range(rect.left(), rect.right()+1):
            for y in range(rect.top(), rect.bottom()+1):
                # this is only used in the case where only one list has layers
                # it is needed for the exception mentioned above
                ruleDefinedListYes = False
                matchListYes = False
                matchListNo  = False
                if (not setLayer.contains(x + offset.x(), y + offset.y())):
                    return False
                c1 = setLayer.cellAt(x + offset.x(),
                                                  y + offset.y())
                # ruleDefined will be set when there is a tile in at least
                # one layer. if there is a tile in at least one layer, only
                # the given tiles in the different listYes layers are valid.
                # if there is given no tile at all in the listYes layers,
                # consider all tiles valid.
                for comparedTileLayer in listYes:
                    if (not comparedTileLayer.contains(x, y)):
                        return False
                    c2 = comparedTileLayer.cellAt(x, y)
                    if (not c2.isEmpty()):
                        ruleDefinedListYes = True
                    if (not c2.isEmpty() and c1 == c2):
                        matchListYes = True

                for comparedTileLayer in listNo:
                    if (not comparedTileLayer.contains(x, y)):
                        return False
                    c2 = comparedTileLayer.cellAt(x, y)
                    if (not c2.isEmpty() and c1 == c2):
                        matchListNo = True

                # when there are only layers in the listNo
                # check only if these layers are unmatched
                # no need to check explicitly the exception in this case.
                if (listYes.isEmpty()):
                    if (matchListNo):
                        return False
                    else:
                        continue

                # when there are only layers in the listYes
                # check if these layers are matched, or if the exception works
                if (listNo.isEmpty()):
                    if (matchListYes):
                        continue
                    if (not ruleDefinedListYes and not cells.contains(c1)):
                        continue
                    return False

                # there are layers in both lists:
                # no need to consider ruleDefinedListXXX
                if ((matchListYes or not ruleDefinedListYes) and not matchListNo):
                    continue
                else:
                    return False

    return True
開發者ID:theall,項目名稱:Python-Tiled,代碼行數:69,代碼來源:automapper.py


注:本文中的pyqtcore.QVector.contains方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。