透明度动画

23 篇文章 0 订阅
<!DOCTYPE  HTML>
<html >
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>透明度动画</title>
<style type="text/css">
*{
  padding:0;
  margin:0;
}
#div1{
  width:200px;
  height:200px;
  background: red;
  filter: alpha(opacity:30); /*IE浏览器*/
  opacity: 0.3;/*非IE浏览器*/
}
</style>
<script type="text/javascript">
  window.onload = function(){
      var div1 = document.getElementById('div1');
      div1.onmouseover = function(){
          move(10,100);
      }

      div1.onmouseout = function(){
          move(-10,30);
      }
  }
    var timer = null;
    var alpha = 30;
    /*
      speed变化速度(+/-代表运动方向)
      stopPoint停止点
    */
   function move(speed,stopPoint){
      var div1 = document.getElementById('div1');

        //避免多个定时器的变化叠加,保证只有一个定时器
         clearInterval(timer);
        
         timer = setInterval(function(){
                alpha = alpha + speed;

                //临界值判断,当运动到临界值为0时停止 清除定时器 
               if(alpha == stopPoint){ 
                  div1.style.filter = 'alpha(opacity:'+alpha+')'; //变化
                  div1.style.opacity = alpha / 100;
                  clearInterval(timer);
               }else{
                  div1.style.filter = 'alpha(opacity:'+alpha+')'; //变化
                  div1.style.opacity = alpha / 100;
               }
                
            },30);
  }
</script>
</head>
<body>
  <div id="div1">
  </div>
  
</div>
</body>
</html>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Android 中,您可以使用透明度动画来改变 View 的可见性。以下是一个简单的示例代码,展示了如何使用透明度动画实现 View 的淡入淡出效果: ```java import android.animation.ObjectAnimator; import android.view.View; public class MainActivity extends AppCompatActivity { private View myView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); myView = findViewById(R.id.my_view); // 设置初始透明度为 0 myView.setAlpha(0f); // 创建透明度动画,从 0 到 1,持续时间为 1000 毫秒 ObjectAnimator fadeIn = ObjectAnimator.ofFloat(myView, "alpha", 0f, 1f); fadeIn.setDuration(1000); // 创建透明度动画,从 1 到 0,持续时间为 1000 毫秒 ObjectAnimator fadeOut = ObjectAnimator.ofFloat(myView, "alpha", 1f, 0f); fadeOut.setDuration(1000); // 设置动画循环播放 fadeIn.setRepeatCount(ObjectAnimator.INFINITE); fadeOut.setRepeatCount(ObjectAnimator.INFINITE); // 顺序播放淡入和淡出动画 AnimatorSet animatorSet = new AnimatorSet(); animatorSet.playSequentially(fadeIn, fadeOut); // 开始动画 animatorSet.start(); } } ``` 在上述代码中,我们使用 `ObjectAnimator` 创建了两个透明度动画,一个用于淡入效果,一个用于淡出效果。然后,我们使用 `AnimatorSet` 将这两个动画按顺序播放,并将动画设置为循环播放。最后,调用 `start()` 方法开始动画。 请注意,上述代码需要在 `onCreate()` 方法或其他适当的生命周期方法中调用,以确保正确的 View 初始化和动画启动。同时,您需要替换代码中的 `R.layout.activity_main` 和 `R.id.my_view` 分别为您的布局文件和目标 View 的 ID。 这样,您就可以实现一个简单的透明度动画效果,让 View 在淡入和淡出之间循环显示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值