Version 0.9 - June 6th,  2019
Author: Harold Linke

This is a Vegas pro Custom Command Extension adding a Python Scripting Interpreter and some features to VEGAS 

All files and directories in the zip file must be must be copied to one of these folders :

C:\Documents and Settings\<username>\Documents\Vegas Application Extensions\  
C:\Documents and Settings\<username>\Local Settings\Application Data\Sony\Vegas Pro\9.0\Application Extensions\ 
C:\Documents and Settings\<username>\Application Data\Sony\Vegas Pro\9.0\Application Extensions\ 
C:\Documents and Settings\All Users\Application Data\Sony\Vegas Pro\9.0\Application Extensions\ 
C:\Documents and Settings\<username>\Local Settings\Application Data\Sony\Vegas Pro\Application Extensions\ 
C:\Documents and Settings\<username>\Application Data\Sony\Vegas Pro\Application Extensions\ 
C:\Documents and Settings\All Users\Application Data\Sony\Vegas Pro\Application Extensions\ 

I'm using on a Win10 system : 
C:\Users\Harold\Documents\Vegas Application Extensions

If the 'Application Extensions' folder does not jet exist, it must be allocated with exact this name.

-------------------------------------------------------------------------------------
For VEGAS Users:

VEGASPython extends VEGAS with following functions:

Simple functions to demonstrate the principle:
- Add2SecondGap
- AddMarkersAtInterval
- AddMarkersToEvents
- AddRegionsToEvent
- AddTransitionToSelectedEvents
- Audit_Event_Levels
- Chopoff_BeginandEndofEvent_PN
- DeleteEmptySpaceBetweenEvents
- LimitSelectedEventLength
- LimitSelectedEventLengthto4Seconds

New functions only available with VEGASPython
- VegasSceneDetect
- Import_PinnacleStudio_SceneDetectFile


VEGASSceneDetect creates subclips of a mediaclip from the Mediapool or on the Timeline based on scene changes.

Usage: Select clips in the mediapool or select clips on the timeline
Call the VEGAS Extension: VEGASScenedetect

A window with the preview of the clip will open. The white bar at the top of the screen shows the progress of the scene detection.
Pressing ESC when the preview window is active aborts the scenedetection process.

VEGASScenedetect is based on PyScenedetect by Brandon Castellano

Import_PinnacleStudio_SceneDetectFile:
Imports a Pinnacle Studio Scene Detection File that was create by Pinnacle Studio for a clip.
The file must have the same name as the clip and has to be located in the same directory. The only difference is the extension .scn.xml for the scene detection file.
When importing, VEGAS automatically adds the clips and all its scenes as subclips to the media pool.

The commands can be found in VEGAS under the menu point: Extra / Extensions

----------------------------------------------------------------------
For VEGAS Script Developers:

In addition VEGASPython includes an interactive window for Python developers.
VEGASPython interactive window is activated via the 'View' / 'Extensions' tab. 

A VEGAS dockable window opens. The window can float over VEGAS or can be integrated into the VEGAS layout as any other VEGAS window.

The VEGASPython window shows two textboxes:

- Input PYTHON Comands
- Output
 
and a menu with two items "File" and "Execute VEGASPython Script".

Python comands are entered in the textbox "Input". Several lines can be entered one after each other. It is possible to copy a complete PYTHON Script from another editor via CTRL+C and CTRL+V.
The PYTHON commands will be executed by clicking on the menu "Execute VEGASPython Script".

All output from PYTHON print statements and all error messages will be shown in the "Output" textbox.

VEGASPython is based on Python 3.7.3 and PythonNet.
Python and PythonNet are included in the download file. There is no need to install anything else.
The Python directory is:  "Application Extension"-Folder\Python37

The Python implementation includes follwing additional modules:
- openCV
- NumPy
- Scenedetect

If you have already another Python installation it will be ignored.

---------------------------------------------
How to access VEGAS from Python:

The VEGAS API can be accessed directly by using the build-in variable "pyVEGAS".
All VEGAS API items are available.

Example for a simple script that can be used in the interactive window:
import clr
clr.AddReference('ScriptPortal.Vegas')
import ScriptPortal.Vegas
from ScriptPortal.Vegas import *

# adapt this value to your needs
maxLength = Timecode.FromString("00:00:04:00")
 
# Go through the list of Tracks
for track in pyVEGAS.Project.Tracks:
    for evnt in track.Events:
        if (evnt.Selected):
            dLength = evnt.Length
            if dLength > maxLength:
                dLength = maxLength
            dStart = evnt.Start
            evnt.AdjustStartLength(dStart, dLength, True)


A script that is used as an extension needs to be included in a function FromVegas. See example below.

import clr
clr.AddReference('ScriptPortal.Vegas')
import ScriptPortal.Vegas
from ScriptPortal.Vegas import *

def FromVegas(pyVEGAS):
   # adapt this value to your needs
    maxLength = Timecode.FromString("00:00:04:00")
 
  # Go through the list of Tracks
    for track in pyVEGAS.Project.Tracks:
        for evnt in track.Events:
            if (evnt.Selected):
                dLength = evnt.Length
                if dLength > maxLength:
                    dLength = maxLength
                dStart = evnt.Start
                evnt.AdjustStartLength(dStart, dLength, True)







