To increase a button's size when it is pressed in Android
How can I make my button's size to increase slightly when it is pressed and decrease again when it is released? This is for highlighting the开发者_运维问答 pressed button, by using size in addition to a different color.
Regards, Kiki
Make your Button
a field, and modify its size in the OnTouchListener
associated with it. Using an OnTouchListener you can listen for different MotionEvents
, such as ACTION_DOWN
and ACTION_UP
.
button.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) v.getLayoutParams();
//Code to convert height and width in dp.
int height = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 35, getResources().getDisplayMetrics());
int width = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 140, getResources().getDisplayMetrics());
if (event.getAction() == MotionEvent.ACTION_DOWN) {
layoutParams.width = width + 5;
layoutParams.height = height + 5;
SearchButton.setLayoutParams(layoutParams);
}
if (event.getAction() == MotionEvent.ACTION_UP) {
layoutParams.width = width;
layoutParams.height = height;
SearchButton.setLayoutParams(layoutParams);
}
return false;
}
});
Since API 21 (Lollipop) an xml-only solution is available based on the stateListAnimator attribute. Even though its primary goal to animate view properties based on state changes you can disable the animation if it's required by setting duration="0"
. For example:
<!-- res/layout/my_layout.xml -->
<LinearLayout ...
android:stateListAnimator="@animator/zoom_animator">...</layout>
<!-- res/animator/zoom_animator -->
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<set>
<objectAnimator android:propertyName="scaleX" android:valueTo="1.0" android:duration="0" />
<objectAnimator android:propertyName="scaleY" android:valueTo="1.0" android:duration="0" />
</set>
</item>
<item android:state_pressed="true">
<set>
<objectAnimator android:propertyName="scaleX" android:valueTo="1.1" android:duration="0" />
<objectAnimator android:propertyName="scaleY" android:valueTo="1.1" android:duration="0" />
</set>
</item>
</selector>
There's also two similar questions about animated scale:
- Animatedly reduce button size on press and regain it's size on release
- Android scale button on touch
In your activity
Private Button myButton;
//...
protected void onCreate(Bundle savedInstanceState) {
//...
myButton = (Button) findViewById(R.id.my_button);
_button.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
myButton.setWidth(50);
myButton.setHeight(50);
}
});
}
//Try it
Private Button myButton;
//...
protected void onCreate(Bundle savedInstanceState) {
//...
myButton = (Button) findViewById(R.id.my_button);
_button.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
myButton.setWidth(myButton.getWidth()+5);
myButton.setHeight(myButton.getHeight()+5);
}
});
}
精彩评论