Scott Hanselman

Easy steps to a mobile-friendly responsive design with an embedded YouTube video and a fluid resize

January 06, 2012 Comment on this post [11] Posted in HTML5 | Mobile | Open Source | Speaking
Sponsored By

imageI recently did a video with Rob Conery on how to be a better technical speaker and blogged about it. I wanted to put up a site for this video to give people more details and to make it easier for me to get the word about about the video separate from Tekpub. I went and bought http://speakinghacks.com and fired up WebMatrix to do a quick one-pager.

The idea was to spend only an hour on this from the moment I got the domain to a "complete" site. My requirements were:

  • An easy to remember domain name.
  • A site that looks kind of like my existing site, to keep the branding cohesive.
    • Cool I've got some existing CSS.
  • Site should look good on mobiles and tablets so I want to use responsive design.
    • Um...
  • A site that includes the free trailer for my video that plays on any device, including phones and tablets.
    • Um...
  • A site that resizes cleanly, rotates cleanly and the video thumbnail is always as large as possible.
    • Um...

First step, a decent starter template that works on Mobile

For stuff like this, I now always started with a decent boilerplate. There's even group knowledge and experience that there's little reason for me to New Blank HTML File these days.

There are a number of options out there, including two of my favorites:

There's others, and the nice thing is that you can get started with a template like this in minutes, not hours, so go find one that makes you happy.

I picked Skeleton, then with a little magic help from Jzy and a late night Skype (go visit his http://programmerryangosling.tumblr.com site, by the way!) we brought in a few elements from my currently blog template so the general look and feel is still there.

Add a YouTube video

There's a number of ways to embed a video that will use Silverlight or Flash if HTML5 video isn't available, including

  • VideoJS - A really nice and image-free HTML5 video player with a series of templates that can make it look like Vimeo or YouTube or others. Works everywhere.
  • SublimeVideo - Free and pretty but they have a few sign up things if you serve hundreds of thousands of views.
  • jMediaelement or "jme" - Clean, basic, simple, open. Flash fallback and semantic code.

These are all great but if you've already got your video up on YouTube, Vimeo, Blip or another video sharing site, you might just want to make that existing video embed resizable.

For that, you can use FitVid, a small jQuery plugin that will take effectively any video element and make it resizable and usable in a responsive design.

Originally Rob was using a Flash player called Flowplayer but I recommended that he save money by serving his video trailers on YouTube. That meant that I could serve my trailer video from YouTube. While I could then use the FitVid JavaScript to make the video resizable, it seemed like overkill to use some JavaScript to resize something that CSS should be handling for me.

Enter A List Apart and their article on Intrinsic Ratios for Video. The hardish part about resizing a video is maintaining the ratio, like 16:9 for example. As they say:

padding-bottom: 56.25%
To create a 16:9 ratio, we must divide 9 by 16 (0.5625 or 56.25%).

Anders M. Andersen has a nice clean example of this with the CSS, so I ended up with this markup. Only the embed-container class matters in this context. The other containers are used by Skeleton.

<div class="container">
<div class="sixteen columns">
<div class="embed-container">
<iframe id='player' src="http://www.youtube.com/embed/4U4TzAtyYs0" frameborder="0" allowfullscreen></iframe>
</div>
</div>
</div>

And this CSS:

.embed-container {    
position: relative;
padding-bottom: 56.25%; /* 16/9 ratio */
padding-top: 30px; /* IE6 workaround*/
height: 0;
overflow: hidden;
}

.embed-container iframe,
.embed-container object,
.embed-container embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

photoSo now, when you visit http://speakinghacks.com in your desktop browser or your mobile browser, you'll have a lovely experience.

Conclusion

I think I only spent about 2 hours total on this site. Taking advantage of existing CSS wisdom and standing on the shoulders of giants is absolutely the way to go for layouts. I'm totally sold on Responsive Design and am planning on including it on all my sites whenever possible.

Related Links

P.S. As an aside, if you bought the video, drop me a line if you liked it and maybe I can put your review on the site! Also feel free to write a review at SpeakerMix if you've seen me speak before.

About Scott

Scott Hanselman is a former professor, former Chief Architect in finance, now speaker, consultant, father, diabetic, and Microsoft employee. He is a failed stand-up comic, a cornrower, and a book author.

facebook bluesky subscribe
About   Newsletter
Hosting By
Hosted on Linux using .NET in an Azure App Service
January 06, 2012 5:49
Maybe not the most helpful comment but here goes: I had the video in my cart, went to the checkout and then discovered I need to use a CC to buy it. Don't have one. Sucks. I would love to pay for it with PayPal or by other means but the only payment method seems to be CC :-(
January 06, 2012 9:46
Hy scott
I'm a huge fan of wordpress. Even small sites I build with wordpress. It is up and running in 2 minutes. You can then choose either a static entry page or a dynamic. Then I usually buy a good design from a professional wordpress theme company 50-100 dollar and tweek it to my needs. What I do before modifying the layout I make a local git repository either in my dropbox or directly on the theme folder of wordpress. Then I stage the initial original design and apply my changes with several stages / commits. With that I assure I can always apply patches on the original layout. With wordpress I'm future ready on the sites for any requirement I might have ( forms, other skins, event manager...)

Daniel
January 07, 2012 0:00
One challenge in responsive design not touched on here is the problem of how to serve up optimally sized videos and images based on the size of the viewport.

This article provides a good starting point for further study:
http://filamentgroup.com/lab/responsive_images_experimenting_with_context_aware_image_sizing/
January 07, 2012 14:51
@Rob Janssen

PayPal is a valid payment method on tekpub.Used it several times.
January 08, 2012 22:06
I signed up for TekPub to watch your video (and because other content there looked good) - enjoyed the "behind the scenes" perspective on your presentations, particularly since I've given a number myself and have always remarked at how thorough-yet-engaging yours consistently are... They've always been good motivation and I've even re-watched some Hanselminutes just to see how you handle some topic transitions.

The video itself validated a lot of what I practice (I even carry my own cables & converters), but I'd still like to know more about how you do what you do... How do you stay motivated? How do you adjust for broadened audiences (I.e., execs + geeks)? How long would you normally speak before interjecting levity or a mental digestion point?

As for TekPub, I have one major annoyance - the DRM or whatever that's going on in the background seems to timeout after 45 minutes, even if you're watching a stream. The only way to make it through your video is to go back to the page, refresh, then start the stream again, provided you remember exactly where you left off.

Thanks for sharing,
Matt
January 24, 2012 20:18
I often view your site on my iPad and iPhone and I'd hardly call them mobile friendly. The biggest complaint I have is removing the ability to pinch/zoom to increase the text size. I don't have bad eyesight, but sometimes I need to zoom in on small type fonts or images to see them better. I've noticed an increasing trend in sites to disable the zooming ability on iOS (I've not tried other devices).

Related to that is the reflowing of text instead of adjusting the viewport size. Sometimes to get the text size to increase I'll turn my iPhone or iPad landscape. On most sites this keeps the text in the lines the same but increases the size of the font to fill the space. On your site the text flows to fill the space without resizing.

I really wish site coders would just stick to a single site and avoid pushing specific device versions. I've not come across a single site that doesn't render/work properly on iOS unless that site is sending device specific markup.
January 28, 2012 5:09
@Alex I; You were right. Just bought the video with PayPal!

Sorry for the late reply.
February 18, 2012 22:21
Nice tut.
Thanks.
July 14, 2012 9:18
Thanks, Scott!
It was really helpful.
I successfully embedded videos in my responsive-layout site :)
- Vincent
August 09, 2012 8:57
Wow, thanks so much for this. Was exactly the answer I was looking for and works like a dream. Oh how I love it when you do a search and it comes up trumps right of the bat.
Jax
September 27, 2012 21:59
It works. Nowadays responsive design is essential and has become compulsory. It is good to find tutorial about making youtube video responsive.

Comments are closed.

Disclaimer: The opinions expressed herein are my own personal opinions and do not represent my employer's view in any way.