block by mpmckenna8 f0abe7ae10eef35972bd

4 little David Bowie head SVGs

Full Screen

Click to make the David Bowie heads move if not groove.

This is a little demo inspired by wanting to learn a little more about these svg things in a non map context after seeing Mike Bostock’s Three Little Circles tutorial I decided to apply some of those and other d3 concepts to 4 David Bowie heads. I’ll try and explain what’s different in this code than that tutorial, but for now you can click anywhere on the violet background to make the Bowie heads move!

The awesome icon is called David Bowie by Vlad Likh from The Noun Project.

Separating out the JavaScript

So in most of my bl.ock examples and many of way smart people they put a bunch of the code in one index.html file. Often all the Javascript and CSS, and if there’s not that much code it’s cool but I want to start separating stuff out so I put my d3 code in a file called threeBowie.js even though I decided to to 4 Bowies. Though I was still lazy and left my CSS in the index.html file.

Appending everything to the page

In the tutorial you start with a bunch of circle svg elements already on defined for you. Here we append the svg w/ the purplish background then append some images to this svg.

Basic Transitions

In the Future

I want to make the heads keep dancing so I’m going to try a setInterval thing or maybe do something else. It’s also heck of easy to make the images change height and width in the same manner they were moved. Make it better and show me please!

index.html

<!DOCTYPE html>
<meta charset="utf-8">
    <style>

.floor{
  background:violet;
}
</style>
<body>


<script src="//d3js.org/d3.v3.js"></script>


<script src="threeBowie.js">        </script>
    </body>

icon_21660.svg

<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" id="Your_Icon" x="0px" y="0px" width="100px" height="100px" viewBox="0 0 100 100" enable-background="new 0 0 100 100" xml:space="preserve">
<path d="M82,80.038v-0.465c-13-4.076-17.154-5.865-22.676-12.828c0.299-0.226,0.401-0.464,0.689-0.715  c1.211,1.318,3.676,3.619,6.606,3.356c-2.08-2.08-2.373-3.917-1.689-5.099c1.009,0.815,3.168,1.693,5.777,1.327  C68.058,63.657,66.607,59,66.469,55C66.467,55,67,55,67,55s0-0.376,0-0.378l-0.149,0.011c0.109,0.01,0.087,0.018,0.199,0.018  c1.114,0,2.12-0.562,2.876-1.541c0.59-0.766,0.938-1.767,1.044-2.818l0.466-4.845c0.11-1.104-0.097-2.203-0.57-3.091  c-0.618-1.167-1.662-1.905-2.854-2.024l-0.194-0.018l0.345-11.045c0.107-0.133,0.174-0.621,0.174-1.644  c0-4.651,2.12-6.265,1.609-11.282c-0.753-7.34-5.138-8.237-7.482-9.237c-2.346-0.999-4.834-3.854-5.384-4.649  c-0.428,1.122-0.307,2.794,0,3.67c-3.487-0.02-6.798-5.505-6.798-5.505s-5.751,5.485-9.237,5.505c0.305-0.876,1.65-1.648,1.896-3.79  c-2.448,2.019-4.935,3.77-7.28,4.768c-2.347,1-6.729,1.897-7.485,9.237c-0.51,5.018,1.611,6.631,1.611,11.282  c0,1.023,0.068,1.511,0.175,1.644l0.347,11.045l-0.193,0.018c-1.193,0.119-2.232,0.857-2.851,2.024  c-0.473,0.89-0.671,1.987-0.562,3.091l0.482,4.844c0.105,1.053,0.489,2.054,1.08,2.819c0.757,0.979,1.83,1.541,2.942,1.541  c0.11,0,0.223-0.008,0.333-0.018l0.039-0.004c-0.139,3.459-1.567,8.843-4.218,10.801c2.611,0.366,4.793-0.326,5.802-1.142  c0.684,1.182,0.438,3.019-1.642,5.099c2.93,0.263,5.491-2.037,6.702-3.354c0.301,0.263,0.778,0.512,1.094,0.75  C33.776,73.715,28,75.504,17,79.573v2.352c0,0.009,0,0.018,0,0.026v0.289c0,5.615,0,17.76,0,17.76h65c0,0,0-12.146,0-17.76l0,0v-2.2  V80.038z M33.288,52.235l-1.968,0.196c-0.039,0.003-0.077,0.005-0.114,0.005c-0.885,0-1.686-1.026-1.821-2.366l-0.482-4.844  c-0.139-1.395,0.501-2.603,1.432-2.693l2.008-0.2c0.037-0.004,0.074-0.007,0.11-0.007c0.084,0,0.17,0.011,0.252,0.028  c0.184-2.825,0.286-5.646,0.599-8.284l0.021-0.107c0,0,0.007-0.094,0.023-0.261c0.121-0.941,0.27-1.858,0.463-2.741  c0.48-2.01,1.403-4.381,3.133-4.889c2.557-0.752,5.196,0.098,9.233,0.429L34.76,48.525l9.728-3.121l-6.547,15.05l17.999-21.779  l-10.229,3.121c0,0,9.099-11.659,12.566-16.009c1.021-0.049,1.967,0.011,2.9,0.286c1.197,0.352,2.009,1.597,2.554,2.999  c1.225,3.86,1.301,8.578,1.607,13.306c0.108-0.031,0.221-0.049,0.334-0.049c0.035,0,0.07,0.001,0.105,0.005l2.01,0.2  c0.929,0.091,1.568,1.298,1.431,2.693l-0.482,4.844c-0.133,1.339-0.936,2.366-1.82,2.366c-0.037,0-0.076-0.002-0.112-0.005  l-2.01-0.2c-0.013-0.002-0.025-0.005-0.037-0.007c-1.819,9.044-7.287,15.579-15.735,15.579  C40.576,67.804,35.11,61.274,33.288,52.235z M48.992,97.424c-12.626,0-18.713-4.491-20.991-12.156  c4.819,1.335,9.174,2.497,9.583,2.683c1.08,0.494,1.404,2.784,1.392,3.815l2.133,0.033c0.001-0.044,0.014-1.104-0.256-2.296  c-0.396-1.754-1.22-2.962-2.382-3.493c-0.682-0.312-5.936-1.606-11.009-2.96c-0.298-1.54-0.471-3.188-0.538-4.933  c5.887-2.42,10.021-4.969,14.09-10.122c2.399,1.332,5.106,2.022,8.009,2.022c2.925,0,5.65-0.701,8.062-2.054  c4.08,5.201,8.147,7.754,14.036,10.19c-0.065,1.729-0.231,3.354-0.514,4.87c-5.038,1.363-10.268,2.672-10.954,2.985  c-1.162,0.531-1.986,1.739-2.383,3.493c-0.27,1.191-0.257,2.252-0.256,2.296l2.133-0.033c-0.012-1.031,0.312-3.321,1.394-3.815  c0.409-0.186,4.751-1.361,9.546-2.706C67.832,93.07,61.718,97.424,48.992,97.424z"/>
</svg>

threeBowie.js

var svg = d3.select('body').append('svg').attr('width', 720).attr('height',270).attr('class','floor');


var daves = [1,2,3,4]

var xpos = 40


// this is what appends some pictures to my svg
svg.selectAll('.bows')
  .data(daves)
  .enter()
  .append('image')
  .attr('xlink:href', './icon_21660.svg')
  .attr('x', function(d){
    return 70 * d
  })
  .attr('y', 40)
  .attr('width',100)
  .attr('height',100)
  .attr('class','bows');


function dance (){

  svg.selectAll('.bows')
  .transition()
  .delay(500)
  .attr('x',function(d){
    return Math.random() *720 -29;
  })
  .attr('y',function(d){
    return Math.random() *200 -30;
  })
  .duration(5000)



};

d3.select('svg')
.on('click',function(){
 return dance()}
)



dance()