我正在使用一个 SVG 元素,其中我使用该元素实现了带有曲线文本的字幕效果<textpath>
。目前,我使用 🌟 表情符号作为字幕文本的一部分,但我想用自定义 SVG 图像替换此表情符号并围绕其轴旋转图像。
我遇到的问题是,当我用自定义图像(通过标签<img>
或内联 SVG)替换表情符号时,图像不会出现,文本只会显示出来。此外,我想将自定义类应用于此图像以进行样式设置(例如,旋转它)。但是,每当我尝试将类添加到表情符号时,它就会消失。
我尝试过的:
<img>
使用引用自定义 SVG 图像或内联 SVG 元素的内联标签替换表情符号。
应用自定义 CSS 类.rotate-image
来旋转图像。
预期结果:
自定义 SVG 图像应该出现在选框路径中,而不是🌟表情符号。
应使用自定义类(例如.rotate-image
)来设置图像的旋转样式。
图像应使用定义的 CSS 动画平滑旋转。
问题:
替换表情符号时自定义图片不显示。只显示文本,不显示图片。
如果我尝试插入自定义图像或使用内联 HTML 元素,图像就会消失,只留下文本。
有人可以建议解决方案或提供指导,告诉我如何成功地用自定义 SVG 图像替换表情符号<textpath>
,并应用自定义 CSS 类进行旋转和样式设置?
这是我目前正在使用的代码:
function startMarquee(id, pathId, content, speed) {
const textPath = document.getElementById(id);
const path = document.getElementById(pathId);
const pathLength = path.getTotalLength();
textPath.innerHTML = content;
let offset = 0;
function animateText() {
offset = (offset + speed) % pathLength;
textPath.setAttribute('startOffset', `${offset}px`);
requestAnimationFrame(animateText);
}
requestAnimationFrame(animateText);
}
document.addEventListener('DOMContentLoaded', () => {
const textContent = "Web Design 🌟 Web Development 🌟 UI/UX Design 🌟 Front-end Development 🌟 HTML & CSS 🌟 JavaScript 🌟 Responsive Design 🌟 E-Commerce Solutions 🌟 SEO Optimization 🌟 Digital Marketing 🌟 Web Hosting 🌟 Content Management 🌟 Website Performance 🌟 Website Maintenance 🌟 Branding 🌟 User-Centered Design 🌟 Cross-Browser Compatibility 🌟 Website Security 🌟 Mobile Optimization 🌟 Conversion Rate Optimization 🌟 Site Speed Optimization";
startMarquee('marquee-text-curved', 'text-path-curved', textContent, 2);
});
body {
background-color: #0d0d0d;
padding: 0;
margin: 0;
}
.elementor-svg-marquee {
width: 100% !important;
height: 100vh !important;
display: block;
margin: 0 auto;
padding: 0 !important;
overflow: hidden;
}
.uppercase-text-curved {
fill: #FFFFFF;
font-size: 2rem !important;
}
text {
font-size: 2rem !important;
}
/* Outer border for the stroke */
.curved-path-border {
stroke-width: 6.1rem;
/* Simulates the border */
stroke: #2fb7d9;
/* Border color */
fill: none;
filter: drop-shadow(0px 0px 5px #2fb7d9);
}
/* Actual stroke */
.curved-path {
stroke-width: 6rem;
/* Slightly smaller than the border */
stroke: black;
/* Stroke color */
fill: none;
}
@media (max-width: 768px) {
text {
font-size: 4rem !important;
}
.curved-path-border {
stroke-width: 8.1rem;
}
.curved-path {
stroke-width: 8rem;
}
}
@media (max-width: 480px) {
text {
font-size: 2rem !important;
}
.curved-path-border {
stroke-width: 6.1rem;
}
.curved-path {
stroke-width: 6rem;
}
}
<div>
<svg class="elementor-svg-marquee" viewbox="-50 0 1300 300" xmlns="http://www.w3.org/2000/svg">
<defs>
<path
id="text-path-curved"
d="M -100 150 Q 200 -50, 400 150 Q 600 350, 800 150 Q 1000 -50, 1300 150"
/>
</defs>
<!-- Simulated border -->
<path
class="curved-path-border"
d="M -100 150 Q 200 -50, 400 150 Q 600 350, 800 150 Q 1000 -50, 1300 150"
/>
<!-- Actual stroke -->
<path
class="curved-path"
d="M -100 150 Q 200 -50, 400 150 Q 600 350, 800 150 Q 1000 -50, 1300 150"
/>
<!-- Scrolling text -->
<text
font-family="Rubik, sans-serif"
class="uppercase-text-curved"
text-anchor="middle"
dominant-baseline="middle"
>
<textpath id="marquee-text-curved" href="#text-path-curved"></textpath>
</text>
</svg>
</div>
<img>
和都不是<svg>
的允许<textpath>
内容。您可以通过构建自己的字体来找到部分解决方案。
@font-face
样式规则,建立font-family
字体文件的名称和引用。<tspan></tspan>
(允许的内容<textpath>
)<tspan></tspan>
标签之间,可能使用字符代码的转义序列。textpath > tspan
您的font-family
姓名的样式规则。即使没有任何动画旋转,这至少会对表情符号进行改进。
我的研究使我相信,虽然SVG 通常支持动画,但它不能应用于
<tspan>
元素。