Shape Drawable Resources

本文介绍如何使用ShapeDrawable创建带有渐变色边框的矩形,并在TextView上应用。详细解释了shape XML文件的各个属性,如渐变色、圆角、内边距等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

、介绍
        Shape Drawable Resources 是指一个XML文件,它定义了几何形状,包括颜色和渐变
放在res/Drawable文件夹下,文件名即为资源id,可以在其他layout中调用R.drawable.filename,
对应的类为ShapeDrawable
shape包含矩形、椭圆形、行、环形。

2、使用
        下面以为一个TextView设置一个渐变色的边框为例进行介绍,第三部分对具体属性含义进行介绍
2.1 定义一个渐变色的矩形shape,文件路径res/drawable/gradient_box.xml
<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android"    android:shape="rectangle">    <gradient        android:startColor="#FFFF0000"        android:endColor="#80FF00FF"        android:angle="45"/>    <padding android:left="7dp"        android:top="7dp"        android:right="7dp"        android:bottom="7dp" />    <corners android:radius="8dp" /></shape>2.2 TextView属性设置
<TextView    android:background="@drawable/gradient_box"    android:layout_height="wrap_content"    android:layout_width="wrap_content" /> 其中 android:background="@drawable/gradient_box"表示设置背景为gradient_box 这个drawable
或者在后台程序中设置
Resources res = getResources();Drawable shape = res. getDrawable(R.drawable.gradient_box);TextView tv = (TextView)findViewByID(R.id.textview);tv.setBackground(shape);
3、属性介绍
xml定义如下
<?xml version="1.0" encoding="utf-8"?><shape    xmlns:android="http://schemas.android.com/apk/res/android"    android:shape=["rectangle" | "oval" | "line" | "ring"] >    <corners        android:radius="integer"        android:topLeftRadius="integer"        android:topRightRadius="integer"        android:bottomLeftRadius="integer"        android:bottomRightRadius="integer" />    <gradient        android:angle="integer"        android:centerX="integer"        android:centerY="integer"        android:centerColor="integer"        android:endColor="color"        android:gradientRadius="integer"        android:startColor="color"        android:type=["linear" | "radial" | "sweep"]        android:useLevel=["true" | "false"] />    <padding        android:left="integer"        android:top="integer"        android:right="integer"        android:bottom="integer" />    <size        android:width="integer"        android:height="integer" />    <solid        android:color="color" />    <stroke        android:width="integer"        android:color="color"        android:dashWidth="integer"        android:dashGap="integer" /></shape>其中shape必须为根元素,android:shape定义了形状,默认为矩形。
corners只对矩形有效,表示圆角的度数
gradient表示渐变色
padding表示即对内的偏移
size为shape大小
solid为填充色
stroke为shape边线的设置
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值