- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试为使用两个图像(无需使用 gif 文件)的 Web 元素完成一种“淡入淡出”动画。这些图像是彼此的精确副本,只是它们具有不同的填充颜色。它们是非常简单的图像,因为它们唯一的颜色是一种填充颜色,每种颜色都不同。
我的目标是进行一种“被动”转换,当用户的视口(viewport)位于页面的特定部分时会触发这种转换。它应该只是看起来像图像的颜色在变化,并且尺寸也略有放大。设置 animation-direction: alternate;
和 animation-iteration-count: infinite;
让它看起来像图像正在扩展和改变颜色并返回到原始状态.
我已将其设置为使两个图像始终以不同的 Z 索引彼此重叠,因此图像 1 在前面,而图像 2 在它后面。使用 CSS @keyframes 规则,我可以使 image1 的不透明度缓慢降低,露出 image2 并给人一种非常轻微的颜色变化的感觉。我还应用了一个不同的@keyframes 规则来处理图像的缩放。代码如下:
<div>
<img class="crane-origami front" src="assets/crane.png">
<img class="crane-origami back" src="assets/craneAlternate.png">
</div>
具有以下样式:
.crane-origami {
position: absolute;
}
.crane-origami.front {
z-index: 2;
animation: breathe 2s infinite alternate, makeTransparent 2s infinite alternate;
}
.crane-origami.back {
opacity: 1;
z-index: 1;
animation: breathe 2s infinite alternate;
}
和@keyframes:
@keyframes makeTransparent {
from {}
to {opacity: 0};
}
@keyframes breathe {
from {}
to {transform: scale(1.2);}
}
我想知道是否有更好的方法来实现这种转变,因为这个解决方案看起来有点脏。我不喜欢这样的事实,即我必须将相同的动画应用于两个不同的图像,这样它们才能始终位于彼此之上。我想一个更大的问题是,如果其中一个动画将其中一个图像从一个地方移动到另一个地方,我将不得不将相同的动画应用于另一个图像以使其与原始图像保持一致。也许将那些“移动”动画应用于包含 div
并将 makeTransparent
动画应用于一个图像会更好,但它看起来仍然不像最佳解决方案。另外,恐怕加载时间不同会导致动画开始时间不对齐,效果不准确。
最佳答案
在你的情况下,我会选择一个 div
和一个伪。
这里两张图片都随 div
和伪造的不透明度缩放。
另一种选择是,如果您的图像没有任何透明区域,可以将不同的彩色部分设置为透明,然后您可以为背景颜色设置动画,只需要一个图像.这当然也可以使用 SVG 来完成,为其填充颜色设置动画,因此图像类型的选择更多地取决于基于图像内容的实用性
.crane-origami {
position: relative;
margin: 20px 0 0 20px;
width: 150px;
height: 150px;
background: url(http://placehold.it/150/f0f);
}
.crane-origami:before {
position: absolute;
content: '';
top: 0;
left: 0;
width: 100%;
height: 100%;
background: url(http://placehold.it/150/f00);
}
.crane-origami {
animation: breathe 2s infinite alternate;
}
.crane-origami:before {
opacity: 1;
animation: trans 2s infinite alternate;
}
@keyframes trans {
from {}
to {
opacity: 0;
}
}
@keyframes breathe {
from {}
to {
transform: scale(1.2);
}
}
<div class="crane-origami">
</div>
关于jquery - 将动画堆叠在一起是不好的做法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40206956/
如果您想分享更多信息,可以在这里找到整个资源 指针: https://github.com/sergiotapia/DreamInCode.Net 基本上,我的API将为其他开发人员提供
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
我不是 SCM 工具的经验丰富的用户,尽管我确信它们的用处,当然。 我在以前的工作中使用了一些不起眼的商业工具,在当前的工作中使用了 Perforce,并在我的小型个人项目中使用了 TortoiseS
所以我想知道一些我应该避免在 javascript 中做的事情以获得良好的 SEO 排名。在我的下一个站点中,我将广泛使用 jquery 和 javascript,但不想牺牲 SEO。那么您认为我应该
基本上,我想知道什么是避免 future CSS 代码出现问题和混淆的最佳方法... 像这样命名 CSS 属性: div#content ul#navigation div.float-left (真
我是一名优秀的程序员,十分优秀!