t-viSNE: Interactive Assessment and Interpretation of t-SNE Projections
https://doi.org/10.1109/TVCG.2020.2986996
267 lines
5.5 KiB
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)
|
|
|