android 简单动画

天高空 发布于 2012/12/21 07:25
阅读 398
收藏 0

private void initAnimation(float x, float y) {
  // 透明度控制动画效果 alpha
  // AlphaAnimation animation_alpha = new AlphaAnimation(0.1f, 1.0f);
  // // 第一个参数fromAlpha为 动画开始时候透明度
  // // 第二个参数toAlpha为 动画结束时候透明度
  // // animation_alpha.setRepeatCount(-1);//设置循环
  // animation_alpha.setDuration(5000);// 设置时间持续时间为 5000毫秒
  // 旋转效果rotate
  // RotateAnimation animation_rotate = new RotateAnimation(0, -720,
  // RotateAnimation.RELATIVE_TO_SELF, 0.5f,
  // RotateAnimation.RELATIVE_TO_SELF, 0.5f);
  // 第一个参数fromDegrees为动画起始时的旋转角度 //第二个参数toDegrees为动画旋转到的角度
  // 第三个参数pivotXType为动画在X轴相对于物件位置类型 //第四个参数pivotXValue为动画相对于物件的X坐标的开始位置
  // 第五个参数pivotXType为动画在Y轴相对于物件位置类型 //第六个参数pivotYValue为动画相对于物件的Y坐标的开始位置
  // animation_rotate.setRepeatCount(-1);
  // animation_rotate.setDuration(5000);// 设置时间持续时间为 5000毫秒
  // 尺寸伸缩动画效果 scale
  ScaleAnimation animation_scale = new ScaleAnimation(1.0f, 0.1f, 1.0f,
    0.1f, Animation.RELATIVE_TO_SELF, 0.5f,
    Animation.RELATIVE_TO_SELF, 0.5f);
  // 第一个参数fromX为动画起始时 X坐标上的伸缩尺寸
  // 第二个参数toX为动画结束时 X坐标上的伸缩尺寸
  // 第三个参数fromY为动画起始时Y坐标上的伸缩尺寸
  // 第四个参数toY为动画结束时Y坐标上的伸缩尺寸
  /*
   * 说明: 以上四种属性值 0.0表示收缩到没有 1.0表示正常无伸缩 值小于1.0表示收缩 值大于1.0表示放大
   */
  // 第五个参数pivotXType为动画在X轴相对于物件位置类型
  // 第六个参数pivotXValue为动画相对于物件的X坐标的开始位置
  // 第七个参数pivotXType为动画在Y轴相对于物件位置类型
  // 第八个参数pivotYValue为动画相对于物件的Y坐标的开始位置
  animation_scale.setRepeatCount(0);
  animation_scale.setDuration(3000);// 设置时间持续时间为 5000毫秒

  // 移动动画效果translate
  // TranslateAnimation animation_translate = new TranslateAnimation(0,
  // Constant.WIDTH -120, 0, -Constant.HEIGHT / 2);
  TranslateAnimation animation_translate = new TranslateAnimation(0,
    advertBB.getWidth() / 2 - 80, 0, -advertBB.getHeight() / 2);
  // 第一个参数fromXDelta为动画起始时 X坐标上的移动位置
  // 第二个参数toXDelta为动画结束时 X坐标上的移动位置
  // 第三个参数fromYDelta为动画起始时Y坐标上的移动位置
  // 第三个参数toYDelta为动画结束时Y坐标上的移动位置
  animation_translate.setRepeatCount(0);// 设置动画执行多少次,如果是-1的话就是一直重复
  animation_translate.setDuration(3000);// 设置时间持续时间为 5000毫秒
  AnimationSet animationSet = new AnimationSet(true);

  // animationSet.addAnimation(animation_alpha);//透明度
  // animationSet.addAnimation(animation_rotate);//旋转
  animationSet.addAnimation(animation_scale);// 尺寸伸缩
  animationSet.addAnimation(animation_translate);// 移动
  // animationSet.setFillAfter(true);
  animationSet.setAnimationListener(new AnimationListener() {
   public void onAnimationStart(Animation animation) {
    // TODO Auto-generated method stub
    // bg.setVisibility(View.VISIBLE);
   }

   public void onAnimationRepeat(Animation animation) {
    // TODO Auto-generated method stub

   }

   public void onAnimationEnd(Animation animation) {
    // TODO Auto-generated method stub
    System.out.println("dadfadfadfasdf");
    in.setVisibility(View.GONE);
    btnright.setEnabled(true);
    // advertBB.setEnabled(false);
   }
  });
  in.startAnimation(animationSet);// 开始播放

加载中
返回顶部
顶部