* fix(curriculum): tests quotes * fix(curriculum): fill seed-teardown * fix(curriculum): fix tests and remove unneeded seed-teardown
		
			
				
	
	
		
			102 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 587d7fac367417b2b2512bdd
 | |
| title: Use Dynamic Scales
 | |
| required:
 | |
|   - src: 'https://cdnjs.cloudflare.com/ajax/libs/d3/4.3.0/d3.min.js'
 | |
| challengeType: 6
 | |
| ---
 | |
| 
 | |
| ## Description
 | |
| <section id='description'>
 | |
| The D3 <code>min()</code> and <code>max()</code> methods are useful to help set the scale.
 | |
| Given a complex data set, one priority is to set the scale so the visualization fits the SVG container's width and height. You want all the data plotted inside the SVG canvas so it's visible on the web page.
 | |
| The example below sets the x-axis scale for scatter plot data. The <code>domain()</code> method passes information to the scale about the raw data values for the plot. The <code>range()</code> method gives it information about the actual space on the web page for the visualization.
 | |
| In the example, the domain goes from 0 to the maximum in the set. It uses the <code>max()</code> method with a callback function based on the x values in the arrays. The range uses the SVG canvas' width (<code>w</code>), but it includes some padding, too. This puts space between the scatter plot dots and the edge of the SVG canvas.
 | |
| <blockquote>const dataset = [<br>  [ 34,    78 ],<br>  [ 109,   280 ],<br>  [ 310,   120 ],<br>  [ 79,    411 ],<br>  [ 420,   220 ],<br>  [ 233,   145 ],<br>  [ 333,   96 ],<br>  [ 222,   333 ],<br>  [ 78,    320 ],<br>  [ 21,    123 ]<br>];<br>const w = 500;<br>const h = 500;<br><br>// Padding between the SVG canvas boundary and the plot<br>const padding = 30;<br>const xScale = d3.scaleLinear()<br>  .domain([0, d3.max(dataset, (d) => d[0])])<br>  .range([padding, w - padding]);</blockquote>
 | |
| The padding may be confusing at first. Picture the x-axis as a horizontal line from 0 to 500 (the width value for the SVG canvas). Including the padding in the <code>range()</code> method forces the plot to start at 30 along that line (instead of 0), and end at 470 (instead of 500).
 | |
| </section>
 | |
| 
 | |
| ## Instructions
 | |
| <section id='instructions'>
 | |
| Use the <code>yScale</code> variable to create a linear y-axis scale. The domain should start at zero and go to the maximum y value in the set. The range should use the SVG height (<code>h</code>) and include padding.
 | |
| <strong>Note</strong><br>Remember to keep the plot right-side-up. When you set the range for the y coordinates, the higher value (height minus padding) is the first argument, and the lower value is the second argument.
 | |
| </section>
 | |
| 
 | |
| ## Tests
 | |
| <section id='tests'>
 | |
| 
 | |
| ```yml
 | |
| tests:
 | |
|   - text: The text in the <code>h2</code> should be 30.
 | |
|     testString: assert(output == 30 && $('h2').text() == '30', 'The text in the <code>h2</code> should be 30.');
 | |
|   - text: The <code>domain()</code> of yScale should be equivalent to <code>[0, 411]</code>.
 | |
|     testString: assert(JSON.stringify(yScale.domain()) == JSON.stringify([0, 411]), 'The <code>domain()</code> of yScale should be equivalent to <code>[0, 411]</code>.');
 | |
|   - text: The <code>range()</code> of yScale should be equivalent to <code>[470, 30]</code>.
 | |
|     testString: assert(JSON.stringify(yScale.range()) == JSON.stringify([470, 30]), 'The <code>range()</code> of yScale should be equivalent to <code>[470, 30]</code>.');
 | |
| 
 | |
| ```
 | |
| 
 | |
| </section>
 | |
| 
 | |
| ## Challenge Seed
 | |
| <section id='challengeSeed'>
 | |
| 
 | |
| <div id='html-seed'>
 | |
| 
 | |
| ```html
 | |
| <body>
 | |
|   <script>
 | |
|     const dataset = [
 | |
|                   [ 34,    78 ],
 | |
|                   [ 109,   280 ],
 | |
|                   [ 310,   120 ],
 | |
|                   [ 79,    411 ],
 | |
|                   [ 420,   220 ],
 | |
|                   [ 233,   145 ],
 | |
|                   [ 333,   96 ],
 | |
|                   [ 222,   333 ],
 | |
|                   [ 78,    320 ],
 | |
|                   [ 21,    123 ]
 | |
|                 ];
 | |
| 
 | |
|     const w = 500;
 | |
|     const h = 500;
 | |
| 
 | |
|     // Padding between the SVG canvas boundary and the plot
 | |
|     const padding = 30;
 | |
| 
 | |
|     // Create an x and y scale
 | |
| 
 | |
|     const xScale = d3.scaleLinear()
 | |
|                     .domain([0, d3.max(dataset, (d) => d[0])])
 | |
|                     .range([padding, w - padding]);
 | |
| 
 | |
|     // Add your code below this line
 | |
| 
 | |
|     const yScale = undefined;
 | |
| 
 | |
| 
 | |
|     // Add your code above this line
 | |
| 
 | |
|     const output = yScale(411); // Returns 30
 | |
|     d3.select("body")
 | |
|       .append("h2")
 | |
|       .text(output)
 | |
|   </script>
 | |
| </body>
 | |
| ```
 | |
| 
 | |
| </div>
 | |
| 
 | |
| 
 | |
| 
 | |
| </section>
 | |
| 
 | |
| ## Solution
 | |
| <section id='solution'>
 | |
| 
 | |
| ```js
 | |
| // solution required
 | |
| ```
 | |
| </section>
 |