- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在下面的代码中,如果我使用 rect()
然后使用 fill()
,第二个 fillStyle
会覆盖第一个中指定的颜色在这两个地方(即,两个矩形都是绿色),但如果我将第一个 rect()
更改为 fillRect() ,则按预期工作(即,第一个矩形为蓝色,第二个矩形为绿色)
。为什么会这样呢?我以为 fillRect()
只是 rect()
然后是 fill()
,对吗?
ctx.translate(canvas.width/2, canvas.height/2);
ctx.fillStyle = "#5A9BDC";
ctx.fillRect(0, 0, rectWidth, rectHeight);
// ctx.rect(0, 0, rectWidth, rectHeight);
// ctx.fill();
ctx.translate(-canvas.width/2, -canvas.height/2);
ctx.fillStyle = "#31B131";
ctx.rect(0, 0, rectWidth, rectHeight);
ctx.fill();
在 Chrome 中测试 | Fiddle
最佳答案
填充矩形
.fillRect 是一个“独立”命令,用于绘制和填充矩形。
因此,如果您使用多个 .fillStyle 命令发出多个 .fillRect 命令,则每个新矩形都将使用前面的 fillstyle 进行填充。
ctx.fillStyle="red";
ctx.fillRect(10,10,10,10); // filled with red
ctx.fillStyle="green";
ctx.fillRect(20,20,10,10); // filled with green
ctx.fillStyle="blue";
ctx.fillRect(30,30,10,10); // filled with blue
正确
.rect 是 Canvas 路径命令的一部分。
路径命令是绘图组,从 beginPath() 开始,一直持续到发出另一个 beginPath() 为止。
在每个组中,只有最后一个样式命令获胜。
因此,如果您在路径内发出多个 .rect 命令和多个 .fillStyle 命令,则只有最后一个 .fillStyle 将用于所有 .rect。
ctx.beginPath(); // path commands must begin with beginPath
ctx.fillStyle="red";
ctx.rect(10,10,10,10); // blue
ctx.fillStyle="green";
ctx.rect(20,20,10,10); // blue
ctx.fillStyle="blue"; // this is the last fillStyle, so it "wins"
ctx.rect(30,30,10,10); // blue
// only 1 fillStyle is allowed per beginPath, so the last blue style fills all
ctx.fill()
关于javascript - HTML5 Canvas - fillRect() 与 rect(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22559603/
为什么会这样: var rows = 80 var cols = 120 var tw = 5 for(var i = 0; i < rows; i++){ for(var j = 0; j
为什么 context.fillRect(10, 10, 20, 20) 填充了一个矩形,但是当使用像player.x或player.y这样的变量时,它不起作用? 如果我在JavaScript控制台中
这是我使用 AWT/Swing 的第一个项目。我正在尝试设计一个简单的元胞自动机。我在选择布局管理器时遇到了一些问题,现在我使用 GridLayout 因为它是最接近我想要的。但是,当尝试在 JPan
可疑的 fillRect() 速度 好吧,让我直截了本地说。 Java 通过遍历数组并将 rgb 值更改为指定颜色来填充矩形。如果它所做的只是改变颜色,那么如果它所做的只是改变数组中的整数,为什么 T
我在屏幕上绘制矩形时遇到问题。我的 jpanel 类中有 paintComponent 方法,我想在其中绘制一个矩形。它看起来像这样: public void paintComponent( Grap
我想为我创建的游戏制作背景。我在使用 fillRect 时遇到了一些问题。getHeight 和 getWidth 是否必须按特定顺序排列,还是应该使用 getX/Y/Height/Width? pr
在我的代码中: void Surface::paintBorders(const Color& color, int borderWidth){ HBRUSH colorBrush = CreateS
我有一个带有 iframe 的网页,并且在该 iframe 中有一个带有 id="canvas"的 Canvas ,当我在整个 Canvas 的上下文中调用(从 iframe 中的 .js 文件)fi
我正在使用 canvas fillrect 函数绘制多个矩形。我现在正在对坐标进行硬编码,但是是否可以像对函数的函数调用一样将它们传递给填充矩形?例如,如果我有 10 组坐标,我可以使用 for 循环
我使用负数让 fillRect() 走相反的路。它在我的电脑上运行良好,但我的 friend 看不到它正常运行。我该怎么办? page.fillRect (12, 12, -5, 10); 最佳答案
我正在使用 JavaScript 开发一个资源监视器,并假装用一个很酷的背景动画来完成它。 我在 fillStyle 中使用 fillRect 和透明颜色时遇到问题,例如: funct
我正在使用 fillRect 在 Canvas 上绘制矩形。我想添加文本,我希望它像编辑框一样可编辑。有没有办法在 JavaScript 中实现这一点? 我不需要 fillText,因为我希望文本在
我正在用 Java 编写一个关于躲避橙色红色方 block 并单击它们将其删除的游戏。但是,我需要弄清楚如何编写代码来在首先单击 fillRect 时执行操作,如果这是不可能的,那么至少有一种方法可以
当我使用它时,唯一填充的是一个白色 矩形,与参数无关。这就是我所做的: var map:Bitmap = new Bitmap (new BitmapData(200,200)) map.bitmap
我喜欢制作直方图。使用drawLine(),这对我来说并不是真正的问题,但是当我尝试使用fillRect()时,矩形会从上到下移动。我想用drawLine()绘制看起来与我的直方图相似的直方图。 这是
我正在尝试使用 Java 中的 fillRect 方法用图像填充矩形。有没有办法使用 fillRect 方法来做到这一点? 这是我正在编写的代码: private int x = 0;
嗨,我目前正在开发一个 Java 应用程序,我必须使用 Canvas、Graphics 等进行一些绘制。 因此,如果我单击一个点并将其拖过,它之间应该画一条线(想想在油漆中画一条线)。 我目前正在使用
Java 新手,遇到了一些让我摸不着头脑的事情。我正在尝试制作一个具有黑色背景的 GUI,可以在其上绘制线条来模拟一组 7 段显示器。另外,我还会有一系列的Jbuttons。我遇到的问题是我可以做其中
我有这个非常简单的代码: private static final int SKY_COLOR = Color.rgb(161, 210, 241); private static final int
我正在执行一项任务,其中涉及使用 x/y 坐标在 500px*500px JFrame 上的某些位置绘制内容。我可以让程序绘制一个位置,但是它完全忽略通过扫描仪从输入文件接收到的信息,只是在左上角绘制
我是一名优秀的程序员,十分优秀!