<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Paul Hayes &#187; webkit</title>
	<atom:link href="http://www.paulrhayes.com/tag/webkit/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.paulrhayes.com</link>
	<description>The web musings and experiments of.</description>
	<lastBuildDate>Sun, 06 Nov 2011 11:31:18 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Creating a sphere with 3D CSS</title>
		<link>http://www.paulrhayes.com/2011-02/creating-a-sphere-with-3d-css/</link>
		<comments>http://www.paulrhayes.com/2011-02/creating-a-sphere-with-3d-css/#comments</comments>
		<pubDate>Thu, 10 Feb 2011 23:33:33 +0000</pubDate>
		<dc:creator>Paul Hayes</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[Experiments]]></category>
		<category><![CDATA[3d]]></category>
		<category><![CDATA[css3]]></category>
		<category><![CDATA[sphere]]></category>
		<category><![CDATA[transformations]]></category>
		<category><![CDATA[transitions]]></category>
		<category><![CDATA[webkit]]></category>

		<guid isPermaLink="false">http://www.paulrhayes.com/?p=124</guid>
		<description><![CDATA[Rotate and combine elements in 3D space to create an awesome sphere using CSS 3D transforms.]]></description>
			<content:encoded><![CDATA[<p>With CSS3’s 3D transforms I’ve illustrated how to build a <a href="http://www.paulrhayes.com/2009-07/animated-css3-cube-interface-using-3d-transforms/">cube</a> and a <a href="http://www.paulrhayes.com/2010-10/css-tetrahedron/">tetrahedron</a>. It is also possible to create a sphere-like object, albeit with many elements.</p>
<p><a href="http://www.paulrhayes.com/experiments/sphere/">3D CSS Sphere</a><br />
Works in the latest Safari and iOS (just about runs on an iPhone 4).</p>
<p><img src="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-normal.png" alt="3D sphere using CSS transform" width="549" /></p>
<p>Recently I’ve been looking at creating applicable 3D carousels. These rely on positioning panels in a circle around a central point (ie. rotation about the Y-axis), I put these panels in an unordered list. A natural extension is to duplicate each <code>&lt;ul&gt;</code> and rotate about the X-axis. With ‘A’ rounds (or lists), and ‘B’ panels per round (<code>&lt;li&gt;</code>s), I built a script that would distribute these in a circular manner, panels about Y-axis, lists about the X-axis, creating a sphere.</p>
<p>The more elements per round and the more rounds, the smoother the sphere. But this soon stacks up and kills Safari. The optimum numbers have been about 9 rounds and 30 panels per round for a decent looking sphere, but that’s 279 3D elements and Safari starts to choke. Allowing the panels to overlap eases this somewhat and leads to a tighter sphere but it still appears blocky.</p>
<p>The biggest gains come with border radius. Using a huge radius that made each panel circular the sphere suddenly gained a lovely curvature, and the number of rounds and panels could be reduced. In the experiment I use 8 rounds and 24 panels (200 elements). This doesn’t start choking until I start aggressively animating.</p>
<p>Playing with this I’ve built a few different styles of sphere. In the experiment I’ve included the blocky “square” version, along with the smoothed out border radius one (default). Marking panels white, and a few black can create a nice eye-ball effect.</p>
<p><a href="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-square.png"><img src="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-square-150x150.png" alt="Sphere without border radius" width="150" height="150" /></a> <a href="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-eye.png"><img src="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-eye-150x150.png" alt="Eye" width="150" height="150" /></a></p>
<p>Also included in the experiment are versions showing a single round and another style named “contact”. This takes two lists and animates them like the space transportation device in the Jodie Foster movie of the same name.</p>
<p><a href="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-contact.png"><img src="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-contact-150x150.png" alt="Rotating rounds" width="150" height="150" /></a> <a href="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-half.png"><img src="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-half-150x150.png" alt="Half a sphere" width="150" height="150" /></a> <a href="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-kaleid.png"><img src="http://www.paulrhayes.com/wp-content/uploads/2011/02/sphere-kaleid-150x150.png" alt="Kaleidoscope effect" width="150" height="150" /></a></p>
<p>Animating the border radius on all 192 panels (if your machine can cope), gives a neat kaleidoscope effect, also included in the experiment.</p>
<h3>Code</h3>
<p>The generated HTML is simply a couple of <code>&lt;div&gt;</code>s containing lists:</p>
<pre>&lt;div id=&quot;sphere&quot;&gt;
	&lt;div class=&quot;container&quot;&gt;
		&lt;ul&gt;
			&lt;li&gt;&lt;/li&gt;
			&lt;li&gt;&lt;/li&gt;
			…
		&lt;/ul&gt;
		…
	&lt;/div&gt;
&lt;/div&gt;</pre>
<p>To transform each set of panels into a circle the total number is divided by 360 to get the angle of rotation. Merely rotating will put all panels on top of each other, translating in the Z axis will move them out from the centre point. The correct translation distance so the panels slightly overlap (i.e. the circle radius) is worked out with some <a href="http://en.wikipedia.org/wiki/Trigonometry#Mnemonics">simple trigonometry</a>. Lists are rotated in the X axis, simply the number of lists divided by 360.</p>
<p>Looping through each panel for each list, the angles of rotation are gradually increased by the calculated increments and applied to the elements:</p>
<pre>
var panels = p || this.panels,
rounds = r || this.rounds,
rotationPerPanel = 360/panels,
rotationPerRound = 360/2/rounds,
yRotation, xRotation,
width = this.panelWidth,
zTranslate = (width/2) / Math.tan(rotationPerPanel * Math.PI/180),
$container = this.el,
$ul, $li, i, j;

this.el.html(&#39;&#39;);
for(i = 0; i &lt; rounds; i++) {
	$ul = $(&#39;&lt;ul&gt;&#39;);
	xRotation = rotationPerRound * i;
	$ul[0].style.webkitTransform = &quot;rotateX(&quot;+ xRotation + &quot;deg)&quot;;
	for(j = 0; j &lt; panels; j++) {
		$li = $(&#39;&lt;li&gt;&#39;);
		yRotation = rotationPerPanel * j;
		$li[0].style.webkitTransform = &quot;rotateY(&quot;+ yRotation +&quot;deg)
                         translateZ(&quot;+ zTranslate +&quot;px)&quot;;
		$ul.append($li);
	}
	$container.append($ul);
}
</pre>
<p>To achieve the 3D effect we give <code>#sphere</code> some perspective, which forms the containing block. A second container transitions between different transforms, letting us rotate the sphere. The complicated transform parts are applied inline via the JavaScript above, but each list element needs <code>preserve-3d</code> so its direct descendants are transformed in the same 3D space (rather than in 2D).</p>
<pre>
#sphere {
width: 100px;
height: 100px;
margin: 200px auto;
-webkit-perspective: 800;
}

.container {
width: 100px;
height: 100px;
-webkit-transition: -webkit-transform 200ms linear;
-webkit-transform-style: preserve-3d;
}

.container > ul {
-webkit-transform-style: preserve-3d;
width: 100%;
height: 100%;
position: absolute;
}

.container li {
width: 98px;
height: 98px;
position: absolute;
display: block;
background: #000;
border: 1px solid #fff;
opacity: 0.1;
border-radius: 50px;
}</pre>
]]></content:encoded>
			<wfw:commentRss>http://www.paulrhayes.com/2011-02/creating-a-sphere-with-3d-css/feed/</wfw:commentRss>
		<slash:comments>9</slash:comments>
		</item>
		<item>
		<title>CSS 3D cube with touch gestures, click and drag</title>
		<link>http://www.paulrhayes.com/2010-09/3d-css-cube-ii-touch-gestures-click-and-drag/</link>
		<comments>http://www.paulrhayes.com/2010-09/3d-css-cube-ii-touch-gestures-click-and-drag/#comments</comments>
		<pubDate>Tue, 28 Sep 2010 22:20:49 +0000</pubDate>
		<dc:creator>Paul Hayes</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[Experiments]]></category>
		<category><![CDATA[3d]]></category>
		<category><![CDATA[css3]]></category>
		<category><![CDATA[cube]]></category>
		<category><![CDATA[perspective]]></category>
		<category><![CDATA[transformations]]></category>
		<category><![CDATA[transitions]]></category>
		<category><![CDATA[webkit]]></category>

		<guid isPermaLink="false">http://www.paulrhayes.com/?p=108</guid>
		<description><![CDATA[An updated 3D cube that comes with touch gestures and click ‘n’ drag.]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.paulrhayes.com/experiments/cube-3d/touch.html">Experiment: 3D cube with touch gestures and click and drag</a></p>
<p><a href="http://www.paulrhayes.com/experiments/cube-3d/touch.html"><img src="http://host.trivialbeing.org/up/small/3d-cube-ii.png" alt="3D cube"></a></p>
<p>An update on the <a href="http://www.paulrhayes.com/2009-07/animated-css3-cube-interface-using-3d-transforms/">original 3D cube</a> (from July 2009 no less), I’ve added touch gesture support (iOS) and click-and-drag behaviour. Animation is incredibly smooth on the iPhone, even the 3G model. Arrow key presses will still rotate the cube, and ESC will reset it.</p>
<p>One year on and the cube still only works in Safari. Chrome, which says it supports <code>webkit-perspective</code> and <code>webkit-transform</code>, still renders differently. Firefox doesn’t support 3D transforms <i><a href="https://developer.mozilla.org/En/CSS/Using_CSS_transforms">yet</a></i>.</p>
<p>It works relatively simply: on click the start co-ordinates are saved and on drag the difference between current drag position and starting co-ordinates are applied to the cube as a transform, which is completed after the specified transition duration. Many thanks to <a href="http://remysharp.com">Remy Sharp</a> and his rubik’s experiment, which got me started with a lot of the basics.</p>
<h3>Touch tweaks</h3>
<p>Pixel values for touch positions are found in <code>event.originalEvent.touches[0].pageX</code>, instead of <code>event.pageX</code>. Using ‘start minus current’ pixel values led the cube to rotate more than intended on the iPhone. To correct, and for intuitive behaviour, the difference is reduced by a factor of four. </p>
<p>JavaScript prevents single touch default events — e.g. scrolling and text selection, but if it detects more than one touch (<code>event.originalEvent.touches.length</code>) the cube won’t rotate, so pinch and zoom will still work. This is a compromise.</p>
<p>A 200ms transition duration suits the browser, but on touch devices it felt sluggish, so I’ve upped it to 50ms so the cube is always at your finger-tips.</p>
<h3>Better CSS</h3>
<p>The cube is created exactly as before, but I’ve simplified the markup a little — dropping the <em>face</em> and <em>number</em> class names in favour of CSS3 selectors:</p>
<pre>
#cube > div:first-child  {
-webkit-transform: rotateX(90deg) translateZ(200px);
}

#cube > div:nth-child(2) {
-webkit-transform: translateZ(200px);
}

#cube > div:nth-child(3) {
-webkit-transform: rotateY(90deg) translateZ(200px);
text-align: center;
}

#cube > div:nth-child(4) {
-webkit-transform: rotateY(180deg) translateZ(200px);
}

#cube > div:nth-child(5) {
-webkit-transform: rotateY(-90deg) translateZ(200px);
}

#cube > div:nth-child(6) {
-webkit-transform: rotateX(-90deg) rotate(180deg) translateZ(200px) ;
}
</pre>
<h3>Any questions?</h3>
<p>This is quite a speedy write-up, if anything needs explaining I’m happy to go into a bit more detail.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.paulrhayes.com/2010-09/3d-css-cube-ii-touch-gestures-click-and-drag/feed/</wfw:commentRss>
		<slash:comments>20</slash:comments>
		</item>
		<item>
		<title>Animated CSS3 cube using 3D transforms</title>
		<link>http://www.paulrhayes.com/2009-07/animated-css3-cube-interface-using-3d-transforms/</link>
		<comments>http://www.paulrhayes.com/2009-07/animated-css3-cube-interface-using-3d-transforms/#comments</comments>
		<pubDate>Sat, 18 Jul 2009 01:16:54 +0000</pubDate>
		<dc:creator>Paul Hayes</dc:creator>
				<category><![CDATA[Experiments]]></category>
		<category><![CDATA[3d]]></category>
		<category><![CDATA[css3]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[perspective]]></category>
		<category><![CDATA[transformations]]></category>
		<category><![CDATA[transitions]]></category>
		<category><![CDATA[webkit]]></category>

		<guid isPermaLink="false">http://www.fofronline.com/?p=99</guid>
		<description><![CDATA[Position elements with 3D transforms to build a cube and use transitions to rotate on keypress.]]></description>
			<content:encoded><![CDATA[<p class="update"><strong>Update (28th Sept 2010)</strong>: Cube updated to work with touch gestures and click and drag — <a href="http://www.paulrhayes.com/2010-09/3d-css-cube-ii-touch-gestures-click-and-drag/">3D CSS cube II</a></p>
<p>Last week WebKit included the much anticipated (at least on my part) 3D transforms in its latest nightly build, announced practically alongside the awesome <a href="http://www.satine.org/research/webkit/snowleopard/snowstack.html">Snow Stack demo</a> that provides a 3D interface for browsing Flickr images (use left, right and space-bar). Today the <a href="http://webkit.org/blog/386/3d-transforms/">Surfin Safari blog</a> has updated with some more exciting demos, including “<em>Morphin Power Cubes</em>” and “<em>Poster Circle</em>”. It is now possible to create all sorts of crazy three-dimensional and animated user interfaces; the power comes largely in <code>-webkit-perspective</code> and a number of updated transforms–adapted to incorporate the Z axis.</p>
<p><span id="more-99"></span></p>
<p>Since working on the <a href="/2009-04/3d-cube-using-css-transformations/">3D cube using 2D transforms</a> back in April I’ve experimented with perspective to create something more powerful, playing around with 3D transforms on the iPhone a few times (e.g. this <a href="/experiments/perspective/">early rotating demo</a>). Now I’ve got something worth sharing.</p>
<p>A 3D cube can be created solely in CSS, with all six faces. Using JavaScript to detect key presses and update inline styles this cube can be intuitively navigated.</p>
<h3>Result</h3>
<p><a href="/experiments/cube-3d/index.html">A 3D cube that rotates using the Up, Down, Left and Right arrow keys.</a><br />
Supported browsers: WebKit Nightly r46042+</p>
<p class="center"><img src="http://host.trivialbeing.org/up/fofr-online-20090717-3d-cube.jpg" alt="3D cube interface using new WebKit transforms" /></p>
<h3>How To</h3>
<p>I’ll start with the markup, because it’s simple. Each of the six cube faces is given a face class and another relating to it’s number. These six faces sit within a cube container, which sits in another wrapper, each is necessary.</p>
<pre class='prettyprint'>&lt;div id=&quot;experiment&quot;&gt;
	&lt;div id=&quot;cube&quot;&gt;
		&lt;div class=&quot;face one&quot;&gt;
			One face
		&lt;/div&gt;
		&lt;div class=&quot;face two&quot;&gt;
			Up, down, left, right
		&lt;/div&gt;
		&lt;div class=&quot;face three&quot;&gt;
			Lorem ipsum.
		&lt;/div&gt;
		&lt;div class=&quot;face four&quot;&gt;
			New forms of navigation are fun.
		&lt;/div&gt;
		&lt;div class=&quot;face five&quot;&gt;
			Rotating 3D cube
		&lt;/div&gt;
		&lt;div class=&quot;face six&quot;&gt;
			More content
		&lt;/div&gt;
	&lt;/div&gt;
&lt;/div&gt;</pre>
<p>The outer wrapper serves as a camera, on which you apply some perspective — appropriate 3D transformations are then applied to descendants. <code>-webkit-perspective</code> defines the depth of the Z-plane and relative sizes of elements above and below it, <code>-webkit-perspective-origin</code> specifies the perspective’s origin. <a href="http://webkit.org/blog-files/3d-transforms/perspective-by-example.html">View a perspective example (webkit.org)</a></p>
<pre class='prettyprint'>
    #experiment {
      -webkit-perspective: 800;
      -webkit-perspective-origin: 50% 200px;
    }
</pre>
<p>The second container, the actual cube, has a specified height, margin, position, etc. as usual. The height and width are necessary to create some confines for the cube face transformations — alternatively the width defaults to 100% and the cube’s appearance would vary with window width. <code>-webkit-transition</code> (<a href="http://www.w3.org/TR/css3-transitions/">documentation</a>) defines the animated property, duration and timing-function — we’re animating the 3d transformation (via <code>-webkit-transform</code>) linearly for two seconds. <code>-webkit-transform-style</code> determines whether child elements lie flat against their parent (“flat”) or remain in 3D space (“preserve-3d”).</p>
<pre class='prettyprint'>
    #cube {
      position: relative;
      margin: 0 auto;
      height: 400px;
      width: 400px;
      -webkit-transition: -webkit-transform 2s linear;
      -webkit-transform-style: preserve-3d;
    }
</pre>
<p>Using the <code>.face</code> class common styles are applied to the six sides; coloring, size, padding, etc. Importantly they are each positioned absolutely, relative to the cube container. The background rgba property is included to make the cube look pretty and transparent.</p>
<pre class='prettyprint'>
    .face {
      position: absolute;
      height: 360px;
      width: 360px;
      padding: 20px;
      background-color: rgba(50, 50, 50, 0.7);
    }
</pre>
<p>Each of the faces, one through six, needs to be rotated in 3D space to its correct starting position. Using <code>translateZ</code> the elements are brought 200px (half their width) off the Z-plane. Each of the faces must be at 90 degrees. Rotating solely in the X plane positions the top and bottom faces (one, six), before rotating the last four faces in the Y plane, much like origami. The extra rotate on the sixth face rotates the content in 2D space to correct its orientation.</p>
<pre class='prettyprint'>
    #cube .one  {
      -webkit-transform: rotateX(90deg) translateZ(200px);
    }

    #cube .two {
      -webkit-transform: translateZ(200px);
    }

    #cube .three {
      -webkit-transform: rotateY(90deg) translateZ(200px);
    }

    #cube .four {
      -webkit-transform: rotateY(180deg) translateZ(200px);
    }

    #cube .five {
      -webkit-transform: rotateY(-90deg) translateZ(200px);
    }

    #cube .six {
      -webkit-transform: rotateX(-90deg) translateZ(200px) rotate(180deg);
    }
</pre>
<p>Our cube is now complete — but it doesn’t move! With a keydown event listener we can increment X and Y angles based on different key presses, before applying them as inline styles on the cube container. In combination with the transition effect on #cube, all six faces rotate in sync from their original position to the newly defined angle, creating a seamless 3D cube interface.</p>
<pre class='prettyprint'>
  	var xAngle = 0, yAngle = 0;
	document.addEventListener('keydown', function(e)
	{
		switch(e.keyCode)
		{

			case 37: // left
				yAngle -= 90;
				break;

			case 38: // up
				xAngle += 90;
				break;

			case 39: // right
				yAngle += 90;
				break;

			case 40: // down
				xAngle -= 90;
				break;
		};

		$('cube').style.webkitTransform = "rotateX("+xAngle+"deg) rotateY("+yAngle+"deg)";
	}, false);
</pre>
]]></content:encoded>
			<wfw:commentRss>http://www.paulrhayes.com/2009-07/animated-css3-cube-interface-using-3d-transforms/feed/</wfw:commentRss>
		<slash:comments>74</slash:comments>
		</item>
		<item>
		<title>Accordion using only CSS</title>
		<link>http://www.paulrhayes.com/2009-06/accordion-using-only-css/</link>
		<comments>http://www.paulrhayes.com/2009-06/accordion-using-only-css/#comments</comments>
		<pubDate>Thu, 25 Jun 2009 22:46:36 +0000</pubDate>
		<dc:creator>Paul Hayes</dc:creator>
				<category><![CDATA[Experiments]]></category>
		<category><![CDATA[css3]]></category>
		<category><![CDATA[transitions]]></category>
		<category><![CDATA[webkit]]></category>

		<guid isPermaLink="false">http://www.fofronline.com/?p=89</guid>
		<description><![CDATA[An animated accordion without JavaScript, using the :target pseudoclass.]]></description>
			<content:encoded><![CDATA[<p>An accordion effect can be achieved using CSS3’s <code>:target</code> pseudo-class, without requiring JavaScript. Using the proprietary <code>-webkit-transition</code> property this accordion can also be animated.<br />
<span id="more-89"></span></p>
<h3>Result</h3>
<p><a href="/experiments/accordion/#one">CSS3 Accordion</a><br />
Works in browsers that support the <code>:target</code> pseudo-class, see the <a href="http://www.quirksmode.org/css/contents.html#t34">Quirks Mode compatibility tables</a>. Animation works in recent WebKit based browsers.</p>
<h3>How To</h3>
<p>Each part of the accordion has an ID, heading and content region. The header includes a link that matches the section’s ID, whilst the content is wrapped in a container which will control its display.</p>
<pre class="prettyprint">
&lt;div class=&quot;accordion&quot;&gt;
	&lt;h2&gt;Accordion Demo&lt;/h2&gt;
	&lt;div id=&quot;one&quot; class=&quot;section&quot;&gt;
		&lt;h3&gt;
			&lt;a href=&quot;#one&quot;&gt;Heading 1&lt;/a&gt;
		&lt;/h3&gt;
		&lt;div&gt;
			&lt;p&gt;Content&lt;/p&gt;
		&lt;/div&gt;
	&lt;/div&gt;
	&lt;div id=&quot;two&quot; class=&quot;section&quot;&gt;
		&lt;h3&gt;
			&lt;a href=&quot;#two&quot;&gt;Heading 2&lt;/a&gt;
		&lt;/h3&gt;
		&lt;div&gt;
			&lt;p&gt;Content&lt;/p&gt;
		&lt;/div&gt;
	&lt;/div&gt;
&lt;/div&gt;
</pre>
<p>The CSS then relies on the <code>:target</code> pseudo-class to apply different styles to the chosen section — increasing the height and, in large content cases, altering the overflow behaviour to allow scrolling. To animate the opening and closing of sections the <code>-webkit-transition</code> property is needed (<a href="http://www.w3.org/TR/css3-transitions/">documentation</a>), in this case acting on the height attribute for a duration of 0.3 seconds using the ease-in timing function.</p>
<p>Stripping out the styling, the CSS boils down to:</p>
<pre class="prettyprint">
.accordion h3 + div {
	height: 0;
	overflow: hidden;
	-webkit-transition: height 0.3s ease-in;
}

.accordion :target h3 + div {
	height: 100px;
}

.accordion .section.large:target h3 + div {
	overflow: auto;
}</pre>
<h3>Critique</h3>
<p>Obviously this approach has its limitations. Multiple open accordions on one page wouldn’t be possible — restricted by a URI’s one fragment identifier limit; as one accordion opens the other would lose the target and automatically close. Similarly, pages that use a fragment identifier for everyday use will notice oddities — take for instance when using <em>top</em> links to return to the top of the page, any accordion would, in this case, reset. Other uses include accessibility links and simulated page histories when using Ajax.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.paulrhayes.com/2009-06/accordion-using-only-css/feed/</wfw:commentRss>
		<slash:comments>51</slash:comments>
		</item>
		<item>
		<title>Auto-scrolling Parallax Effect without JavaScript</title>
		<link>http://www.paulrhayes.com/2009-04/auto-scrolling-parallax-effect-without-javascript/</link>
		<comments>http://www.paulrhayes.com/2009-04/auto-scrolling-parallax-effect-without-javascript/#comments</comments>
		<pubDate>Thu, 02 Apr 2009 07:40:16 +0000</pubDate>
		<dc:creator>Paul Hayes</dc:creator>
				<category><![CDATA[Experiments]]></category>
		<category><![CDATA[css3]]></category>
		<category><![CDATA[parallax]]></category>
		<category><![CDATA[transitions]]></category>
		<category><![CDATA[webkit]]></category>

		<guid isPermaLink="false">http://www.fofronline.com/?p=48</guid>
		<description><![CDATA[Recreating the infamous parallax without scripting, using only CSS3.]]></description>
			<content:encoded><![CDATA[<p>Here’s another quick CSS3/WebKit transitions project in the controversial realm of CSS animation. This time I have opted to recreate the popular parallax effect using multiple background images on a single element and the <code>-webkit-transition</code> property (<a href="http://webkit.org/specs/CSSVisualEffects/CSSTransitions.html">documentation</a>). I have based this on Chris Coyier’s <a href="http://css-tricks.com/3d-parralax-background-effect/">parallax tutorial</a>, reusing the star images with permission, the technique itself was coined by <a href="http://clearleft.com/is/paulannett/">Paul Annett</a> (explanation on <a href="http://thinkvitamin.com/features/how-to-recreate-silverbacks-parallax-effect/">Think Vitamin</a>). If you’re not quite sure what parallax is, then Chris and Paul both go into some depth to explain it and <a href="http://en.wikipedia.org/wiki/Parallax">Wikipedia</a> is always helpful.<br />
<span id="more-48"></span></p>
<h3>Result</h3>
<p><a href="/experiments/parallax/#experiment">Experiment: Auto-scrolling CSS3 Parallax Effect</a><br />
Experiment works in Safari 4 Beta and Google Chrome. No JavaScript necessary.</p>
<p class="center"><img src="http://host.trivialbeing.org/up/fofrOnlineAutoScrollingParallax.jpg" alt="Correctly rendered background images for parallax effect" /></p>
<h3>How To</h3>
<p>The HTML markup is fairly simple, one DIV for the background and another for the content, the example uses CSS3’s multiple backgrounds, so no need for extra markup to accommodate all those other images:</p>
<pre class='prettyprint'>
&lt;div id=&quot;background&quot;&gt;&lt;/div&gt;
&lt;div id=&quot;content&quot;&gt;
	Content
&lt;/div&gt;
</pre>
<p>For the CSS the background container is set to a fixed position (for convenience more than anything) and spread across the bottom of the page using the top, left, bottom and right properties. The background images are defined using the background shorthand property with multiple declarations being comma delimited, the first being the top-most. Each of the images has a different position defined in percentage, so as the size of the container changes (e.g. on window resize) the images move disproportionately to each other; creating the impressive parallax effect.</p>
<pre class='prettyprint'>
#background {
	background: url('../images/foreground.png') 5% 5%,
		url('../images/midground.png') 20% 20%,
		url('../images/background.png') 90% 110%;
}
</pre>
<p>Ordinarily this effect is only seen when the page is re-sized or JavaScript is used for animation. My first approach to animation via CSS was to apply the transition to the background-positions, with background-position being an <em>animatable</em> property as defined in the proposed specification. However this doesn’t yet work in the latest WebKit nightly build (r42142), it is a <a href="https://bugs.webkit.org/show_bug.cgi?id=23219">known</a> <a href="http://farukat.es/bugs/webkit-background-pos-trans.html">bug</a>.</p>
<p>As an alternate route, albeit a temporary one, I have opted to use transitions to animate the left-most edge of the background container (for instance from 0px to –100px). This gradually alters the overall width of the container causing the backgrounds to shift disproportionately as per their percentages, creating the parallax effect. With a large enough duration and left position the effect appears to be continuous.</p>
<pre class='prettyprint'>
#background {
	left: 0;
	-webkit-transition: left 300s linear;
}

#experiment:target #background {
	left: -5000px;
}</pre>
<p>To make things a bit more fun I’ve increased the ‘flying speed’ when the mouse hovers over the background area. The final CSS looks like this:</p>
<pre class='prettyprint'>
#background {
	background: url('../images/foreground.png') 5% 5%,
		url('../images/midground.png') 20% 20%,
		url('../images/background.png') 90% 110%;
	top: 218px;
	left: 0;
	right: 0;
	bottom: 0;
	position: fixed;
	-webkit-transition: left 300s linear;
}

#experiment:target #background {
	left: -5000px;
}

#experiment:hover #background {
	left: -9999px;
}
</pre>
]]></content:encoded>
			<wfw:commentRss>http://www.paulrhayes.com/2009-04/auto-scrolling-parallax-effect-without-javascript/feed/</wfw:commentRss>
		<slash:comments>18</slash:comments>
		</item>
		<item>
		<title>An analogue clock using only CSS</title>
		<link>http://www.paulrhayes.com/2009-03/an-analogue-clock-using-only-css/</link>
		<comments>http://www.paulrhayes.com/2009-03/an-analogue-clock-using-only-css/#comments</comments>
		<pubDate>Wed, 25 Mar 2009 01:16:44 +0000</pubDate>
		<dc:creator>Paul Hayes</dc:creator>
				<category><![CDATA[Experiments]]></category>
		<category><![CDATA[css3]]></category>
		<category><![CDATA[transformations]]></category>
		<category><![CDATA[transitions]]></category>
		<category><![CDATA[webkit]]></category>

		<guid isPermaLink="false">http://www.fofronline.com/?p=23</guid>
		<description><![CDATA[Use CSS transitions and transforms to rotate clock hands.]]></description>
			<content:encoded><![CDATA[<p>Having read the blurb around <a href="http://webkit.org/blog/138/css-animation/">Safari’s CSS transitions</a> I opted to familiarize myself with a quick project — the aim of which was to create a functional, CSS only, analogue clock.<br />
<span id="more-23"></span></p>
<h3>Result</h3>
<p><a href="/experiments/clock/#clock">Experiment: CSS Analogue Clock</a><br />
Experiment works in Safari 4 Beta and Google Chrome. A working clock that optionally resorts to JavaScript to grab the current time (can be achieved by other means).</p>
<h3>How To</h3>
<p>Before getting into the nitty gritty I created four images, a clock face and three transparent PNG hands (seconds, minutes and hours), ensuring that each of these were the same size so that when overlayed their centres would align. The HTML and CSS to get us going is as follows:</p>
<pre class='prettyprint'>
&lt;div id=&quot;clock&quot;&gt;
	&lt;div id=&quot;hour&quot;&gt;&lt;img src=&quot;images/hourHand.png&quot; /&gt;&lt;/div&gt;
	&lt;div id=&quot;minute&quot;&gt;&lt;img src=&quot;images/minuteHand.png&quot; /&gt;&lt;/div&gt;
	&lt;div id=&quot;second&quot;&gt;&lt;img src=&quot;images/secondHand.png&quot; /&gt;&lt;/div&gt;
&lt;/div&gt;
</pre>
<pre class='prettyprint'>
#clock {
position: relative;
width: 378px;
height: 378px;
background-image: url('../images/clockFace.png');
left: 50%;
margin: 5em 0 0 -189px;
}

#clock div {
position: absolute;
}
</pre>
<p>The magic that rotates the clock’s hands comes via two WebKit specific CSS properties, <code class='prettyprint'>-webkit-transition</code> (<a href="http://webkit.org/specs/CSSVisualEffects/CSSTransitions.html">documentation</a>) and <code class='prettyprint'>-webkit-transform</code> (<a href="http://webkit.org/specs/CSSVisualEffects/CSSTransforms.html">documentation</a>). The transform property can alter the appearance of an element via a two dimensional transformation, for instance: scaling, rotating and skewing a DIV element. In this case it is used to rotate the clock hands to the correct angles; the CSS below puts the hour hand at 3 o’clock:</p>
<pre class='prettyprint'>
#clock img[src*='hour'] {
-webkit-transform: rotate(90deg);
}
</pre>
<p>The transition property creates an animation of a specified property between two values when triggered, for instance fading the opacity on a DIV element from 1 to 0 — triggered using the :hover pseudo class. Transition duration and the transition timing function (e.g. linear) should also be set, amongst other optional properties. In this example the transition is from one transformation angle to another with durations that match the appropriate clock hand, so the second hand takes 60 seconds to complete a 360 degree rotation. The transition is triggered using the :target pseudo element — if the URI contains the ‘clock’ fragment then the time piece shall start ticking.</p>
<pre class='prettyprint'>
#clock img[src*='second'] {
/* -webkit-transition: property duration timing-function */
-webkit-transition: -webkit-transform 60s linear;
}

#clock:target img[src*='second'] {
-webkit-transform: rotate(360deg);
}
</pre>
<p>The above transition lasts only one rotation but by altering the duration length and degree of rotation in accordance the second hand can keep on going (e.g. 600 seconds and 3600 degrees rotation gives a battery life of 10 minutes), a fairly safe assumption that users will not stay on the page for too long.</p>
<pre class='prettyprint'>
#clock img[src*='second'] {
-webkit-transition: -webkit-transform 600000s linear;
}

#clock:target img[src*='second'] {
-webkit-transform: rotate(3600000deg);
}

#clock img[src*='minute'] {
-webkit-transition: -webkit-transform 360000s linear;
}

#clock:target img[src*='minute'] {
-webkit-transform: rotate(36000deg);
}
</pre>
<h3>Grab the current time</h3>
<p>Although the animation works beautifully, CSS alone is not capable of obtaining the current time. To start the clock at the correct time a dynamic transformation needs to be applied to the clock hand containers, this is  easiest done with inline styles and can be set in any number of ways by the backend when the page loads, thereby eradicating any need for JavaScript.</p>
<p>Alternatively, if you’ve no objections to using JavaScript, I’ve created a small <code class='prettyprint'>startClock()</code> function to do the job (<em>albeit using Prototype 1.6.0.3 for my own convenience</em>):</p>
<pre class='prettyprint'>
function startClock() {
	var angle = 360/60;
	var date = new Date();
	var hour = date.getHours();
	if(hour > 12) {
		hour = hour - 12;
	}
	var minute = date.getMinutes();
	var second = date.getSeconds();
	var hourAngle = (360/12)*hour + (360/(12*60))*minute;
	$('minute').setStyle('-webkit-transform: rotate('+angle*minute+'deg)');
	$('second').setStyle('-webkit-transform: rotate('+angle*second+'deg)');
	$('hour').setStyle('-webkit-transform: rotate('+hourAngle+'deg)');
}
</pre>
<p>A word of warning — applying the inline style directly to the image will override the transition effects defined in the CSS file.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.paulrhayes.com/2009-03/an-analogue-clock-using-only-css/feed/</wfw:commentRss>
		<slash:comments>51</slash:comments>
		</item>
	</channel>
</rss>

