html animation 无限循环,javascript – 如何创建一个有效的无限循环挥动文本动画?...

这是我试图创建的效果(

JSFiddle):

$('.header h1 span').each(function() { // each letter is contained inside a element

var that = $(this);

setTimeout(function() {

that.animate({

top: "-10px"

},animateTime / 2)

.animate({

top: "10px"

},animateTime / 2);

},that.index() * 100);

});

结果:

12d519031d4e19d9c77465373b9b92e7.gif

它似乎很成功.但是,在切换标签后,我遇到了这样的问题,然后又回来了:

6c5b16e850a488fe02714ab4e1fae05a.gif

在上面的小提琴中,我试图通过在选项卡未聚焦时停止动画来“修复”这个问题.这比我没有检查标签无焦点时更好,但它仍然有问题.这是我用来做的代码:

var running = true;

document.addEventListener('visibilitychange',function(){

console.log("Running:" + running);

running = !document.hidden;

if(!running) clearQueues();

})

如果用户从标签中花费的时间不到几秒钟,动画看起来就像是第二个GIF,我没有办法避免这种情况.我尝试过使用requestAnimationFrame(),但我无法弄清楚如何使其正常运行.

所以,我的问题是:如何防止动画受到未聚焦选项卡的影响?

奖励积分(比喻)如果你能帮我在移动设备上提高效率的话.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现一个无限循环的轮播效果,可以使用逐帧动画和补间动画的组合。 首先,需要准备好一组图片,这些图片将会组成轮播效果的帧动画。然后,在程序中创建一个ImageView控件,将帧动画的第一帧作为初始图片显示在ImageView上。 接着,利用补间动画的TranslateAnimation来实现图片的平移动画效果。将ImageView不断向左移动一个图片的宽度,当ImageView移动到最后一张图片时,将它瞬间移动到第一张图片的位置,从而实现无限循环播放的效果。 代码示例: ```java // 加载帧动画资源 AnimationDrawable animDrawable = new AnimationDrawable(); animDrawable.addFrame(getResources().getDrawable(R.drawable.image1), 100); animDrawable.addFrame(getResources().getDrawable(R.drawable.image2), 100); animDrawable.addFrame(getResources().getDrawable(R.drawable.image3), 100); animDrawable.setOneShot(false); // 设置循环播放 // 创建ImageView并设置初始图片 ImageView imageView = new ImageView(this); imageView.setImageDrawable(animDrawable); setContentView(imageView); // 创建平移动画 TranslateAnimation animation = new TranslateAnimation(0, -imageView.getWidth(), 0, 0); animation.setDuration(1000); animation.setRepeatCount(Animation.INFINITE); animation.setRepeatMode(Animation.RESTART); imageView.startAnimation(animation); ``` 这样,就可以实现一个无限循环的轮播效果了。不断平移的ImageView会不断播放帧动画,从而呈现出连续的图片轮播效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值