1.结果展示(selector):
注意:PNG图片着色要选择纯色图片,否则图片会严重失真,如下图
原图:
结果图:
2.透明度设置:
private void setBg(ImageButton imageButton) {
//0~255透明度值
imageButton.getBackground().setAlpha(255);
}
设置成255:
设置成0
3.源代码
项目结构:
MainActivity
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//使用图片ic_launcher着色,得不到想要的效果。
ImageButton imageButton = findViewById(R.id.image);
//设置透明度
setBg(imageButton);
Drawable drawable = imageButton.getDrawable();
//方式一:启动就更改颜色,也可以通过事件
//imageButton.setImageDrawable(tintDrawable(drawable, ColorStateList.valueOf(Color.RED)));
//方式二:selector来改变颜色,注意btn_color.xml必须在color文件夹下
imageButton.setImageDrawable(tintDrawable(drawable, getResources().getColorStateList(R.color.btn_color)));
}
//设置透明度
private void setBg(ImageButton imageButton) {
//0~255透明度值
imageButton.getBackground().setAlpha(0);
}
//着色
public static Drawable tintDrawable(Drawable drawable, ColorStateList colors) {
final Drawable wrappedDrawable = DrawableCompat.wrap(drawable);
DrawableCompat.setTintList(wrappedDrawable, colors);
return wrappedDrawable;
}
}
btn_color.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="#FF4081" android:state_pressed="true" />
<item android:color="#666666" android:state_pressed="false"/>
</selector>
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="透明度测试" />
<ImageButton
android:id="@+id/image"
android:layout_width="100dp"
android:layout_height="100dp"
android:scaleType="fitXY"
android:src="@mipmap/contacts" />
<!--<ImageButton
android:id="@+id/image"
android:layout_width="100dp"
android:layout_height="100dp"
android:src="@mipmap/ic_launcher" />-->
</android.support.constraint.ConstraintLayout>