Movie-style scrolling credits

Hi guys. First post from a newbie. I like to help my son with creation of game play videos for his YouTube channel, and have been using Shotcut lately (instead of the now-defunct Windows Movie Maker). One feature I was looking for was a way to scroll end credits but wasn’t happy with the results of using the “HTML Overlay” feature to do this…the text I was scrolling with Marquee was choppy. Didn’t like the tutorials I’ve seen out there using Blender either. So, I came up with my own! https://drive.google.com/open?id=0Bw47Y8go9X7dYWFkZElKZ3lBcU0

Yes, it’s a PDF and not a video but perhaps I can create a video tutorial using the PDF doc someday.

Basically I’m playing an HTML with the Marquee tag in Chrome and use OBS Studio to record the screen, then use that clip within Shotcut. I haven’t explored Shotcut enough yet to see if it has its own built-in screen recording (I know it does for audio for voiceovers) so I might have this more complicated than it needs to be.

Anyways, any input you guys have on this would be helpful and feel free to run with it. Thanks!

You can still find, install and use WMM with Windows 10. Yes it’s officially EOL, but it still works just the same.
Also, DaVinci Resolve has a title and credit maker built in. If you have a decent modern PC with more than 8Gb RAM it will run DVR just fine - and it’s also free.

Hi Ken, Your post was very timely for me because I’m just experimenting with scrolling movie credits using HTML overlay too! Your method of creating the scrolling text in a html editor then capturing the screen as it plays in a browser was very useful. Using this method I just came up with this video:

The HTML code I used for the scrolling text is below if anyone would like to experiment with this.

Video end credits adapted by JSR experiment 01.pdf (39.9 KB)

Copying the code from the pdf, putting it into notepad and saving it with a html extension should enable you to open it in a browser.
Notice it uses the @keyframes credits CSS rule rather than the marquee tab and it scrolls very smoothly in the browser.

I adapted it from an example html from a site called codepen: It’s here:
https://codepen.io/oknoblich/pen/vfJxr

What I did was to screen capture (as an mp4) the output from Chrome, using Sharex, then import into Shotcut as well as a short video of clouds which I took using my Panasonic camera, applied a chroma key filter to the text video, and merged the two together. I’m not there yet - the text scrolling is choppy (I probably needed to screen capture it at 60fps, I think it was only 25 or 30fps). Also the green colour is still appearing on the scrolling text.
Will experiment further when I have time but thanks Ken for helping me along the way with this.
My ideal goal is to find out if I can import the HTML code into the Shotcut HTML editor and get it to work that way. I have tried this but can’t get it to work yet.
Jon

That’s awesome!! I’ll have to check out the keyframes credits CSS rule that you mentioned.

I’m at the same point, but the filter needs to be adapted I think…

I’ve been experimenting with the “Overlay HTML” filter and WebVfx to produce smooth scrolling credits and have managed to produce an HTML script that works. It is reasonably simple to understand and can be modified to produce any number of different types of HTML animation.

For an example of the effect see the video:

https://vimeo.com/251327215

I’ll try and put together a tutorial shortly and publish it but in the meantime perhaps you’d like to try it and let me know what you think.

Just modify the HTML to your requirements, but don’t touch the javascript, unless you know what you’re doing. The CSS and HTML can be modified to produce any number of different designs. Before you open the script in the “Filters window” you need to tick the box “Use WebVfx javascript extension” and reply to the popup that asks if you know what you are doing.

The script, which follows, contains a large number of characters in the line starting ‘<img alt=“shotcut logo” src="…’, this is the Shotcut logo in base64 encoding. If you don’t want the logo inserted just delete this (long) line.

 	<html>
<head>
<style>
	html, body    {margin: 0; width: 100%; height: 100%; overflow: hidden;}                                   /* <---- Do NOT change these */
	#credits      {position: absolute; top: 100%; width: 100%; padding:50px 0; margin:0; text-align: center;} /* <---- Do NOT change these */
		/****************************************/
		/* You may change any styles below here */
		/****************************************/
	#credits {font: 50px Liberation Sans, Arial, sans-serif; color: #ddd;} /* Alter the color especially according to your background */
	h1	{font-size: 2em;}                                             /* Alter the size especially according to your requirement */
	.legal	{font-size: 0.75em; width: 50%; margin: auto; color: #bbb;}   /* Alter the color especially according to your background */
	/********************************************************/
			 /* Change CSS below only if you know what you are doing */
	/********************************************************/
	dl	{overflow: hidden}
	dt	{width: 47%; padding: 8px 1%; text-align: right; float:left; clear: left;}
	dd	{width: 47%; padding: 8px 1%; text-align: left;  margin-left: 50%}
	dd:before{display: table; content: ' ';}
	dd:after {display: table; content: ' '; clear: both;}
</style>

<script>
	function Producer(style) {this.style = style;}
	Producer.prototype.render = function(time) {this.style.top = (initial_top - total_height * time) + "px";}; // Scrolls up an increment
	function onLoad() {
		var credits      = document.getElementById("credits");    // The #credits div
		var style        = credits.style;                         // The style object for #credits
		var height       = credits.offsetHeight;                  // The height of #credits
			initial_top  = credits.offsetTop;       // Global scoped variable since it used in the "render" function
			total_height = height + initial_top;    // Global scoped variable since it used in the "render" function
		var producer     = new Producer(style);
	//  Use webvfx to call the "render" function for each frame to change #credit's "top", so making it scroll up.
		webvfx.renderRequested.connect(producer, Producer.prototype.render);
		webvfx.readyRender(true);
	}
	window.addEventListener("load", onLoad, false);
</script>

</head>
<body>
	<div id="credits"> <!-- Do not change the ID of this div, anything in it will appear on the scrolling credits -->
		<h1>Cast</h1>
		<dl>			
			<dt>The Terminator</dt><dd>Arnold Schwarzenegger</dd>
			<dt>Kyle Reese</dt><dd>Michael Biehn</dd>
			<dt>Sarah Connor</dt><dd>Linda Hamilton</dd>
		</dl>
		<h1>Credits</h1>
		<dl>			
			<dt>Director</dt><dd>James Cameron</dd>
			<dt>Writer</dt><dd>James Cameron</dd>
			<dt>Writer</dt><dd>Galyle Anne Hurd</dd>
		</dl>
		<h1>Locations</h1>
		<p>Elephant Rocks, New Zealand</p>
		<p>The Cotswolds, UK</p>
		<p>New York, USA</p>
		<p class="legal">
			No animals were harmed during the making of this film.<br>
			&copy;2018 - Elusien Entertainment.
			Except where otherwise noted, content is licensed under a
			Creative Commons Attribution 4.0 International Licence.
		</p>
		<hr>
		<p>
			<!-- Now display the shotcut logo -->
			Produced using the free, open source, cross-platform video editor:<br><br>
			<img alt="shotcut logo" src=""><br>
			https://shotcut.org
		</p>
	</div>
</body>
</html>
2 Likes

Speed of scrolling is automatically calculated and adapted to the clip lengh?

Yes. The WebVfx renderer is called for every frame in the clip and the speed of movement up the screen is calculated such that the last frame contains the movement into the last incremental position. That is what this line does:

this.style.top = (initial_top - total_height * time) + “px”;

I’m not a “specialist” but it’s what I understood reading it.

I’m just asking myself if it can give a smoother rtesult than the others stuff I’ve tested.
Your test is quite good but a little bit to quick to judge.
(and I just saw it from my phone and I need to see on a computer).
Thanks again :slight_smile:
:clap::clap:

Thank you SO much, Elusian for your post. This gives me a greater understanding of how to use the HTML overlay filter and your code is very useful to me - I will experiment with it when I get some time.

I understand the HTML and CSS part of the code - the WebVfx part is a little above my head right now but it gives me something to investigate. The scrolling is very smooth. Well done and thanks again for your time doing this.
Best wishes
Jon

Hi! I copy and pasted to try your code out, but I wasn’t able to get the overlay to show up on my shotcut video. Is there any other advice you can give me? I tried opening in the browser as well and couldn’t make anything appear.

Can you post the steps you too to use the above code?
Obviously you have made an error somewhere, because I just tried it and it works perfectly.

https://streamable.com/s3lw9

I copy and pasted the full code without changing it into my notepad and saved it as an html. Then, I used the Overlay HTML filter with a black screen video selected first checking the java box before choosing the html file. I made sure the filter itself was checked, clicked reload, and then tried to play the video without exporting.

Actually, nevermind, I neglected to make sure the track was visible; I must have disabled it earlier. Thank you so much for your help!

Mine isn’t the same scale as yours those compared to the video, did you do anything to the code to make it look like that?

No, I just started with a 1920x1080 video (My video mode settings are set at ‘Automatic’ before importing the first video source)

Please note that in the meantime shotcut has added “keyframe” feature. With that you can achieve scrolling text much easier.

The way to do this now is to use the Overlay HTML filter and click the checkbox to enable WebVfx JavaScript extensions. This creates a blank document that scrolls the document body vertically completely over the duration of the filter.