Jump to content
imitto

PAL timecode calculator UDF

Recommended Posts

imitto

Hello all!

I use Autoit for a while, already made some automation for a TV station's master control room with it. I made a UDF to easily work with PAL timecode and time with milliseconds, convert, add or subtract them. Feel free to use it if you want something like this :)

#Region ;**** Directives created by AutoIt3Wrapper_GUI ****
#AutoIt3Wrapper_Res_Description=PAL Timecode Calculator UDF
#AutoIt3Wrapper_Res_LegalCopyright=horvath.imre@gmail.com
#EndRegion ;**** Directives created by AutoIt3Wrapper_GUI ****
;
; #FUNCTION#
; Name...........:  _tcAdd
; Description....:  Returns addition of two timecodes
; Syntax.........:  _tcAdd($fTc1, fTc2 [, $fFormat = "P"])
;
; Parameters.....:  $fTc1               - First timecode in hh:mm:ss.ff format
;                   $fTc2               - Second timecode in hh:mm:ss.ff format
;                   $fFormat            - Time base -   "P" (default): PAL (25 fps)
;                                                       "M" : millisecond
;
; Return value...:  Sum of the two timecode in the selected format

Func _tcAdd($fTc1, $fTc2, $fFormat = "P", $fHourFormat = 1)
    Local $fMs1 = _tcToMs($fTc1)
    Local $fMs2 = _tcToMs($fTc2)
    Local $fSumMs = $fMs1 + $fMs2
    Return _msToTc($fSumMs, $fFormat, $fHourFormat)
EndFunc

; #FUNCTION#
; Name...........:  _tcsSub
; Description....:  Returns addition of two timecodes
; Syntax.........:  _tcSub($fTc1, fTc2 [, $fFormat = "P"])
;
; Parameters.....:  $fTc1               - First timecode in hh:mm:ss.ff format
;                   $fTc2               - Second timecode in hh:mm:ss.ff format
;                   $fFormat            - Time base -   "P" (default): PAL (25 fps)
;                                                       "M" : millisecond
;
; Return value...:  Subtract $fTc2 from $fTc1 in the source format

Func _tcSub($fTc1, $fTc2, $fFormat = "P")
    Local $fMs1 = _tcToMs($fTc1)
    Local $fMs2 = _tcToMs($fTc2)
    Local $fSumMs = $fMs1 - $fMs2
    If $fSumMs < 0 Then
        $fSumMs = _tcToMs("24:00:00.00") - ($fSumMs * -1)
    EndIf
    Return _msToTc($fSumMs, $fFormat)
EndFunc

; #FUNCTION#
; Name...........:  _tcToMs
; Description....:  Returns timecode converted to total milliseconds
; Syntax.........:  _tcToMs($fTc)
;
; Parameters.....:  $fTc                - Timecode in hh:mm:ss.ff or hh:mm:ss:xxx format, where xxx are milliseconds
;
; Return value...:  Milliseconds as an integer value

Func _tcToMs($fTc)
    Local $fTemp = StringSplit($fTc, ":.")
    Local $fChr = StringLen($fTemp[4])
    Switch $fChr
        Case 2
            Return ($fTemp[4] * 40) + ($fTemp[3] * 1000) + ($fTemp[2] * 60000) + ($fTemp[1] * 3600000)
        Case 3
            Return ($fTemp[4]) + ($fTemp[3] * 1000) + ($fTemp[2] * 60000) + ($fTemp[1] * 3600000)
    EndSwitch
EndFunc

; #FUNCTION#
; Name...........:  _msToTc
; Description....:  Converts total milliseconds to timecode
; Syntax.........:  _msToTc($fIn, $fFormat = "P", $fHourFormat = 1)
;
; Parameters.....:  $fIn                - Time in milliseconds
;                   $fFormat            - Output format     "P": PAL TC (default)
;                                                           "M": hh:mm:ss.xxx where xxx are milliseconds
;                   $fHourFormat        - Hour format       "1": max. value is 23, then starts from 0 (default)
;                                                           "0": hours can be more then 23
;
; Return value...:  Timecode as string in the selected format

Func _msToTc($fIn, $fFormat = "P", $fHourFormat = 1)
    Switch $fFormat
        Case "P"
            Local $fFr = StringFormat("%02i",  (StringRight($fIn, 3) - Mod(StringRight($fIn, 3), 40)) / 40)
        Case "M"
            Local $fFr = StringFormat("%03i",  StringRight($fIn, 3))
    EndSwitch
    $fIn = StringTrimRight($fIn, 3)
    Local $fSec = StringFormat("%02i", Mod($fIn, 60))
    $fIn -= $fSec
    Local $fMinTot = $fIn / 60
    Local $fMin = StringFormat("%02i", Mod($fMinTot, 60))
    $fIn -= $fMin*60
    Local $fHourTot = $fIn / 60 / 60
    Switch $fHourFormat
        Case 1
            $fHour = StringFormat("%02i", Mod($fHourTot, 24))
        Case 0
            $fHour = StringFormat("%02i", $fHourTot)
    EndSwitch
    Return($fHour & ":" & $fMin & ":" & $fSec & "." & $fFr)
EndFunc

; #FUNCTION#
; Name...........:  _tcFormatChange
; Description....:  Toggle TC format
; Syntax.........:  _tcFormatChange($fTc)
;
; Parameters.....:  $fTc                - Timecode in hh:mm:ss.ff or hh:mm:ss:xxx format, where xxx are milliseconds
;
; Return value...:  PAL timecode or time with milliseconds as string, depends on input

Func _tcFormatChange($fTc)
    Local $fTemp = StringSplit($fTc, ":.")
    Local $fChr = StringLen($fTemp[4])
    Switch $fChr
        Case 2
            Return $fTemp[1]&":"&$fTemp[2]&":"&$fTemp[3]&"."&StringFormat("%03i", $fTemp[4]*40)
        Case 3
            Return $fTemp[1]&":"&$fTemp[2]&":"&$fTemp[3]&"."&StringFormat("%02i", ($fTemp[4]-Mod($fTemp[4], 40))/40)
    EndSwitch
EndFunc

And the example script:

#include<_PAL_TC_Calc.au3>

$palTC1 = "00:01:12.20"
$palTC2 = "23:59:50.02"
$msTC1 = "00:01:12.800"
$msTC2 = "23:59:50.120"

MsgBox(0, "1", _tcAdd($palTC1, $palTC2));           Adds $palTC1 to $palTC2, turns hour back to 0 after 23, returns PAL TC format
MsgBox(0, "2", _tcAdd($palTC1, $palTC2, "M"));      Adds $palTC1 to $palTC2, turns hour back to 0 after 23, returns time with milliseconds format
MsgBox(0, "3", _tcAdd($palTC1, $palTC2, "M", 0));   Adds $palTC1 to $palTC2, hours can be infinite, returns time with milliseconds format
MsgBox(0, "4", _tcAdd($msTC1, $msTC2));             Adds $palTC1 to $palTC2, turns hour back to 0 after 23, returns PAL TC format
MsgBox(0, "5", _tcAdd($msTC1, $msTC2, "M"));        Adds $palTC1 to $palTC2, turns hour back to 0 after 23, returns time with milliseconds format
MsgBox(0, "6", _tcAdd($msTC1, $msTC2, "M", 0));     Adds $palTC1 to $palTC2, hours can be infinite, returns time with milliseconds format

MsgBox(0, "7", _tcSub($palTC2, $palTC1));           Subtract $palTC1 from $palTC2, returns PAL TC format
MsgBox(0, "8", _tcSub($palTC2, $palTC1, "M"));      Subtract $palTC1 from $palTC2, time with milliseconds format
MsgBox(0, "9", _tcSub($msTC1, $msTC2));             Subtract $palTC1 from $palTC2, returns PAL TC format - when hits zero, counts back from 24:00:00.00
MsgBox(0, "10", _tcSub($msTC1, $msTC2, "M"));       Subtract $palTC1 from $palTC2, time with milliseconds format - when hits zero, counts back from 24:00:00.000

MsgBox(0, "11", _tcFormatChange($palTC2));          Convert PAL TC to time with milliseconds and back
MsgBox(0, "12", _tcFormatChange($msTC2));           Convert PAL TC to time with milliseconds and back

 

TC_CALC_example.au3

_PAL_TC_Calc.au3

Share this post


Link to post
Share on other sites
mLipok

Thanks for posting your UDF.
If you want to make them better start with using this:
 

#Tidy_Parameters=/sort_funcs /reel
#AutoIt3Wrapper_Au3Check_Parameters=-d -w 1 -w 2 -w 3 -w- 4 -w 5 -w 6 -w 7

And read about #include directive, as in non standalone Include file it should be used like this:

#include "_PAL_TC_Calc.au3"

 


Signature beginning:   Wondering who uses AutoIT and what it can be used for ?
* GHAPI UDF - modest begining - comunication with GitHub REST API Forum Rules *
ADO.au3 UDF     POP3.au3 UDF     XML.au3 UDF    How to use IE.au3  UDF with  AutoIt v3.3.14.x  for other useful stuff click the following button

Spoiler

Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. 

My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST APIErrorLog.au3 UDF - A logging Library
 

My contribution to others projects or UDF based on  others projects: * _sql.au3 UDF  * POP3.au3 UDF *  RTF Printer - UDF * XML.au3 UDF * ADO.au3 UDF SMTP Mailer UDF * Dual Monitor resolution detection * * 2GUI on Dual Monitor System * _SciLexer.au3 UDF *

Useful links: * Forum Rules * Forum etiquette *  Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * 

Wiki: Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Good coding practices in AutoIt * 

IE Related:  * How to use IE.au3  UDF with  AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * IE in TaskScheduler

I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions *  EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *

"Homo sum; humani nil a me alienum puto" - Publius Terentius Afer
"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming"
:naughty:  :ranting:, be  :) and       \\//_.

Anticipating Errors :  "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty."

Signature last update: 2018-10-31

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • nooneclose
      By nooneclose
      I need help turning this string "20180913221626" into a formatted time string.
      I need to go from this: 20180913221626
      to this: 09/13/2018 10:16 PM
      I do not always know what the date will be so I can not just use a variable I need to actually convert/format. 
      I did see an older post in the forms that was basically the same question only the other guy did not post the working code and I can not figure out how to use _AD_GetObjectProperties properly to get what I want. 
      As always any help would be appreciated. 
      Here is the code I use to find the date, but it always gives me the unformatted version. 
      ;retrieve the items object $oItem = $oOutlook.Session.GetItemFromID($aItems[1][0], Default) $oItem.GetInspector $eSentOn = $oItem.SentOn ; When was the email sent? MsgBox("", "Sent On of the email", $eSentOn) ;******************************************************************************* ; Formats the date and time from the email ;******************************************************************************* ;Local $fDatenTime = _DateTimeFormat($eSentOn, 1) ;MsgBox("", "Formatted email time", $fDatenTime) $aProperties = _AD_GetObjectProperties($eSentOn) _ArrayDisplay($aProperties, "Did the conversion work?")  
    • caramen
      By caramen
      I watched _OL_ItemSend&_OL_ItemFind&_OL_ItemCreate in OutlookEx UDF but hmmm
       
      Since it use the test environnement i cant get the orders of the mail creation
       
      Can someone make me win some time of reading all exemples script and lead me how to do one ?
      That whould be lovely.
      Gnight
    • Jemboy
      By Jemboy
      Hi,
      Ones(some times twice) a month I get an e-mail with zip file, which has price updates from a supplier.
      I have to upload the file to an FTP to get it processed.
      When uploading the file, it will get "timestamped" with the time and date at which time the file was uploaded.
      Normally this is fine, because I mostly upload the file the same day.
      Sometimes it may take 1 or 2 days before I can upload the file.
      For historical purpose, I would like to have the file timestamped with the original date.
      I have tried using:  _FTP_Command ( $hFTPSession, "MFCT YYYYMMDDHHMMSS path") 
      however this command does not work or change the timestamp as I expected.
      Does anyone now a way how I can change the timestamp of a FTP-file?
    • Tersion
      By Tersion
      Here the this wiki page with list of available UDFs for data compression. For my tasks I only need ZIP support, so I started looking at pure AutoIt UDFs without any 3rd party dlls. And found out that most of available realizations uses standard ("native method") Windows dll - "zipfldr.dll". So for now I chose ZIP UDF by wraithdu. I've tested it on Windows 7 (x64) and it seem works fine. But here the comment from another topic where user says that Windows 10 discontinued support of "zipfldr.dll". Now I confused. I don't have around any Windows 10 machine to tested it. So maybe someone could confirm or deny that? Or maybe would better to switch to UDF with 7zip dll?
      I need an advice...
    • TheSaint
      By TheSaint
      Here is the bare bones of a UDF I have started work on.
      Mostly just a proof of concept at this stage, and still need to add some functions and dress the UDF up a bit ... to look like a UDF ... though it has my own distinct styling, especially as I have never really developed a UDF before now .... used plenty and modified plenty though. I've even invented my own UDF variable naming convention, which I am sure some of you will be aghast at. I work with what feels best for me, but others are free to adapt if they wish.
      The idea is to emulate the simplicity of INI files, but gain the benefits of SQL.
      Two scripts are provided.
      (1) The UDF, a work in progress - SimpleSQL_UDF.au3
      (2) An example or testing script - UDF_Test.au3
      Another first for me, is creating a 2D array from scratch, never done that before, that I can recall ... never had a need, and even for 1 dimension arrays, for a long time now, I have just used _StringSplit to create them. So I needed a bit of a refresher course, which my good buddy @TheDcoder assisted me with ... not without some angst I might add. LOL
      SimpleSQL_UDF.zip  (12 downloads previously)
      (I have now completed all the functions I intended to. My next update will be a big improvement, bringing things more inline with my latest INItoSQL DB program changes.)
      Program requires the sqlite3.dll, not included, but easily enough obtained.
      Hopefully the usage is self-evident ... just change the Job number variable in the UDF_Test.au3 file to check the existing functions out.
      Enjoy!
      P.S. This is also related to a new program I have just finished and uploaded - INItoSQL DB
×