I need to create an alpha-gradient on the edge of the ImageView. Preferably using only XML.
-
1also take a look at here: http://stackoverflow.com/a/5088137/4270676 should also work for an ImageView. – Lucker10 Jul 18 '16 at 10:21
-
@Lucker10 Yep. This is correct answer. Thank you! – ftp27 Jul 19 '16 at 13:34
4 Answers
Here the solution
the image look like below picture
code for that:
- Prepare shape drawable
res/drawable/gradient_shape.xml:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<gradient
android:startColor="#00FFFFFF"
android:endColor="#FFFFFFFF"
android:type="linear" />
</shape>
Define layout: activity_main.xml:
<ImageView
android:id="@+id/photo"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/photo"
android:src="@drawable/gradient_shape" />
here drawable/photo is just jpeg in drawables folder
EDIT for more information refer this Tutorial
- 6,179
- 1
- 31
- 42
-
1@ffp27 this is the right solution for u & same as your image & to do transparent refer my answer's tutorial & hope this help u. – Dixit Patel Jan 15 '13 at 20:12
-
36No it's a wrong answer. This just puts a alpha/white gradient shape overlay on the image. It doesn't make part of the original image transparent in any way. – Edward van Raak Aug 17 '13 at 17:38
-
1It's the correct answer you just need to change the start and end color – user2512888 Sep 19 '14 at 06:57
-
1
-
1A "real" alpha gradient is not available with xml. Adding another layer of a gradient with color (since unfortunately there is no colorless pure-alpha color code for android) would pollute the gradient with the color, it's FFFFFF in this case. To achieve colorless gradient you'll probably need to for a ComposeShader like mentioned here: https://stackoverflow.com/a/40395350/3591480 – Teng-pao Yu Sep 07 '17 at 08:10
-
Setting the actual image as background messes up the scaling. I prefer using a layer-list drawable (see my answer below) – joe1806772 Aug 07 '20 at 08:08
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<gradient
android:startColor="#00FFFFFF"
android:endColor="#FFFFFFFF"
android:type="linear" />
</shape>
perfect transperancy. Make sure that the View below gradient is actually below and not just touching Gradient shape View.
If you have main RelativeLayout, ListView and View(Background:Gradient )
make sure that Gradient View is on top, of the ListView, and not a side. If Your gradient is aside it will be transparent by RelativeLayout Background Color and not by ListView .
i hope you understand what i want to say.
- 1,745
- 3
- 21
- 38
For transparency :
android:startColor="@null"
Or you can use a 8-digit hex color like that :
android:startColor="#FF000000"
The first two FF are for the alpha of the color, 00 is fully transparent and FF opaque
- 21
- 4
Need to code a custom ImageView if you want colorless transparency.
If your background is a static color, here's my preferred workaround:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/your_image"/>
<item>
<shape android:shape="rectangle">
<gradient android:startColor="#00efefef"
android:endColor="#ffefefef"
android:angle="270"
android:type="linear"/>
</shape>
</item>
</layer-list>
- 446
- 6
- 19