block by sxywu 03da5746504ff83db37ca787fd4cf62f

Film Flowers, Full Starter

Full Screen

Built with blockbuilder.org

forked from sxywu‘s block: DS July: Code 1

forked from sxywu‘s block: DS July: Code 2

forked from sxywu‘s block: DS July: Code 3

forked from sxywu‘s block: DS July: Code 4

forked from sxywu‘s block: DS July: Code 5

forked from sxywu‘s block: DS July: Code 6

forked from sxywu‘s block: DS July: Code 7

forked from sxywu‘s block: Film Flowers, All

forked from anonymous‘s block: Film Flowers, Refactored

forked from sxywu‘s block: Film Flowers, Single Complete

forked from sxywu‘s block: Film Flowers, Full Complete

index.html

<!DOCTYPE html>
<head>
  <meta charset="utf-8">
  <script src="https://d3js.org/d3.v4.min.js"></script>
  <script src='https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.13.1/lodash.js'></script>
  <link href='https://fonts.googleapis.com/css?family=Libre+Baskerville:400,700' rel='stylesheet' type='text/css'>
  
  <style>
    svg {
      width: 600px;
      height: 20000px;
    }
  </style>
</head>

<body>
  <svg></svg>
  
  <script>
    const width = 600;
    const height = 600;
    
    const petalPaths = [[
    	'M0,0',
      'C50,40 50,70 20,100',
      'L0,85',
      'L-20,100',
      'C-50,70 -50,40 0,0'
    ],
    	// ADD 3 MORE PETAL PATHS                   
    ];
    
    // instantiate scales and petal path lookup
    const sizeScale = d3.scaleLinear()
    	.range([0.1, 1]);
   	const numPetalsScale = d3.scaleQuantize()
    	.range(_.range(5, 10));
    const pathLookup = {
      G: petalPaths[0],
      PG: petalPaths[1],
      'PG-13': petalPaths[2],
      R: petalPaths[3],
    };
    
    // grab svg
    const svg = d3.select(' svg');
    
    /*****************************************************
    ** get movie data
    ******************************************************/
    
    d3.json('movies.json', function(movies) {
      movies = _.map(movies, movie => {
        return {
          rating: ++movie.imdbRating,
          votes: parseInt(movie.imdbVotes.replace(/\,/g, '')),
          year: ++movie.Year,
          title: movie.Title,
          pg: movie.Rated,
        }
      });
      
      // 1. set domain for scales

      // 2. create a <g> for each flower
      // and translate+scale the whole flower
      // instead of individual petals
      
      // 2. for each flower calculate
      // number of petals and their angle of rotation
      // and draw them like before
    });
    
  </script>
</body>