内容に基づいてセルに色を付けたいのですが。0
=赤、100
=緑、線形補間。
function LinInt(x){
var ss = SpreadsheetApp.getActiveSheet();
var cell = ss.getActiveRange();
var hue;
hue = (x/100)*120;
var color = HSVtoRGB(hue, 40, 100);
cell.setBackground(color);
return x;
}
function HSVtoRGB(h, s, v) {
var r, g, b, i, f, p, q, t;
if (h && s === undefined && v === undefined) {
s = h.s, v = h.v, h = h.h;
}
i = Math.floor(h * 6);
f = h * 6 - i;
p = v * (1 - s);
q = v * (1 - f * s);
t = v * (1 - (1 - f) * s);
switch (i % 6) {
case 0: r = v, g = t, b = p; break;
case 1: r = q, g = v, b = p; break;
case 2: r = p, g = v, b = t; break;
case 3: r = p, g = q, b = v; break;
case 4: r = t, g = p, b = v; break;
case 5: r = v, g = p, b = q; break;
}
return '#'+((b | g << 8 | r << 16) / 0x1000000).toString(16).substring(2);
}
これを行うと、電話をかけることができないというエラーが表示されますsetBackground
。これは、関数が実行されている現在のセルを取得するのに失敗しているため、あるセルの色を別のセルから変更することが許可されていないためだと思います。
関数を呼び出すことができるように、関数が実行されているセルを取得するにはどうすればよいsetBackground()
ですか?
たとえば、=LinInt(50)
セルに入力しA1
、A1
黄色で50の数字を入力したいとします。次に、=LinInt(100)
セルに入力するA2
と、緑色で100の数字が表示されます。