Skip to content

tylergregg/unity-webgl-youtube

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

unity-webgl-youtube

Add embedded youtube videos to a Unity WebGL build.

What?

Videos are played in iframes, just like normal youtube embeds. The iframes are transformed with 3D CSS, and are then visible behind transparent areas of the Unity player.

There's a demo here: https://tylergregg.itch.io/unity-webgl-youtube. I included a simple FPS controller that was the second google result for "unity fps controller."

Built with Unity 2023.1.13f1. It may very well work with earlier versions, but I haven't tried.

Huh?

Ingredients:

This shader, which masks everything behind it except the camera background: https://stackoverflow.com/questions/72477399/occluding-parts-of-an-object-behind-a-transparent-object

This Unity package, which makes the WebGL canvas background transparent: https://forum.unity.com/threads/how-can-i-make-the-canvas-transparent-on-webgl.831580/#post-8310864

three.js and its CSS 3D Renderer.

Some quaternion magic from this thread, which turned out not to be entirely correct, OR (more likely) I've made a mistake somewhere: https://stackoverflow.com/questions/18066581/convert-unity-transforms-to-three-js-rotations

How?

Extract all the files into your project. There's a sample implementation in the YoutubeDemo scene.

In Project Settings under Resolution & Presentation, select the "Youtube" WebGL template.

Set your main camera clear flags to Solid Color with alpha = 0. Add the WebClickHandler component to the camera.

If you don't use the SC_FPSController component on your player object, note that ProcessInput() is called from the template at the beginning of animate(), and when that function is done it calls SyncCameraTransform() in WebSync.jslib. You'll need to do something similar in your implementation, and be sure to maintain the order that things happen to avoid camera lag.

You can either use the provided YoutubeVideoPlayer prefab, or create a quad, add the CSS3DIframe component, and set its xy scale to 4.8 x 3.6. This will result in a 480px x 360px iframe. Note that only y-axis rotation is supported at the moment.

Set the iframe's id to something unique (like "youtubePlayer1").
You can either add video IDs to the videoIdList OR select a listType and set listId to a playlist ID or youtube username. Doing the latter will override the former.

Drag the YoutubeManager prefab into your scene. This sets the video titles, and also delays loading youtube's API until after Unity tells the browser to create the iframes. I don't know why this is necessary, but it doesn't work otherwise with dynamically added iframes.

What else?

While you can run this in editor, the video players only work in a WebGL build.

Interaction is limited to click to play/pause/unpause and playlist next/previous buttons. Interacting with the iframes directly would require using the mouse cursor and temporarily disabling pointer events on the Unity player. This is possible, but awkward.

Fullscreen mode works, except when exiting in Safari the canvas is in the wrong position for 10-20 seconds before shifting back into place. No idea why.

Safari, Chrome, and Firefox on Mac don't show videos when running on localhost. In Safari you can get around this by disabling the Cross-Origin-Embedder-Policy (COEP) Header in Preferences->Feature Flags.

Safari (Mac and iOS) had a bug where videos wouldn't play when refreshing the page. It doesn't happen when the iframes are predefined, so in index.html you'll see a bunch of iframes with the same youtubeStaticPlayer id. If that isn't enough to handle all the videos in your scene, copy and paste that iframe declaration as many times as you need. It's messy, but I couldn't find another way around the problem.

iOS: It works! For the most part. Due to what I assume are restrictions by Apple, youtube's setVolume() function doesn't work as expected - videos either play muted or at your device's current volume level, so I disabled the distance-based volume. Also, videos won't autoplay, and starting a second video automatically pauses the first one.

My quaternion math is a mess. Help.

About

Add YouTube embeds to a Unity WebGL build

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published