这是我的React组件演示:https : //codesandbox.io/s/epic-brown-osiq1,我现在使用viewBox
的值,getBBox
并getBoundingClientRect()
实现一些计算以定位元素。目前,我已根据控制台从getBoundingClientRect()
日志中提供给我的收益输入了原始值。你可以看到,我已经实现了的元素getBoundingClientRect()
上,即的根元素和
clip-path
的text
的元素。更好,但text
更多的地方是将屏幕的中心真正对准text
框的中心,您可以看到“ So”一词位于“ Food”一词的开头,而不是对准的box
的中心。所以我目前在这一点上。
注意:您会在沙箱中看到一些评论,这些评论提供了我的部分信息或以前的试用版。
我的代码是什么?具体来说,我显示的clip-path
是带有一些动画面板的文本,这些动画面板在clip-path
-上移动- color_panel_group's element
可以使构图具有动态感。后面还带有阴影text
可以使构图更深。
期望:显示一个clip-path
的text
响应定位在垂直和水平的视口的中心。
问题:我clip-path
隐藏了的一部分,text
而我尝试将元素相对于视口居中的操作却很费劲。
我曾尝试:我曾尝试与元素的宽度和发挥x
-主要元素的位置text
,clip-path
,symbol
和这两个案例。甚至尝试use
通过在其中实现某个类来使用该元素,但最终却得到了非常近似的结果。同样,在tspan
和中,symbol
我也尝试使用x
的属性,再次取得了非常近似的结果。我尝试过使用position absolute
-主要是relative container
直接在SVG
CSS选择器上使用-仍然具有近似结果。
我想知道我缺少什么。也许有人可以对我的代码的行为做出一些解释?
这是我第二次演示的结果代码(大约是React组件生成的代码):
body {
background: orange;
}
svg {
background: green;
display: block;
margin: auto;
position: relative;
z-index: 2;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
}
.component {
min-width: 100vw;
min-height: 100vh;
font-size: 100%;
}
.fade_in_background {
opacity: 1;
visibility: visible;
transition: all 1.5s ease-out 0s;
}
.brandtype {
margin: auto;
text-align: center;
}
.brandtype_use {
position: absolute;
transform: translate(-112.65px, 0)
}
.clipPath_text {
text-align: center;
}
.color_panel_group {
padding: 25px;
}
.shape_animation {
transform-origin: 0;
transform: scale(0, 1) translate(0, 0);
animation: moving-panel 3s 1.5s 1 alternate forwards;
}
.shadow {
transform: translate(10px, 10px)
}
.shape_animation_shadow {
fill: black;
fill-opacity: .505;
transition: all 1.3s ease-out 0.3s;
}
.brandtype {
font-size: 6.8em;
}
@keyframes moving-panel {
to {
transform: scale(1, 1) translate(20px, 0);
}
}
感谢您的任何提示。
SVG中的文本对齐方式无法像从HTML和CSS那样习惯,在HTML和CSS中,所有内容都是具有一定尺寸的框,我们可以应用例如text-align: center
。
在
起始坐标中定义文本行将从其开始扩展的点。
text-anchor
属性控制着展开的方向:center
value表示它将双向展开,因此初始锚点将位于边界框宽度的中间(对于水平书写系统)。请参阅出色的答案以说明这text-anchor
是将文本居中SVG的最佳方法:https : //stackoverflow.com/a/23272367/540955。而且,SVG内没有CSS位置属性(左/上),只有x / y坐标,也没有空白和余量,就像您在HTML中所知道的那样。
因此,在代码中添加坐标并向右text-anchor="middle"
移动x
将产生居中文本。我建议使用裸
元素而不是
s,因为用dx
/ dy
相对于最后一个前一个字符移动它们,并且该字符可能与父级之间有一些空格
(取决于代码格式),这会导致不平衡的居中。对于更简单的计算(或仅用于水平书写系统),它也很有用,因为它将锚点从基线移到“中心线”。因此,使用属性(如您已经做的那样)将行高的第一行“一半”上移,另一行下移应该可以解决问题:dominant-baseline
="central"
middle
dy