ImageView.setAlpha(int)
has been renamed to ImageView.setImageAlpha(int)
to avoid confusion with the new method View.setAlpha(float)
introduced in API level 11.
View.setAlpha(float)
is a general method available on all View
s, including ImageView
. It applies the specified opacity to the whole view. To achieve this, by default the system creates a temporary buffer (a hardware layer) where the View is drawn as usual, then the buffer is drawn on the screen with the specified alpha value. It's a two-pass mechanism which requires the initial allocation of a buffer, so it's somewhat slower. See this video for more information and how to change the default behavior: Hidden Cost of Transparency.
It's important to note that ImageView
includes by default an optimization that will avoid this buffer allocation if it has no background, so in practice there will be no performance penalty when calling ImageView.setAlpha(float)
if the ImageView
has no background.
ImageView.setImageAlpha(int)
(and ImageView.setAlpha(int)
) are methods proper to the ImageView
. They control the alpha value which is used to draw the content image (bitmap or other) directly on the screen, with no intermediate pass, so this is the preferred method to use to apply transparency to an image displayed by an ImageView
. Of course if you set a background Drawable on your ImageView
that you also want to be translucent, this method will not produce the expected result.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…