Merge branch 'master' into aliabd/saliency

This commit is contained in:
Abubakar Abid 2019-07-25 23:46:23 -07:00 committed by GitHub
commit f73e0d385f
3 changed files with 22 additions and 3 deletions

View File

@ -45,7 +45,7 @@
.saliency_holder {
position: absolute;
top: 0;
opacity: 0.7;
opacity: 0.9;
}
.view_holders canvas {
background-color: white;

View File

@ -16,7 +16,7 @@ const textbox_input = {
let text = this.target.find(".input_text").val();
let index = 0;
data.forEach(function(value, index) {
html += `<span style='background-color:rgba(0,100,255,${value})'>${text.charAt(index)}</span>`;
html += `<span style='background-color:rgba(75,150,255,${value})'>${text.charAt(index)}</span>`;
})
$(".input_text_saliency").html(html);
},

View File

@ -44,13 +44,32 @@ function paintSaliency(data, width, height, ctx) {
var cell_width = width / data[0].length
var cell_height = height / data.length
var r = 0
let blue = [75, 150, 255];
let white = [255, 255, 255];
data.forEach(function(row) {
var c = 0
row.forEach(function(cell) {
ctx.fillStyle = `rgba(${(1 - cell) * 255},${(1 - cell) * 255},255,0.5)`;
let shade = interpolate(cell, blue, white)
ctx.fillStyle = colorToString(shade);
ctx.fillRect(c * cell_width, r * cell_height, cell_width, cell_height);
c++;
})
r++;
})
}
// val should be in the range [0.0, 1.0]
// rgb1 and rgb2 should be an array of 3 values each in the range [0, 255]
function interpolate(val, rgb1, rgb2) {
var rgb = [0,0,0];
var i;
for (i = 0; i < 3; i++) {
rgb[i] = rgb1[i] * (1.0 - val) + rgb2[i] * val;
}
return rgb;
}
// quick helper function to convert the array into something we can use for css
function colorToString(rgb) {
return "rgb(" + rgb[0] + ", " + rgb[1] + ", " + rgb[2] + ")";
}