爲什麼下面的代碼不會產生三行,都具有相似的漸變?HTML5畫布:漸變和strokeStyle讓我感到困惑
<html>
<body style="background: black;">
<canvas id="Test" width="516" height="404"> </canvas>
<script>
var ctx = document.getElementById('Test').getContext('2d');
ctx.lineWidth = 8;
function addColorStops(gradient) {
gradient.addColorStop(0.5, 'rgba(151, 165, 193, 0.5)');
gradient.addColorStop(1, 'rgba(151, 165, 193, 1)');
}
function drawLine(x1, x2, y) {
var g = ctx.createLinearGradient(x1, y, x2, y);
addColorStops(g);
ctx.strokeStyle = g;
ctx.moveTo(x1, y);
ctx.lineTo(x2, y);
ctx.stroke();
}
drawLine(10, 100, 10);
drawLine(10, 100, 30);
drawLine(10, 100, 50);
</script>
</body>
</html>
代替第一線得到一個非常非常輕微的坡度,第二行得到了相當不錯的梯度,最後得到了大幅度的梯度。
我想從任如何參數createLinearGradient
都應該工作,或者誤解strokeStyle
分配如何影響未來招...