- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我找到了这个 CSS3 3D 动画:Animation ;我正在尝试复制它:Replica ;但正如您所看到的,我的动画跳跃时并不流畅。
我的 HTML 看起来像这样:
<div class="pole-container">
<div class="pole">
<div class="stripes-wrapper">
<span class="stripe-01"></span>
<span class="stripe-02"></span>
<span class="stripe-03"></span>
<span class="stripe-04"></span>
<span class="stripe-05"></span>
<span class="stripe-06"></span>
<span class="stripe-07"></span>
<span class="stripe-08"></span>
<span class="stripe-09"></span>
<span class="stripe-10"></span>
<span class="stripe-11"></span>
<span class="stripe-12"></span>
</div>
</div>
</div>
还有 CSS:
.preloader-container {
position: absolute;
top: 0px;
right: 0px;
bottom: 0px;
left: 0px;
background: #FFFFFF;
z-index: 5;
opacity: 1;
-webkit-transition: all 500ms ease-out;
-moz-transition: all 500ms ease-out;
-o-transition: all 500ms ease-out;
transition: all 500ms ease-out;
}
.preloader-container.hidden {
display: block !important;
visibility: visible;
opacity: 0;
z-index: 0;
pointer-events: none;
}
.pole-container {
position: absolute;
top: 50%;
left: 50%;
margin-top: -100px;
margin-left: -20px;
white-space: nowrap;
overflow: hidden;
-webkit-transform: rotate(-90deg);
-moz-transform: rotateX902deg);
-ms-transform: rotate(-90deg);
-o-transform: rotate(-90deg);
transform: rotate(-90deg);
}
.pole-container::after {
position: absolute;
display: block;
content: "";
}
.stripes-wrapper {
white-space: nowrap;
-webkit-animation: WEBKIT-BP .5s linear infinite;
-moz-animation: MOZ-BP .5s linear infinite;
-ms-animation: MS-BP .5s linear infinite;
-o-animation: O-BP .5s linear infinite;
animation: BP .5s linear infinite;
}
.stripes-wrapper span {
margin: 0;
display: inline-block;
margin-left: 10px;
width: 10px;
height: 40px;
background: #9FCBDA;
-webkit-transform: skew(32deg);
-moz-transform: skewX(32deg);
-ms-transform: skew(32deg);
-o-transform: skew(32deg);
transform: skew(32deg);
}
谁能指出我的动画不以相同方式运行的原因,我将不胜感激?
最佳答案
这是你的答案:
.preloader-container {
position: absolute;
top: 0px;
right: 0px;
bottom: 0px;
left: 0px;
background: #FFFFFF;
z-index: 5;
opacity: 1;
-webkit-transition: all 500ms ease-out;
-moz-transition: all 500ms ease-out;
-o-transition: all 500ms ease-out;
transition: all 500ms ease-out;
}
.preloader-container.hidden {
display: block !important;
visibility: visible;
opacity: 0;
z-index: 0;
pointer-events: none;
}
.pole-container {
position: absolute;
top: 50%;
left: 50%;
margin-top: -100px;
margin-left: -20px;
white-space: nowrap;
overflow: hidden;
-webkit-transform: rotate(-90deg);
-moz-transform: rotateX902deg);
-ms-transform: rotate(-90deg);
-o-transform: rotate(-90deg);
transform: rotate(-90deg);
}
.pole-container::after {
position: absolute;
display: block;
content: "";
}
.stripes-wrapper {
white-space: nowrap;
-webkit-animation: WEBKIT-BP .5s linear infinite;
-moz-animation: MOZ-BP .5s linear infinite;
-ms-animation: MS-BP .5s linear infinite;
-o-animation: O-BP .5s linear infinite;
animation: BP .5s linear infinite;
}
.stripes-wrapper span {
margin: 0;
display: inline-block;
margin-left: 10px;
width: 10px;
height: 40px;
background: #9FCBDA;
-webkit-transform: skew(32deg);
-moz-transform: skewX(32deg);
-ms-transform: skew(32deg);
-o-transform: skew(32deg);
transform: skew(32deg);
}
span.stripe-01 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-02 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-03 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-04 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-05 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-06 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-07 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-08 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-09 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-10 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-11 {
background-color: rgba(217, 007, 045, 1);
}
span.stripe-12 {
background-color: rgba(217, 007, 045, 1);
}
@-webkit-keyframes WEBKIT-BP {
0% {
-webkit-transform: translate3D(-30px, 0, 0);
}
100% {
-webkit-transform: translate3D(-6px, 0, 0);
}
}
@-moz-keyframes MOZ-BP {
0% {
-moz-transform: translateX(-30px);
}
100% {
-moz-transform: translateX(-6px);
}
}
@-ms-keyframes MS-BP {
0% {
-ms-transform: translateX(-30px);
}
100% {
-ms-transform: translateX(-6px);
}
}
@-o-keyframes O-BP {
0% {
-o-transform: translateX(-30px);
}
100% {
-o-transform: translateX(-6px);
}
}
@keyframes BP {
0% {
transform: translateX(-30px);
}
100% {
transform: translateX(-6px);
}
}
现在,动画“跳跃”的原因有两个。一个是“动画”只有一个颜色条纹,一个蓝色条纹,而“复制品”有两个颜色条纹,红色和蓝色。关键帧只能通过欺骗眼睛认为它看到了相同的条纹一直穿过条形图来工作。这仅在颜色保持相同时有效!
虽然我的 jsfiddle 可以使用两种颜色,但效果是相同的条纹穿过 strip ,但它在穿过时在红色和蓝色之间交替。本质上不是坏效果,但这就是为什么 Replica 效果不如 Animation 的原因。该代码仅支持一种颜色。两种颜色都可以,但需要反复试验才能确定条纹必须行进的距离,以及条纹的数量、宽度和条纹之间的距离。
第二个原因是您的关键帧没有正确同步。
“动画”在循环之前将其条纹移动了 20 个像素,这很好,因为条纹之间的距离、条纹的数量和条纹的宽度意味着这个距离成功地欺骗了眼睛,使其认为它看到的是相同的条纹一直穿过酒吧。
0% {
-webkit-transform: translate3D(-30px,0,0);
}
100% {
-webkit-transform: translate3D(-10px,0,0);
}
对于“副本”,虽然条纹数量相同,但它们之间的距离不同,导致条纹似乎“跳跃”的不和谐效果。实际上,动画循环得太快了,条形图没有移动到动画欺骗眼睛所需的距离。因此,经过一番试错,我发现24px的距离是最平滑的距离:
@-webkit-keyframes WEBKIT-BP {
0% {
-webkit-transform: translate3D(-30px, 0, 0);
}
100% {
-webkit-transform: translate3D(-6px, 0, 0);
}
}
关于css3 3D 变换动画不流畅,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16635078/
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
我试图用这种形式简单地获取数字 28 integer+space+integer+integer+space+integer我试过这个正则表达式 \\s\\d\\d\\s 但我得到了两个数字11 和
最近一直在学习D语言。我一直对运行时感到困惑。 从我能收集到的关于它的信息中,(这不是很多)我知道它是一种有助于 D 的一些特性的运行时。像垃圾收集一样,它与您自己的程序一起运行。但是既然 D 是编译
想问一下这两个正则表达式有区别吗? \d\d\d 与 \d{3} 我已经在我的本地机器上使用 Java 和 Windows 操作系统对此进行了测试,两者都工作正常并且结果相同。但是,当在 linux
我正在学习 Go,而且我坚持使用 Go 之旅(exercise-stringer.go:https://tour.golang.org/methods/7)。 这是一些代码: type IPAddr
我在Java正则表达式中发现了一段令我困惑的代码: Pattern.compile( "J.*\\d[0-35-9]-\\d\\d-\\d\\d" ); 要编译的字符串是: String string
我在 ruby 代码上偶然发现了这个。我知道\d{4})\/(\d\d)\/(\d\d)\/(.*)/是什么意思,但是\1-\2-\3-\4 是什么意思? 最佳答案 \1-\2-\3-\4 是 b
我一直在努力解决这个问题,这让我很恼火。我了解 D 运行时库。它是什么,它做什么。我也明白你可以在没有它的情况下编译 D 应用程序。就像 XoMB 所做的那样。好吧,XoMB 定义了自己的运行时,但是
我有两个列表列表,子列表代表路径。我想找到所有路径。 List> pathList1 List> pathList2 当然是天真的解决方案: List> result = new ArrayList>
我需要使用 Regex 格式化一个字符串,该字符串包含数字、字母 a-z 和 A-Z,同时还包含破折号和空格。 从用户输入我有02-219 8 53 24 输出应该是022 198 53 24 我正在
目标是达到与this C++ example相同的效果: 避免创建临时文件。我曾尝试将 C++ 示例翻译为 D,但没有成功。我也尝试过不同的方法。 import std.datetime : benc
tl;dr:你好吗perfect forwarding在 D? 该链接有一个很好的解释,但例如,假设我有这个方法: void foo(T)(in int a, out int b, ref int c
有什么方法可以在 D 中使用abstract auto 函数吗? 如果我声明一个类如下: class MyClass { abstract auto foo(); } 我收到以下错误: mai
有没有人为内存中重叠的数组切片实现交集?算法在没有重叠时返回 []。 当 pretty-print (使用重叠缩进)内存中重叠的数组切片时,我想要这个。 最佳答案 如果您确定它们是数组,那么只需取 p
我已经开始学习 D,但我在使用 Andrei Alexandrescu 所著的 The D Programming Language 一书中提供的示例时遇到了一些麻烦。由于 int 和 ulong 类
如何创建一个不可变的类? 我的目标是创建一个实例始终不可变的类。现在我只是用不可变的方法和构造函数创建了一个“可变”类。我将其称为 mData,m 表示可变。然后我创建一个别名 alias immut
不久前我买了《The D Programming Language》。好书,很有教育意义。但是,我在尝试编译书中列出的语言功能时遇到了麻烦:扩展函数。 在这本书中,Andrei 写了任何可以像这样调用
我在 D http://www.digitalmars.com/d/2.0/lazy-evaluation.html 中找到了函数参数的惰性求值示例 我想知道如何在 D 中实现可能的无限数据结构,就像
这个问题在这里已经有了答案: 12 年前关闭。 Possible Duplicate: Could anyone explain these undefined behaviors (i = i++
当前是否可以跨模块扫描/查询/迭代具有某些属性的所有函数(或类)? 例如: source/packageA/something.d: @sillyWalk(10) void doSomething()
我是一名优秀的程序员,十分优秀!