i want something like following image
i tried it using drawable shape
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" >
<gradient
android:angle="360"
android:centerX="50%"
android:centerY="50%"
android:gradientRadius="50%"
android:endColor="#000000"
android:centerColor="#FFFFFF"
android:startColor="#000000" >
</gradient>
</shape>
Here is my solution to the problem.
By changing the value of
android:gradientRadius
I was able to get the exact results for me.If the aspect ratio of the oval you need is fixed, then you can use the gradient drawable as a background and use scaleX or scaleY to stretch it into an oval.
drawable myradial.xml:
view using it as a background
If the aspect ratio is not fixed, it still might be possible to set scaleX in code at runtime.
This will not work for everyone in all situations. It can make for tricky layouts. One nice things is it is a single render pass, compared to the 3 passes of the very elegant solution posted with 2 linear gradients over a solid. It also can be used to stretch out any gradient, for example to create a linear gradient at a 22.5 degree angle.
The effect can be approximated in a Layer-List using multiple rectangular shapes. Use a solid rectangle with the center background color. Then use two gradients with the start and end colors the same. Make the center color the same also, except set the alpha to zero.
In the code below the colors are as follows:
One more solution:
Make a new Android xml file (say GreyRadial.xml) file in your drawable folder
In your xml file
Use this xml in your layout background using