android自定义view背景透明度,Android 背景透明度设置总结

概述

在需求上遇到背景设置透明度还是比较常见的,设置透明度有几种方式,但是不同的场景应用下,不同的方式可能会出现一些问题。针对开发过程中的需求做以下总结。

效果图

图1、

382a44600c66

image

图2、

382a44600c66

image

图3、

382a44600c66

image

图4

382a44600c66

image

图1、蓝色头部和输入框背景初始状态

图2、点击按钮01,输入框的透明度不起作用,和title的透明度一样

图3、点击按钮02,背景透明度设置正常,但是可能会对全局的背景有影响

图4、点击按钮03,背景透明度设置正常,具体原因代码注释有提到

代码

按钮点击

public void button01(View view){

// search透明度不起作用

title.setAlpha(0.2f);

search.setAlpha(0.8f);

}

public void button02(View view){

// 在布局中多个控件同时使用一个资源的时候,这些控件会共用一个状态

// 如果你改变了一个控件的状态,其他的控件都会接收到相同的通知

title.getBackground().setAlpha(51);

search.getBackground().setAlpha(153);

}

public void button03(View view){

// 使用mutate()方法使该控件状态不定,这样不定状态的控件就不会共享自己的状态了

title.getBackground().mutate().setAlpha(51);

search.getBackground().mutate().setAlpha(153);

}

布局

android:orientation="vertical"

android:layout_width="match_parent"

android:layout_height="match_parent">

android:id="@+id/ll_title"

android:layout_width="match_parent"

android:layout_height="80dp"

android:gravity="center"

android:background="#0000ff"

android:orientation="horizontal">

android:id="@+id/et_search"

android:layout_width="200dp"

android:layout_height="60dp"

android:gravity="center"

android:hint="输入框"

android:textColorHint="#ffffff"

android:background="@drawable/search_title_bg"/>

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_marginTop="40dp"

android:orientation="horizontal">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="01"

android:onClick="button01"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="02"

android:onClick="button02"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="03"

android:onClick="button03"/>

输入框背景 search_title_bg

android:shape="rectangle">

android:color="#000000"/>

android:radius="8dp"/>

android:width="1dp"

android:color="#666666"/>

写在后面的

背景透明度设置比较常见,mutate()方法,可以解决背景透明状态设置异常的现象。这里只记载需求开发中遇到的问题,可能还有其他方式,欢迎分享!!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值