X-Git-Url: https://git.ao2.it/vidi-player.git/blobdiff_plain/89d6d61324d22afd1f441c9b01956645c4305fe0..f778b0ade9ac49e0deab3f694c7e4a0905388f1b:/create_test_videofont.py diff --git a/create_test_videofont.py b/create_test_videofont.py index 14c6509..acde8ab 100755 --- a/create_test_videofont.py +++ b/create_test_videofont.py @@ -9,28 +9,39 @@ FONT_DESC = "Mono, 72" SAMPLE_LENGTH_SECONDS = 4 -# 48000 samples per seconds, at 1024 samples per buffer -NUM_AUDIO_BUFFERS = round(SAMPLE_LENGTH_SECONDS * 48000 / 1024) +VIDEO_FRAMERATE = 25 +VIDEO_BUFFERS = SAMPLE_LENGTH_SECONDS * VIDEO_FRAMERATE + +AUDIO_SAMPLERATE = 48000 +AUDIO_SAMPLESPERBUFFER = 1024 +AUDIO_BUFFERS = round(SAMPLE_LENGTH_SECONDS * 48000 / 1024) LIVE_PIPELINE_TEMPLATE = """ - videotestsrc num-buffers=1 pattern=black ! \ + videotestsrc num-buffers=%d pattern=black ! video/x-raw,framerate=%d/1 ! \ textoverlay valignment=center halignment=center font-desc="%s" text="{0}" ! \ autovideosink \ - audiotestsrc num-buffers=%d freq={1:f} ! audio/x-raw,rate=48000 ! \ + audiotestsrc num-buffers=%d samplesperbuffer=%d freq={1:f} ! audio/x-raw,rate=%d ! \ autoaudiosink -""" % (FONT_DESC, NUM_AUDIO_BUFFERS) +""" % (VIDEO_BUFFERS, VIDEO_FRAMERATE, FONT_DESC, AUDIO_BUFFERS, + AUDIO_SAMPLESPERBUFFER, AUDIO_SAMPLERATE) FILE_PIPELINE_TEMPLATE = """ webmmux name=mux ! filesink location="{2}/sample_{0}.webm" - videotestsrc num-buffers=1 pattern=black ! \ + videotestsrc num-buffers=%d pattern=black ! video/x-raw,framerate=%d/1 ! \ textoverlay valignment=center halignment=center font-desc="%s" text="{0}" ! \ queue ! vp9enc ! mux. - audiotestsrc num-buffers=%d freq={1:f} ! audio/x-raw,rate=48000 ! \ + audiotestsrc num-buffers=%d samplesperbuffer=%d freq={1:f} ! audio/x-raw,rate=%d ! \ queue ! audioconvert ! vorbisenc quality=0.5 ! queue ! mux. -""" % (FONT_DESC, NUM_AUDIO_BUFFERS) +""" % (VIDEO_BUFFERS, VIDEO_FRAMERATE, FONT_DESC, AUDIO_BUFFERS, + AUDIO_SAMPLESPERBUFFER, AUDIO_SAMPLERATE) def create_test_videofont(pipeline_template, notes_range, destination_dir=None): + print("Silence") + pipeline_string = pipeline_template.format("rest", 0, destination_dir) + player = vidi.Player.from_pipeline_string(pipeline_string) + player.play() + for i, note_number in enumerate(notes_range): note = vidi.SpnNote(note_number)