android高分段进阶攻略(3)旋转等待UI界面设计

自定义动画在Android UI设计中的应用
本文介绍了一个简单的Android UI设计案例,通过自定义rotate动画实现了几行代码赚取300RMB的效果。重点讲解了rotate动画的核心属性及使用方法,包括interpolator、fromDegrees、toDegrees、pivotX、pivotY和duration等,并提供了完整的代码示例。

http://www.tuicool.com/articles/eMnEJnN

http://blog.youkuaiyun.com/heaimnmn/article/details/20542397

因为最近工作较忙的原因,可能更新较慢,而且内容越来越细,从一个完整的app到一个

简单的功能,甚至到UI设计,今天介绍的就是一个常见的UI设计,先上图: 

别看只是个简单的UI,只有几行代码,当时我把这个demo卖给客户赚了300RMB,就几

行代码, 其实这个代码的核心在于,自定义 animation的rotate动画,

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"> 
  3. <rotate  
  4.         android:interpolator="@android:anim/accelerate_decelerate_interpolator" 
  5.         android: fromDegrees ="0"  
  6.         android:repeatCount="infinite"           
  7.         android:pivotX="50%"  
  8.         android:pivotY="50%"      
  9.         android:duration="3000" 
  10. ndroid:toDegrees="360.0" 
  11. />   
  12. <!-- rotate 旋转动画效果 
  13.        属性:interpolator 指定一个动画的插入器 
  14.              在我试验过程中,使用android.res.anim中的资源时候发现 
  15.              有三种动画插入器: 
  16.                 accelerate_decelerate_interpolator    加速-减速 动画插入器 
  17.                 accelerate_interpolator                加速-动画插入器 
  18.                 decelerate_interpolator                减速- 动画插入器 
  19.              其他的属于特定的动画效果 

  20.        浮点数型值: 
  21.             fromDegrees 属性为动画起始时物件的角度     
  22.             toDegrees   属性为动画结束时物件旋转的角度 可以大于360度    


  23.             说明: 
  24.                      当角度为负数——表示逆时针旋转 
  25.                      当角度为正数——表示顺时针旋转               
  26.                      (负数from——to正数:顺时针旋转)    
  27.                      (负数from——to负数:逆时针旋转)  
  28.                      (正数from——to正数:顺时针旋转)  
  29.                      (正数from——to负数:逆时针旋转)        

  30.             pivotX     属性为动画相对于物件的X坐标的开始位置 
  31.             pivotY     属性为动画相对于物件的Y坐标的开始位置 

  32.             说明:        以上两个属性值 从0%-100%中取值 
  33.                          50%为物件的X或Y方向坐标上的中点位置 

  34.         长整型值: 
  35.             duration  属性为动画持续时间 
  36.             说明:       时间以毫秒为单位 
  37. -->

然后就是调用这个这个自定义的rotate

RotateAnimation rotateAnimation = (RotateAnimation) AnimationUtils.loadAnimation(context, R.anim.refresh); // 加载XML文件中定义的动画
并且通过自定义dialog完整显示出来,完整代码如下:
public MyProgressDialog(Context context, int theme) {
        super(context, theme);
        this.context = context;
        View view = LayoutInflater.from(context).inflate(R.layout.load, null); // 加载自己定义的布局
        ImageView img_loading = (ImageView) view.findViewById(R.id.img_load);
        RelativeLayout img_close = (RelativeLayout) view.findViewById(R.id.img_cancel);
        RotateAnimation rotateAnimation = (RotateAnimation) AnimationUtils.loadAnimation(context, R.anim.refresh); // 加载XML文件中定义的动画
        img_loading.setAnimation(rotateAnimation);// 开始动画
        setContentView(view);// 为Dialoge设置自己定义的布局
        // 为close的那个文件添加事件
        img_close.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
                dismiss();
            }
        });
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值