Hiero中versionscanner模块结构图
花了两周读这个模块,终于把结构理清楚了,当然新功能也搞定了,搜索条件更宽松,可以找到binitem对象中更多的版本,截图如下:
当然功能也做出来啦:
代码如下:
##########################################################################################################################################
# ScanForVersions is the action responsible for scanning for versions.
# This action is added to the BinView context menu.
# The code responsible for the scanning is located in hiero.core.VersionScanner
import hiero.core
import hiero.core.log
import VersionScanner_vhq
import hiero.ui
import PySide.QtGui
import PySide.QtCore
import foundry.ui
import threading
import time
class VersionScannerThreaded (object):
'''Class to run a threaded scan to discover additional versions for a set of versioned clips'''
_scanner = VersionScanner_vhq.VersionScanner_vhq()
def scanForVersions_vhq(self, versions, postScanFunc, shouldDisplayResults):
'''Scan for versions starting from the specified version
@param versions - set of versions to scan. Note that the versions listed belong to different bin items
@param postScanFunc - optional post scan update function
@param shouldDisplayResults - Whether we should display how many versions were discovered'''
task = foundry.ui.ProgressTask("Finding Versions...")
# Rescan clip file ranges for all existing versions
for version in versions:
hiero.core.executeInMainThreadWithResult(self.rescanClipRanges, version)
# Find all the files to be added as versions
numNewFiles = 0
newVersionFiles = []
numNewVersions = 0
# For each version find the additional files
for version in versions:
newFiles = self._scanner.findVersionFiles_vhq(version)
newVersionFiles.append ( [ version, newFiles ] )
numNewFiles += len(newFiles)
# Now create the clips for the additional files
fileIndex = 0
for versionFile in newVersionFiles:
newClips = []
version, newFiles = versionFile
for newFile in newFiles:
# If the user has hit cancel then drop out
if task.isCancelled():
return
fileIndex += 1
task.setProgress(int(100.0*(float(fileIndex)/float(numNewFiles))))
newClip = hiero.core.executeInMainThreadWithResult(self._scanner.createClip, newFile)
# Filter out any invalid clips
if newClip is not None:
newClips.append(newClip)
versionFile.append ( newClips )
# Now create the additional versions from the clips and add them to the version list
for versionFile in newVersionFiles:
version = versionFile[0]
newClips = versionFile[2]
binitem = version.parent()
# Now add the clips as new versions
newVersions = hiero.core.executeInMainThreadWithResult(self._scanner.insertClips, binitem, newClips)
hiero.core.log.info("InsertClips - Versions found for %s: %s", version, newVersions)
numNewVersions += len(newVersions)
# If we have a post scan function then run it (version up/down, min/max)
if (postScanFunc is not None):
oldClip = version.item()
hiero.core.executeInMainThreadWithResult(postScanFunc)
newClip = binitem.activeVersion().item()
# Then update any viewers looking at the old clip to the new clip
hiero.core.executeInMainThreadWithResult(hiero.ui.updateViewer, oldClip, newClip)
# If we're supposed to display results then do so
if (shouldDisplayResults):
hiero.core.executeInMainThreadWithResult(self.displayResults, numNewVersions)
# Display results
def displayResults(self, numNewVersions):
msgBox = PySide.QtGui.QMessageBox()
msgBox.setText("Found " + str(numNewVersions) + " new versions")
msgBox.setStandardButtons(PySide.QtGui.QMessageBox.Ok)
msgBox.setDefaultButton(PySide.QtGui.QMessageBox.Ok)
msgBox.exec_()
# From an active version, iterates through all the siblings inside the BinItem
def rescanClipRanges(self, activeVersion):
binItem = activeVersion.parent()
if binItem:
for version in binItem.items():
clip = version.item()
if clip:
clip.rescan()
# Helper class to call thread with a arbitrary number of arguments
class FuncThread(threading.Thread):
def __init__(self, target, *args):
self._target = target
self._args = args
threading.Thread.__init__(self)
def run(self):
self._target(*self._args)
def ScanAndNextVersion(version):
'''Scan then move to next version'''
binitem = version.parent()
_DoScanForVersions([version], binitem.nextVersion, False)
def ScanAndPrevVersion(version):
''' Scan then move to prev version'''
binitem = version.parent()
_DoScanForVersions([version], binitem.prevVersion, False)
def ScanAndMinVersion(version):
'''Scan then move to min version'''
binitem = version.parent()
_DoScanForVersions([version], binitem.minVersion, False)
def ScanAndMaxVersion(version):
'''Scan then move to max version'''
binitem = version.parent()
_DoScanForVersions([version], binitem.maxVersion, False)
def ScanAndNextVersionTrackItem(version, trackItem):
'''Scan then move to next version on the track item'''
_DoScanForVersions([version], trackItem.nextVersion, False)
def ScanAndPrevVersionTrackItem(version, trackItem):
'''Scan then move to prev version on the track item'''
_DoScanForVersions([version], trackItem.prevVersion, False)
def ScanAndMinVersionTrackItem(version, trackItem):
'''Scan then move to min version on the track item'''
_DoScanForVersions([version], trackItem.minVersion, False)
def ScanAndMaxVersionTrackItem(version, trackItem):
'''Scan then move to max version on the track item'''
_DoScanForVersions([version], trackItem.maxVersion, False)
# Create threaded scan using VersionScannerThreaded
def _DoScanForVersions(versions, postUpdateFunc, shouldDisplayResults):
scanner = VersionScannerThreaded()
thread = FuncThread(scanner.scanForVersions_vhq, versions, postUpdateFunc, shouldDisplayResults)
thread.start()
# Action to scan for new versions
class ScanForVersionsAction(PySide.QtGui.QAction):
_scanner = hiero.core.VersionScanner.VersionScanner()
def __init__(self):
PySide.QtGui.QAction.__init__(self, "Scan For More Versions (VHQ)", None)
self.triggered.connect(self.doit)
hiero.core.events.registerInterest((hiero.core.events.EventType.kShowContextMenu, hiero.core.events.EventType.kBin), self.eventHandler)
hiero.core.events.registerInterest((hiero.core.events.EventType.kShowContextMenu, hiero.core.events.EventType.kTimeline), self.eventHandler)
def doit(self):
# get the currently selected versions from UI
versions = self.selectedVersions()
if len(versions) == 0:
hiero.core.log.info( "No valid versions found in selection" )
return
# For each version, do:
# - rescan any versions already loaded to find the maximum available range
# - run _scanner.doScan which returns added versions
# - compute the total count of new versions.
_DoScanForVersions(versions, None, True)
def eventHandler(self, event):
enabled = False
if hasattr(event.sender, 'selection'):
s = event.sender.selection()
if len(s)>=1:
enabled = True
# enable/disable the action each time
if enabled:
hiero.ui.insertMenuAction( self, event.menu, after="foundry.project.rescanClips" ) # Insert after 'Version' sub-menu
# Get all selected active versions
def selectedVersions(self):
selection = hiero.ui.currentContextMenuView().selection()
versions = []
self.findActiveVersions(selection, versions)
return (versions)
#
def alreadyHaveVersion(self, findversion, versions):
newFilename = findversion.item().mediaSource().fileinfos()[0].filename()
for version in versions:
thisFilename = version.item().mediaSource().fileinfos()[0].filename()
if (newFilename == thisFilename):
return True
return False
# Find all active versions in container and append to versions
def findActiveVersions(self, container, versions):
# Iterate through selection
if isinstance(container, (list,tuple)):
for i in container:
self.findActiveVersions(i, versions)
# Dive into Projects to find clipsBin (NB: not strictly needed at the moment, we get RootBins from BinView)
elif isinstance(container, hiero.core.Project):
self.findActiveVersions(container.clipsBin(), versions)
# Dive into Bins to find BinItems
elif isinstance(container, hiero.core.Bin):
for i in container.items():
self.findActiveVersions(i, versions)
elif isinstance(container, hiero.core.TrackItem) and isinstance(container.source(), hiero.core.Clip):
activeVersion = container.currentVersion()
if activeVersion and not activeVersion.isNull():
if not self.alreadyHaveVersion(activeVersion, versions):
#if activeVersion not in versions:
versions.append(activeVersion)
# Dive into BinItem to retrieve active Version
elif isinstance(container, hiero.core.BinItem) and isinstance(container.activeItem(), hiero.core.Clip):
activeVersion = container.activeVersion()
if activeVersion:
if not self.alreadyHaveVersion(activeVersion, versions):
#if activeVersion not in versions:
versions.append(activeVersion)
# Instantiate the action to get it to register itself.
action = ScanForVersionsAction()
Hiero中versionscanner模块结构图的更多相关文章
- Hiero中的Events机制
The hiero.core.events module allows you to register method callbacks to respond to events sent by Hi ...
- 第三十篇:SOUI模块结构图及SOUI框架图
模块结构图: SOUI框架图:
- 隐藏进程中的模块绕过IceSword的检测
标 题: [原创] 隐藏进程中的模块绕过IceSword的检测 作 者: xPLK 时 间: 2008-06-19,17:59:11 链 接: http://bbs.pediy.com/showthr ...
- 浅析JS中的模块规范(CommonJS,AMD,CMD)////////////////////////zzzzzz
浅析JS中的模块规范(CommonJS,AMD,CMD) 如果你听过js模块化这个东西,那么你就应该听过或CommonJS或AMD甚至是CMD这些规范咯,我也听过,但之前也真的是听听而已. ...
- 解决centos7中python-pip模块不存在的问题
centos 7中python-pip模块不存在,是因为像centos这类衍生的发行版,源跟新滞后,或者不存在.即使使用yum去search python-pip也找不到软件包. 为了使用安装滞后或源 ...
- Nodejs中cluster模块的多进程共享数据问题
Nodejs中cluster模块的多进程共享数据问题 前述 nodejs在v0.6.x之后增加了一个模块cluster用于实现多进程,利用child_process模块来创建和管理进程,增加程序在多核 ...
- Python中optionParser模块的使用方法[转]
本文以实例形式较为详尽的讲述了Python中optionParser模块的使用方法,对于深入学习Python有很好的借鉴价值.分享给大家供大家参考之用.具体分析如下: 一般来说,Python中有两个内 ...
- python中threading模块详解(一)
python中threading模块详解(一) 来源 http://blog.chinaunix.net/uid-27571599-id-3484048.html threading提供了一个比thr ...
- Python中的模块与包
标准库的安装路径 在import模块的时候,python是通过系统路径找到这些模块的,我们可以将这些路径打印出来: >>> pprint.pprint(sys.path) ['', ...
随机推荐
- Semaphore计数信号量
ExecutorService exec = Executors.newCachedThreadPool(); final Semaphore semp = new Semaphore(5); for ...
- JAVA接口传递参数(POST),从接口接收数据(JSON) -----记录
1,给接口传递json格式的数据 import java.io.BufferedReader; import java.io.DataOutputStream; import java.io.IOEx ...
- mysql 批量kill
select concat('kill ',id,';') t from information_schema.processlist order by t
- c++字符串前几位,后几位的截取
参考 1. https://blog.csdn.net/haijunsm/article/details/82733584 完
- mxnet 动手学深度学习
http://zh.gluon.ai/chapter_crashcourse/introduction.html 强化学习(Reinforcement Learning) 如果你真的有兴趣用机器学习开 ...
- ZK集群搭建和配置
1. 克隆三台空虚拟机(含有jdk和lrzsz),修改网络ip,并关闭虚拟机的防火墙 临时关闭:service iptables stop 永久关闭:chkconfig iptables off 2. ...
- windows apache "The requested operation has failed" 启动失败
找到失败原因,进入cmd(win+r快捷键,输入cmd)命令行下 进入到你的apache bin目录下: 每个人错误可能不同,根据自己问题去相应改
- Windows下安装Python模块时环境配置
“Win +R”打开cmd终端,如果直接在里面使用pip命令的时候,要么出现“syntax invalid”,要么出现: 'pip' is not recognized as an internal ...
- 【BZOJ2120】数颜色
看代码学习好,好学好懂好ac 原题: 墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会像你发布如下指令: 1. Q L R代表询问你从第L支画笔到第R支画笔中 ...
- 把oracle数据库恢复到某个时间点或者某个scn
alter session set nls_date_format='yyyymmdd hh24:mi:ss'; select sysdate from dual; conn dbauser/1234 ...