Button自定义样式及动画

1.自定义样式

   drawable目录下面新建shape_buttuon

<?xml version="1.0" encoding="UTF-8"?> 
<shape 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:shape="rectangle"> 
    <!-- 填充的颜色 --> 
    <solid android:color="#ff91d119" /> 
    <!-- 设置按钮的四个角为弧形 --> 
    <!-- android:radius 弧形的半径 --> 
    <corners android:radius="24dip" /> 
      s
<!-- padding:Button里面的文字与Button边界的间隔 --> 
<padding 
   android:left="10dp" 
   android:top="10dp" 
   android:right="10dp" 
   android:bottom="10dp" 
/> 
</shape> 

  然后设为button背景

2.自定义动画

   (1).添加监听器

bt_login.setOnTouchListener(new OnTouchListener() {
			
			@Override
			public boolean onTouch(View v, MotionEvent event) {
				if (event.getAction() == MotionEvent.ACTION_DOWN) {
					// 点击按钮松开后按钮缩小
					narrow(v);
				} else if (event.getAction() == MotionEvent.ACTION_UP) {					
					// 点击按钮未松开时按钮放大
					blow_up(v);
				}			
				return false;
			}
		});

   (2).动画

 // 放大按钮动画
	private void blow_up(View v) {
		float[] vaules = new float[] { 0.9f, 0.95f, 1.0f };
		AnimatorSet set = new AnimatorSet();
		set.playTogether(ObjectAnimator.ofFloat(v, "scaleX", vaules),
				ObjectAnimator.ofFloat(v, "scaleY", vaules));
		set.setDuration(30);
		set.start();
	}


	// 缩小按钮动画
	private void narrow(View v) {
		float[] vaules = new float[] { 1.0f, 0.95f, 0.9f };
		AnimatorSet set = new AnimatorSet();
		set.playTogether(ObjectAnimator.ofFloat(v, "scaleX", vaules),
				ObjectAnimator.ofFloat(v, "scaleY", vaules));
		set.setDuration(30);
		set.start();
	}


3.也可以使用selector编辑

   在drawable下面新建selector,设置backgroud为selector

<?xml version="1.0" encoding="utf-8"?>  
<selector xmlns:android="http://schemas.android.com/apk/res/android">  
  
    <item android:drawable="@drawable/button_press" android:state_pressed="true"/>  
    <item android:drawable="@drawable/button_nomal" android:state_focused="false" android:state_pressed="false"/>  
    <item android:drawable="@drawable/button_focus"  android:state_focused="true"/>  
    <item android:drawable="@drawable/button_nomal" android:state_focused="false"/>  
  
</selector>  





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值