首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何将梯度的底部锚定到它填充的HTML5画布中的容器上?

如何将梯度的底部锚定到它填充的HTML5画布中的容器上?
EN

Stack Overflow用户
提问于 2014-12-31 21:51:42
回答 1查看 90关注 0票数 2

我正试图在画布的一半上画一个渐变,这样渐变就覆盖了上半部分。

问题是,我无法弄清楚如何使梯度与“容器”(由fillRect()控制的形状)排列--当我将容器推到适当的位置时,梯度将固定在画布的底部,而不是它正在填充的容器的底部。

渐变的底部应该从它填充的容器的底部开始,而不是画布的底部。我怎样才能做到这一点?

代码语言:javascript
运行
复制
//not sliding gradient container upward
function paintC1() {
  var canvas = document.getElementById('canvas-1');
  var context = canvas.getContext('2d');
  var height = canvas.height;
  var width = canvas.width;
  var grd = context.createLinearGradient(width, 0, width, height);
  grd.addColorStop(0.5, 'rgba(0,174,239,0)');
  grd.addColorStop(0.85, 'rgba(0,174,239,0.6)');
  grd.addColorStop(1, 'rgba(0,174,239,1)');
  context.fillStyle = grd;
  context.fillRect(0, 0, width, height);
}

/* for comparison */

//sliding gradient container up
function paintC2() {
  var canvas = document.getElementById('canvas-2');
  var context = canvas.getContext('2d');
  var height = canvas.height;
  var width = canvas.width;
  var grd = context.createLinearGradient(width, 0, width, height);
  grd.addColorStop(0.5, 'rgba(0,174,239,0)');
  grd.addColorStop(0.85, 'rgba(0,174,239,0.6)');
  grd.addColorStop(1, 'rgba(0,174,239,1)');
  context.fillStyle = grd;
  context.fillRect(0, -50, width, height);
}

paintC1();
paintC2();
代码语言:javascript
运行
复制
<canvas id="canvas-1" style="width:250px; height:500; border-style:solid; float:left; margin-right:10px;"></canvas>

<canvas id="canvas-2" style="width:250px; height:500; border-style:solid; float:left; margin-right:10px;"></canvas>

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-01-01 11:12:48

渐变填充相对于画布,而不是元素,因此要完成任务,您应该这样做。

代码语言:javascript
运行
复制
 var grd = context.createLinearGradient(width, -50, width, height -50);

否则,您必须翻译上下文:

代码语言:javascript
运行
复制
var canvas = document.getElementById('c');
var context = canvas.getContext('2d');
var gradient = context.createLinearGradient(0, 0, 0, 30);
var sampleW = 100;
var sampleH = 30;
gradient.addColorStop(0.5, 'rgba(0,174,239,0)');
gradient.addColorStop(0.85, 'rgba(0,174,239,0.6)');
gradient.addColorStop(1, 'rgba(0,174,239,1)');

var translations= [[30, 150],[100, 110],[170, 70],[240, 30]];

context.font = '12px verdana bold';
for (var i = 0; i < translations.length; i++) {
  var t= translations[i];
  context.save();
  // gradient is defined at the origin,
  // so we have to move the origin
  context.translate(t[0], t[1])
  context.fillStyle = gradient;
  context.fillRect(0, 0, sampleW, sampleH);
  context.strokeRect(0, 0, sampleW, sampleH);
 
  context.restore();
}
代码语言:javascript
运行
复制
<canvas id="c" width="500" height="500"></canvas>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27726631

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档