Android 我怎么画这个边界?

Android 我怎么画这个边界?,android,android-canvas,Android,Android Canvas,如何绘制渐变边框(边框淡出为透明)和径向渐变背景 我的代码: Drawable/bg.xml Radial gradient code is here Drawable/border.xml <item> <shape android:shape="rectangle"> <solid android:color="@android:color/h

如何绘制渐变边框(边框淡出为透明)和径向渐变背景

我的代码:

Drawable/bg.xml
        Radial gradient code is here    
Drawable/border.xml
            <item>
                <shape android:shape="rectangle">
                    <solid android:color="@android:color/holo_blue_light"/>
                    <corners android:topLeftRadius="100dp" android:topRightRadius="100dp"/>
                </shape>
            </item>
            <item android:left="3dp" android:right="3dp" android:top="2dp">
                <shape android:shape="rectangle">
                    <solid android:color="@color/white"/>
                    <corners android:topLeftRadius="100dp" android:topRightRadius="100dp"/>
                </shape>
            </item>
            <item android:height="5dp"  android:left="30dp" android:right="30dp">
                <shape android:shape="rectangle">
                    <solid android:color="@color/colorPrimary"/>
                    <corners android:topLeftRadius="100dp" android:topRightRadius="200dp"/>
                    <gradient android:endColor="@color/transparent"
                        android:centerColor="@color/white"
                        android:startColor="@color/transparent"/>
                </shape>
            </item>
            <item>
                <shape android:shape="rectangle">
                    <gradient android:endColor="@color/white"
                        android:startColor="@android:color/transparent"
                        android:angle="-90" />
                </shape>
            </item>
Drawable/bg.xml
径向梯度代码在这里
Drawable/border.xml
我想要这个结果:


在drawable文件夹中创建这个rectangle.xml文件。
将此代码复制到其中

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape android:shape="rectangle">
            <gradient
                android:angle="270"
                android:endColor="#000000"
                android:startColor="#FFFFFF" />
            <corners android:radius="10dp" />
            <padding
                android:bottom="5dp"
                android:left="5dp"
                android:right="5dp"
                android:top="5dp" />
        </shape>
    </item>
    <item>
        <shape android:shape="rectangle">
            <solid android:color="#af25e1" />
            <corners android:radius="10dp" />
            <size
                android:width="250dp"
                android:height="150dp" />
        </shape>
    </item>
</layer-list>

并将其设置为容器的背景。
您可以根据需要进行更改

希望它对您有用。


<?xml version="1.0" encoding="utf-8"?>
<layer-list  xmlns:android="http://schemas.android.com/apk/res/android">

    <item>
        <shape android:shape="rectangle">
            <solid android:color="@android:color/holo_blue_light"/>
            <corners android:topLeftRadius="100dp" android:topRightRadius="100dp"/>
        </shape>
    </item>

    <item android:left="3dp" android:right="3dp" android:top="2dp">
        <shape android:shape="rectangle">
            <solid android:color="@color/white"/>
            <corners android:topLeftRadius="100dp" android:topRightRadius="100dp"/>
        </shape>
    </item>

    <item  android:width="40dp" android:left="70dp" android:right="200dp">
        <shape android:shape="rectangle">
            <solid android:color="@color/colorPrimary"/>

            <gradient android:endColor="@color/white"
                android:startColor="@color/transparent"/>
        </shape>
    </item>

    <item android:width="40dp" android:left="240dp" android:right="20dp">
        <shape android:shape="rectangle">
            <solid android:color="@color/white"/>
            <gradient android:endColor="@color/transparent"
                android:startColor="@color/white"/>
        </shape>
    </item>

    <item android:left="110dp" android:right="120dp">
        <shape android:shape="rectangle">
            <solid android:color="@color/white"/>
        </shape>
    </item>

    <item>
        <shape android:shape="rectangle">
            <gradient android:endColor="@color/white"
                android:startColor="@color/transparent"
                android:angle="-90" />
        </shape>
    </item>
</layer-list>

如果背景是渐变的,有可能吗?你的意思是,有可能制作bg渐变吗?是的,我想在我的要求设计中使用圆形渐变背景而不是白色背景,有可能吗?检查代码,在末尾添加另一个带有形状和渐变的项目-你可以用谷歌搜索一点圆形渐变I在末尾添加渐变项目,但只显示渐变。我想显示边界(像你的结果代码)与梯度背景,而不是白色背景。