- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Chrome 不会像 Firefox 或 IE 10 那样呈现以下 svg 示例:
<svg style="width: 500px; height:500px">
<defs>
<pattern id="pattern-stripe" width="4" height="4"
patternUnits="userSpaceOnUse" patternTransform="rotate(45)">
<rect width="2" height="4" fill="white"></rect>
</pattern>
<pattern id="pattern-stripe2" width="4" height="4"
patternUnits="userSpaceOnUse" patternTransform="rotate(45)">
<rect width="2" height="4" fill="green"></rect>
</pattern>
<mask id="mask-stripe">
<rect x="0" y="0" width="100" height="100"
fill="url(#pattern-stripe)"></rect>
</mask>
</defs>
<!-- When there is no scale, you can't see the problem. -->
<g transform="scale(4,4)">
<!-- First square:
Use mask, fill attribute is specified on the element.
-->
<rect style="mask: url('#mask-stripe'); fill: green;"
x="0" y="0" width="50" height="50"></rect>
<!-- Second square:
Use the second pattern. The fill color value need to be set on
the pattern. You can't reuse the hatch pattern with different color
-->
<rect style="fill: url(#pattern-stripe2);"
x="51" y="0" width="50" height="50" ></rect>
</g>
</svg>
第一个方 block 在 Chrome 中是模糊的,而在 Firefox 或 IE 10 中可以正确呈现。第一个方 block 很酷的一点是图案颜色可以直接在 rect
元素上由 css 控制正在使用面具。因此,如果我有很多方 block ,我可以重复使用该图案并为每个方 block 应用不同的颜色。
而在第二种情况下,您必须在图案上应用颜色,这会降低它的可重复使用性,因为您无法更改特定方 block 的背景颜色。
这是一个 jsfiddle用上面的例子。
问题:
有什么办法可以解决 Chrome 中的问题吗?
或者也许是另一种解决方案仍然在元素上使用 css 样式来控制“填充”属性?
注意事项:
我无法从 g
元素中删除 transform
属性。它在这里发挥作用:如果您在转换中删除比例,您可以使用浏览器进行缩放,并且您永远不会看到任何模糊的东西。
在我的真实场景中,我需要能够像使用 path
元素一样使用 transform
。使用 javascript 手动缩放值会太慢。
我部分解决了我的解决方案(以防它可能对其他人有帮助):
如果您有转换的最大比例值,您可以使用该最大值缩放所有数据,然后应用当前比例的倒数。那就是代替
<g transform="scale(currentscale, currentscale)"> (conceptually)
你这样做:
<g transform="scale(1/currentscale, 1/currentscale)">
最佳答案
也许以下解决方案可以满足您的需求?
首先,用另一个 <g>
围绕您的对象并在上面涂上面具。
<g mask="url(#mask-stripe)">
<g transform="scale(4,4)">
<rect style="fill: rgb(0, 128, 0);" x="0" y="0" width="50" height="50"/>
</g>
</g>
然后为您的 patternTransform
添加一个比例尺:
<pattern id="pattern-stripe" width="4" height="4" patternUnits="userSpaceOnUse"
patternTransform="scale(4,4) rotate(45)">
<rect width="2" height="4" transform="translate(0,0)" fill="white"></rect>
</pattern>
关于css - 使用蒙版时 SVG 图案模糊,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24997937/
我正在使用自定义的 uitableviewcell,并尝试重新创建一张活页纸作为背景。由于每个单元格都会根据文本量而增长,因此我需要为每个单元格的背景使用一个图案。但我对这些黑线有疑问,这让我发疯!
我已经解决这个问题 2 个小时了,似乎无法弄清楚如何按模式计数。 图案: 1-1-1 1-1-2 1-2-1 1-2-2 2-1-1 2-1-2 2-2-1 2-2-2 等等…… 最佳答案 我认为最简
我想尝试创建一个学习象棋应用程序作为学校项目。我的第一个计划是简单地让这个人工智能与自己进行较量,但要真正展示它是否成功,它需要能够展示它的进展情况。为了做到这一点,我希望它能够在 chess.com
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎偏离主题,因为它缺乏足够的信息来诊断问题。 更详细地描述您的问题或 include a mini
以下函数返回什么? (就意义而言) int f(int n){ if(n == 0) return 0; else return n % 2 + f(n / 2) } 尝试运行代码,但
我有一个专栏A3:A71我希望填充值 =COUNTIF(B3:B71,B3) 第二个参数随每个单元格递增。 显然我不想每次都复制这个函数,所以我希望填充句柄能帮助我。然而,尽管它正确地增加了 COUN
我需要重复 svg 在水平方向 . 我的意思是,svg 比图案大,所以我需要它在剩下的任何空间上水平重复。 我希望主要图案出现在中心,这正是现在正在发生的事情。我只需要让它在两边都重复。 现在,我只
我需要重复 svg 在水平方向 . 我的意思是,svg 比图案大,所以我需要它在剩下的任何空间上水平重复。 我希望主要图案出现在中心,这正是现在正在发生的事情。我只需要让它在两边都重复。 现在,我只
请帮我完成作业。我想使用循环 C 语言生成这样的模式 X X X XXX XXXXX XXX X X X XXXXX X X X X X X XXXXX X XX X X X X X
c# 3.0 为我们提供了带有编译器生成的支持字段的 getter 和 setter - 这真的很棒,但很多时候您仍然需要使用支持字段。 在一个完美的世界(意见)中,你可以做类似的事情 class M
我正在创建一个 wordpress 主题,我正在尝试创建一个导航栏,其中每个 li 都有不同的背景颜色(例如,红色,然后是绿色,然后是蓝色)。然后在使用前三种颜色后,它会再次重复使用。 例如:
是否可以将 .svg 图案作为背景图像,svg 图案应调整为窗口宽度和高度。 最佳答案 这是可能的,但浏览器支持有限。 Webkit 往往具有最好的 SVG 支持,而 IE 最差。您可以使用 CSS
如何打印反Z图案? 普通 Z 模式的代码: int main() { int n; printf("Enter number of rows: "); scanf("%d", &n); for (in
我的图片中有重复的图案。我想根据相似的模式找到相似的图像。 图案由十字形、三角形、正方形组成,它们组合在一起形成由这些“原始形状”构成的更复杂的结构。例如,想象一个由三角形或六边形等组成的十字架。 这
是否可以在 SVG 填充中模拟以下 CSS? background-image: url(/* URL */); background-position: 50%; background-size:
这个问题在这里已经有了答案: How to make SVG image pattern fill move with object? (4 个答案) 关闭 1 年前。 我创建了这里看到的 svg
问题:存在关联键的表列表。有必要为每个表实现 CRUD + 一些关于表细节的功能(分页等)。麻烦:在每个表的每个功能实现中重复了大约 50% 的代码。问题:关于语言细节、优化/重构/使用类似代码模式的
尝试绘制在 x 轴上重复的背景。然而,图像放错了位置,当我调整窗口大小时,位于图案中的 View 将开始“移动”。 我做错了什么?目前正在做以下工作: [[NSColor colorWithPatte
Javascript 问题。 关于模式或表达,可能是重复的问题。 您可以使用下面的三个来获得一个对象。结果对象的工作原理相同。 当您使用繁重的 JavaScript Web 应用程序时,哪种模式最好?
是否可以使用 CSS 创建以下效果。我在 HTML 中只有一个 H2 元素,我对页面的 HTML 没有任何控制。我只能更改 CSS。 我用 :before 和 :after 尝试过,但到目前为止没有成
我是一名优秀的程序员,十分优秀!