t-viSNE: Interactive Assessment and Interpretation of t-SNE Projections https://doi.org/10.1109/TVCG.2020.2986996
 
 
 
 
 
t-viSNE/modules/d3-legend/docs/legends.js

267 lines
5.5 KiB

//Color: Quantile #svg-color-quant
var svg = d3.select("#svg-color-quant")
var quantize = d3
.scaleQuantize()
.domain([0, 0.15])
.range(
d3.range(9).map(function(i) {
return "q" + i + "-9"
})
)
svg
.append("g")
.attr("class", "legendQuant")
.attr("transform", "translate(20,20)")
var legend = d3
.legendColor()
.labelFormat(d3.format(".2f"))
.useClass(true)
.title("A really really really really really long title")
.titleWidth(100)
.scale(quantize)
svg.select(".legendQuant").call(legend)
//Color: Treshold #svg-color-threshold
var svg = d3.select("#svg-color-threshold")
var thresholdScale = d3
.scaleThreshold()
.domain([0, 1000, 2500, 5000, 10000])
.range(
d3.range(6).map(function(i) {
return "q" + i + "-9"
})
)
svg
.append("g")
.attr("class", "legendThreshold")
.attr("transform", "translate(20,20)")
var legend = d3
.legendColor()
.labelFormat(d3.format(".2f"))
.labels(d3.legendHelpers.thresholdLabels)
.useClass(true)
.shapeWidth(30)
.scale(thresholdScale)
svg.select(".legendThreshold").call(legend)
//Color: Log #svg-color-log
var svg = d3.select("#svg-color-log")
var log = d3
.scaleLog()
.domain([0.1, 100, 1000])
.range(["rgb(46, 73, 123)", "rgb(71, 187, 94)"])
svg
.append("g")
.attr("class", "legendLog")
.attr("transform", "translate(20,20)")
var logLegend = d3
.legendColor()
.cells([0.1, 5, 10, 50, 100, 500, 1000])
.scale(log)
svg.select(".legendLog").call(logLegend)
//Color Linear #svg-color-linear
var linear = d3
.scaleLinear()
.domain([0, 10])
.range(["rgb(46, 73, 123)", "rgb(71, 187, 94)"])
svg = d3.select("#svg-color-linear")
svg
.append("g")
.attr("class", "legendLinear")
.attr("transform", "translate(20,20)")
var legendLinear = d3
.legendColor()
.shapeWidth(30)
.orient("horizontal")
.scale(linear)
//Color Linear #svg-color-linear-10
svg.select(".legendLinear").call(legendLinear)
svg = d3.select("#svg-color-linear-10")
svg
.append("g")
.attr("class", "legendLinear")
.attr("transform", "translate(20,20)")
legendLinear.cells(10)
svg.select(".legendLinear").call(legendLinear)
//Linear #svg-color-linear-custom
svg.select(".legendLinear").call(legendLinear)
svg = d3.select("#svg-color-linear-custom")
svg
.append("g")
.attr("class", "legendLinear")
.attr("transform", "translate(20,20)")
legendLinear.cells([1, 2, 3, 6, 8])
svg.select(".legendLinear").call(legendLinear)
//Ordinal #svg-color-ordinal
var ordinal = d3
.scaleOrdinal()
.domain(["a", "b", "c", "d", "e"])
.range([
"rgb(153, 107, 195)",
"rgb(56, 106, 197)",
"rgb(93, 199, 76)",
"rgb(223, 199, 31)",
"rgb(234, 118, 47)"
])
svg = d3.select("#svg-color-ordinal")
svg
.append("g")
.attr("class", "legendOrdinal")
.attr("transform", "translate(20,20)")
var legendOrdinal = d3
.legendColor()
.shape(
"path",
d3
.symbol()
.type(d3.symbolTriangle)
.size(150)()
)
.shapePadding(10)
.cellFilter(function(d) {
return d.label !== "e"
})
.scale(ordinal)
svg.select(".legendOrdinal").call(legendOrdinal)
var sequentialScale = d3.scaleSequential(d3.interpolateRainbow).domain([0, 10])
svg = d3.select("#svg-color-sequential")
svg
.append("g")
.attr("class", "legendSequential")
.attr("transform", "translate(20,20)")
var legendSequential = d3
.legendColor()
.shapeWidth(30)
.cells(10)
.orient("horizontal")
.scale(sequentialScale)
svg.select(".legendSequential").call(legendSequential)
//Size: Linear Circle #svg-size-linear
var linearSize = d3
.scaleLinear()
.domain([0, 10])
.range([10, 30])
svg = d3.select("#svg-size-linear")
svg
.append("g")
.attr("class", "legendSize")
.attr("transform", "translate(20, 40)")
var legendSize = d3
.legendSize()
.scale(linearSize)
.shape("circle")
.shapePadding(15)
.labelOffset(20)
.orient("horizontal")
.on("cellover", function() {
console.log("cellover", d3.event, d3.event.type)
})
svg.select(".legendSize").call(legendSize)
//Size: Linear Line #svg-size-line
var lineSize = d3
.scaleLinear()
.domain([0, 10])
.range([2, 10])
svg = d3.select("#svg-size-line")
svg
.append("g")
.attr("class", "legendSizeLine")
.attr("transform", "translate(0, 20)")
var legendSizeLine = d3
.legendSize()
.scale(lineSize)
.shape("line")
.orient("horizontal")
.labels([
"tiny testing at the beginning",
"small",
"medium",
"large",
"grand, all the way long label"
])
.labelWrap(30)
.shapeWidth(50)
.labelAlign("start")
.shapePadding(10)
svg.select(".legendSizeLine").call(legendSizeLine)
//Symbol: Ordinal #svg-symbol-ordinal
svg = d3.select("#svg-symbol-ordinal")
svg
.append("g")
.attr("class", "legendSymbol")
.attr("transform", "translate(20, 20)")
var triangleU = d3.symbol().type(d3.symbolTriangle)(),
circle = d3.symbol().type(d3.symbolCircle)(),
cross = d3.symbol().type(d3.symbolCross)(),
diamond = d3.symbol().type(d3.symbolDiamond)(),
star = d3.symbol().type(d3.symbolStar)()
//example output of d3.svg.symbol().type('circle')();
//"M0,4.51351666838205A4.51351666838205,4.51351666838205 0 1,1 0,
//-4.51351666838205A4.51351666838205,4.51351666838205 0 1,1 0,4.51351666838205Z"
var symbolScale = d3
.scaleOrdinal()
.domain(["a longer label", "b", "c", "d", "e"])
.range([triangleU, circle, cross, diamond, star])
var legendPath = d3
.legendSymbol()
.scale(symbolScale)
//.orient("horizontal")
.labelWrap(30)
.title("Symbol Legend Title")
.on("cellclick", function(d) {
alert("clicked " + d)
})
svg.select(".legendSymbol").call(legendPath)