Last Friday, I gave a brownbag talk for my Virtual Coffee community on getting started with streaming on Twitch.
This is a work in progress post. I'm just putting out what I had in my slide deck here, but in a more readable format than the bullet points in the slide deck. Feedback is welcome.
Open Broadcaster Software (OBS) permalink
The first thing to do is install OBS. It is the standard when it comes to streaming. There are tools built on top of it, but typically I recommend using bare-bones OBS or Streamlabs OBS (SLOBS) which is OBS with some plugins from Streamlabs.
The main reason to use OBS or SLOBS is more flexibility when streaming, and as far as I know, OBS is the only one that allows you to stream closed captioning.
For the remainder of the post, I will refer to just OBS instead of OBS/SLOBS.
I won't do a deep dive into all the things you can do with OBS, but know that you can create scenes with many sources. A scene can be for example a starting soon page, and when you're ready to start talking you transition to another scene, perhaps called chatting or coding view.
There are many sources you can add to a scene:
- images
- browser sources, e.g. a web page used for an overlay in your stream
- display capture, e.g. an external monitor
- video capture device, e.g. a webcam
- etc.
Streaming Checklist permalink
It's important to go over your setup before going live on a stream. You want to make sure audio is good, video etc. Here is a sample checklist that I created for the purpose of this post. It's a reduced version of my own checklist.
- Turn off notifications for any software on laptop
- Ensure closed captioning is working with OBS
- Check audio is not muted and is working for you and your guests
- Have Twitch chat open in a browser or the entire stream (make sure stream is muted!)
- Ensure you’re on the right scene to start
Going Live permalink
Here's some typical steps to take when going live on a stream.
- Go over checklist
- Tweet out that you are going live on your stream with a link to your stream. SLOBS has this built-in
- Start Stream
- Check the stream to make sure you’re streaming
- You should be good to go at this point
Streaming Tips permalink
Here are some streaming tips that I've found useful
- Interact with the Twitch chat
- It’s not going to be perfect, that’s OK
- Have fun, really!
- If you’re live coding, talk through what you’re doing
- Tweet midway through your stream that you’re still streaming about topic X or live coding
Come by and say hi! We're hanging with @cassidoo on the @ThePracticalDev Twitch stream currently chatting about mechanical keyboards!https://t.co/z8E6kmqLsA #DEVCommunity
— Nick Taylor (he/him) (@nickytonline) June 16, 2021
- Post your streams to Polywork, LinkedIn and Twitter. Here are some examples at timeline.iamdeveloper.com, my LinkedIn, and Twitter
If you missed the Twitch stream with @jlengstorf, check it out on @ThePracticalDev Youtube.
— Christina Gorton (@coffeecraftcode) April 21, 2021
We talked Jamstack, serverless, and @nickytonline and Jason used serverless functions on Netlify to quickly set up an API to grab DEV posts with the DEV API. 🥳https://t.co/pMnlitQt7N
- Have a consistent schedule
- Don’t worry if no one or few people are watching your stream when you get started out
- Zoom in your editor and browser to help folks see things better
- If you use Visual Studio Code, @john_papa created an amazing extension for hiding environment files called Cloak
It's only for environment files, but I use @John_Papa's Cloak extension, https://t.co/4JAGgb937j
— Nick Taylor (he/him) (@nickytonline) August 1, 2021
- If you plan on uploading your streams to YouTube or want to create clips later, ensure that you have Store past broadcasts on in your stream settings
Having Guests on Your Stream permalink
There is no native way for guests to join a stream in OBS, so a third party application is required. These are the common ones that are out there:
For Discussions permalink
You should have one or more topics to discuss, but they do not need to be scripted. It should feel natural. I also tend to go on tangents sometimes. Maybe this is good, maybe it's bad. 🙃
Extras permalink
Here's some not necessarily crucial stuff for your stream, but some nice additions to spice up your stream.
- Add interactivity to your stream. A browser source in a scene that loads a page using ComfyJS is a great for this.
- Automate things as much as possible
- Scheduled tweet that you’re going live
- Use a stream deck if it’s in your budget. I bought one about a year into streaming.
- Use service like StreamLabs or StreamElements for moderation bots, interactivity, like when someone follows your stream.
Additional software permalink
Below is a list of additional software that can help you out during a stream or post-stream.
- Loopback, for merging audio or creating other virtual audio devices
- descript, for subtitles, removing filler words, and video editing if you plan on publishing your streams to YouTube
- krisp, noise-cancelling software
Hardware permalink
Although not required when starting out with streaming, these are things you can add to your stream over time.
- Light ring
- An external microphone
- Better Web Cam or Camera
- Streaming Deck
If your worries about equipment are preventing you from starting a YouTube channel, I started mine in Jan 2020 using my phone and the sun as lighting!! Don't let equipment stop you from creating. Get the fancy stuff later! 🥰 #youtuber #devcommunity #Growth pic.twitter.com/nQJfzo75EN
— Ania Kubów #JavaScriptGames (@ania_kubow) July 29, 2021
Additional Resources permalink
- Web Captioner
- Steve Seguin’s YouTube channel (creator of VDO.ninja)
- The Invisible Zoom Streaming method by Rachael Wright-Munn
- Pair Programming with Jhey (shows how to use ComfyJS)
- livecoding.ca’s interactions using ComfyJS
- My Uses Page (software and hardware I use)
And last but not least, some shameless plugs!
Until next time folks!