我想在文本下显示图像。我已经用 Photoshop 完成了这个,但它是一个图像。因此,每次文本更改时,我都必须在 Photoshop 中进行更改。我想使用 jQuery 或 CSS3 或任何其他网络技术来实现相同的目标。
我想要与此类似,但不是每次我的文本更改时都创建新图像
这不是按要求使用 CSS,而是使用 canvas 元素。
以下示例将通过文本剪辑图像并为其添加阴影。
这样做的结果将是:
/// set some text settings
ctx.textBaseline = 'top'; /// defaults to baseline, using top makes life simpler
ctx.font = '150px impact'; /// set the font and size we want to use
ctx.textAlign = 'center'; /// center for example
/// next draw the text
ctx.fillText(txt, demo.width * 0.5, 10);
下一步是更改合成模式,以便我们使用已经绘制的文本作为我们绘制的下一件事的剪辑:
/// change composite mode to fill text
ctx.globalCompositeOperation = 'source-in';
/// draw the image you want on top; will be clipped by text
ctx.drawImage(img, 0, 0);
现在我们绘制的图像被剪裁了。要添加阴影,我们需要多做一轮,就好像我们从一开始就添加了阴影一样,图像也会被绘制到阴影区域中。
所以我们需要做的就是将合成模式重置为默认值,设置阴影,然后将画布绘制回自身。由于它在完全相同的位置绘制在顶部,我们不会注意到。
我们在这里使用save
andrestore
来避免手动重置阴影。
/// reset composite mode to normal
ctx.globalCompositeOperation = 'source-over';
/// create a shadow by setting shadow...
ctx.save();
ctx.shadowColor = 'rgba(0,0,0,0.5)';
ctx.shadowBlur = 7;
ctx.shadowOffsetX = 3;
ctx.shadowOffsetY = 3;
/// ... and drawing it self back
ctx.drawImage(demo, 0, 0);
ctx.restore();
在演示中,我制作了一个循环来更改文本,因此您可以看到这只是提供不同文本的问题。
另请注意,背景是透明的,因此您可以将画布放在其他元素之上(在演示中,我更改了主体的背景颜色)。
我建议将演示代码重构为通用函数。为此,您可以将所有设置放入其中并移至save
开头和restore
结尾,以保留在功能之外设置的其他设置。
使用 webkit-background-clip 的解决方案 - 请注意,目前这在 Firefox 中不起作用
从这里重写HTML/CSS:“透视背景”文本?
h1, p { margin: 0; }
#container {
padding: 20px 20px 100px;
margin: 50px;
position: relative;
}
#container h1 {
/* has same bg as #container */
background: url(http://media.royalcaribbean.com/content/shared_assets/images/destinations/regions/hero/hawaii_01.jpg);
font-size: 12em;
font-family: impact;
left: 0;
line-height: 100%;
padding-top: 25px; /* padding + border of div */
position: absolute; /* position at top left of #containter to sync bg */
text-align: center;
top: 0;
width: 100%;
text-fill-color: transparent;
background-clip: text;
text-fill-color: transparent;
background-clip: text;
-webkit-text-fill-color: transparent;
-webkit-background-clip: text;
-moz-text-fill-color: transparent;
-moz-background-clip: text;
}
结合Ken - Abdias Software和mplungjan的解决方案,我决定制作一个相对跨浏览器的 CSS 解决方案,允许从数组中更改文本。
重要的 CSS(用于剪辑)
h1 {
background: white;
-moz-background-clip: padding;
-webkit-background-clip: padding;
background-clip: padding-box;
width: 100%;
max-width: 960px;
margin: 5% auto;
}
.backgroundclip h1 span {
background: url(http://i.imgur.com/TzKl9Kml.jpg) center center no-repeat;
text-align: center;
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
-moz-background-clip: text;
-moz-text-fill-color: transparent;
}
用于循环的重要 jQuery
var terms = ["This", "is", "Hawaii"];
function rotateTerm() {
var ct = $("h1 > span").data("term") || 0;
$("h1 > span").data("term", ct == terms.length -1 ? 0 : ct + 1).text(terms[ct])
.fadeIn().delay(600).fadeOut(600, rotateTerm);
}
$(rotateTerm);
对原作者的引用在 Fiddle 中。改编自那些作者。
如果文本没有改变,只需制作具有白色背景和透明文本的图像,然后使用 css 将该图像放在您的背景上,不需要 jquery。