Pokemon Form
In the previous page, the selection of which attributes to visualize were hard coded. Let's make our viz more interactive and flexible by providing forms for users to select which attributes to visualize dynamically.
Menu
One attribute
Attribute (e.g., Attack):
Comparing two attributes
Attribute 1:
Attribute 2:
One attribute with sorting
Attribute:
Three attributes
Width 1:
Width 2:
Color:
Viz
Data is not loaded yet
// pokemonData is a global variable
pokemonData = 'not loaded yet'
$.get('/data/pokemon-small.json')
.success(function(data){
console.log('data loaded', data)
// TODO: show in the myviz that the data is loaded
pokemonData = data
})
function vizAsHorizontalBars(attributeName){
// TODO: modify this function to visualize the data as horizontal
// bars to compare attack points
// define a template string
var tplString = '<g transform="translate(0 ${d.y})"> \
<rect \
width="${d.width}" \
height="20" \
style="fill:${d.color}; \
stroke-width:3; \
stroke:rgb(0,0,0)" /> \
</g>'
// compile the string to get a template function
var template = _.template(tplString)
function computeX(d, i) {
return 0
}
function computeWidth(d, i) {
return d[attributeName]
}
function computeY(d, i) {
return i * 20
}
function computeColor(d, i) {
return 'red'
}
var viz = _.map(pokemonData, function(d, i){
return {
x: computeX(d, i),
y: computeY(d, i),
width: computeWidth(d, i),
color: computeColor(d, i)
}
})
console.log('viz', viz)
var result = _.map(viz, function(d){
// invoke the compiled template function on each viz data
return template({d: d})
})
console.log('result', result)
$('.myviz').html('<svg>' + result + '</svg>')
}
$('button#viz-horizontal').click(function(){
var attributeName = $('input#pokemon-attribute-name').val()
vizAsHorizontalBars(attributeName)
})
// TODO: complete the code below
function vizSideBySide(attributeName1, attributeName2){
var tplString = '<g transform="translate(120 ${d.y})"> \
<rect \
x="-${d.width}" \
width="${d.width}" \
height="20" \
style="fill:${d.color}; \
stroke-width:1; \
stroke:rgb(0,0,0)" /> \
<rect \
x="0" \
width="${d.height}" \
height="20" \
style="fill:blue; \
stroke-width:1; \
stroke:rgb(0,0,0)" /> \
<text transform="translate(0 15)">${d.name} </text> \
</g>'
// compile the string to get a template function
var template = _.template(tplString)
function computeX(d, i) {
return i * 20
}
function computeWidth(d, i) {
return d[attributeName1]
}
function computeY(d, i) {
return i * 20
}
function computeColor(d, i) {
return 'red'
}
function computeName(d, i) {
return d.Name
}
function computeHeight(d, i) {
return d[attributeName2]
}
var viz = _.map(pokemonData, function(d, i){
return {
x: computeX(d, i),
y: computeY(d, i),
width: computeWidth(d, i),
color: computeColor(d, i),
name: computeName(d,i),
height:computeHeight(d,i)
}
})
console.log('viz', viz)
var result = _.map(viz, function(d){
// invoke the compiled template function on each viz data
return template({d: d})
})
console.log('result', result)
$('.myviz').html('<svg>' + result + '</svg>')
}
$('button#viz-compare').click(function(){
var attributeName1 = $('input#pokemon-attribute-name-1').val()
var attributeName2 = $('input#pokemon-attribute-name-2').val()
vizSideBySide(attributeName1, attributeName2)
})
// TODO: complete the code below
function vizAsSortedHorizontalBars(attributeName, sortDirection){
var tplString = '<g transform="translate(0 ${d.y})"> \
<rect \
width="${d.width}" \
height="20" \
style="fill:${d.color}; \
stroke-width:3; \
stroke:rgb(0,0,0)" /> \
<text transform="translate(0 15)">${d.name} </text> \
</g>'
// compile the string to get a template function
var template = _.template(tplString)
function computeX(d, i) {
return 0
}
function computeWidth(d, i) {
return d[attributeName]
}
function computeY(d, i) {
return i * 20
}
function computeColor(d, i) {
return 'red'
}
function computeName(d, i) {
return d.Name
}
if(sortDirection=="asc")
pokemonData=_.sortBy(pokemonData,attributeName)
else
pokemonData=_.sortBy(pokemonData,attributeName).reverse()
var viz = _.map(pokemonData, function(d, i){
return {
x: computeX(d, i),
y: computeY(d, i),
width: computeWidth(d, i),
color: computeColor(d, i),
name: computeName(d,i)
}
})
console.log('viz', viz)
var result = _.map(viz, function(d){
// invoke the compiled template function on each viz data
return template({d: d})
})
console.log('result', result)
$('.myviz').html('<svg>' + result + '</svg>')
}
$('button#viz-horizontal-sorted-asc').click(function(){
var sortDirection = 'asc'
var attributeName = $('input#pokemon-sorted-attribute-name').val()
vizAsSortedHorizontalBars(attributeName, sortDirection)
})
$('button#viz-horizontal-sorted-desc').click(function(){
var sortDirection = "desc"
var attributeName = $('input#pokemon-sorted-attribute-name').val()
vizAsSortedHorizontalBars(attributeName, sortDirection)
})
// TODO: complete the code below
// visualize three attributes, the first two attributes as side-by-side bar charts
// using bar widths to represent attribute values, and the third attribute's value
// is represented using the red color brightness
function vizThreeAttributes(attributeName1, attributeName2, attributeName3){
var tplString = '<g transform="translate(120 ${d.y})"> \
<rect \
x="-${d.width}" \
width="${d.width}" \
height="20" \
style="fill:${d.color}; \
stroke-width:1; \
stroke:rgb(0,0,0)" /> \
<rect \
x="0" \
width="${d.height}" \
height="20" \
style="fill:${d.color}; \
stroke-width:1; \
stroke:rgb(0,0,0)" /> \
<text transform="translate(0 15)">${d.name} </text> \
</g>'
// compile the string to get a template function
var template = _.template(tplString)
function computeX(d, i) {
return i * 20
}
function computeWidth(d, i) {
return d[attributeName1]
}
function computeY(d, i) {
return i * 20
}
function computeColor(d, i) {
return attributeName3
}
function computeName(d, i) {
return d.Name
}
function computeHeight(d, i) {
return d[attributeName2]
}
var viz = _.map(pokemonData, function(d, i){
return {
x: computeX(d, i),
y: computeY(d, i),
width: computeWidth(d, i),
color: computeColor(d, i),
name: computeName(d,i),
height:computeHeight(d,i)
}
})
console.log('viz', viz)
var result = _.map(viz, function(d){
// invoke the compiled template function on each viz data
return template({d: d})
})
console.log('result', result)
$('.myviz').html('<svg>' + result + '</svg>')
}
$('button#viz-three').click(function(){
var attributeName1 = $('input#pokemon-three-width1').val()
var attributeName2 = $('input#pokemon-three-width2').val()
var attributeName3 = $('input#pokemon-three-color').val()
vizThreeAttributes(attributeName1, attributeName2, attributeName3)
})