Android 使用shape定义不同控件的的颜色、背景色、边框色

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape=["rectangle" | "oval" | "line" | "ring"]      //共有4种类型,矩形(默认)/椭圆形/直线形/环形
    // 以下4个属性只有当类型为环形时才有效
    android:innerRadius="dimension"     //内环半径
    android:innerRadiusRatio="float"    //内环半径相对于环的宽度的比例,比如环的宽度为50,比例为2.5,那么内环半径为20
    android:thickness="dimension"   //环的厚度
    android:thicknessRatio="float"     //环的厚度相对于环的宽度的比例
    android:useLevel="boolean">    //如果当做是LevelListDrawable使用时值为true,否则为false.

    <corners    //定义圆角
        android:radius="dimension"      //全部的圆角半径
        android:topLeftRadius="dimension"   //左上角的圆角半径
        android:topRightRadius="dimension"  //右上角的圆角半径
        android:bottomLeftRadius="dimension"    //左下角的圆角半径
        android:bottomRightRadius="dimension" />    //右下角的圆角半径

    <gradient   //定义渐变效果
        android:type=["linear" | "radial" | "sweep"]    //共有3中渐变类型,线性渐变(默认)/放射渐变/扫描式渐变
        android:angle="integer"     //渐变角度,必须为45的倍数,0为从左到右,90为从上到下
        android:centerX="float"     //渐变中心X的相当位置,范围为0~1
        android:centerY="float"     //渐变中心Y的相当位置,范围为0~1
        android:startColor="color"      //渐变开始点的颜色
        android:centerColor="color"     //渐变中间点的颜色,在开始与结束点之间
        android:endColor="color"    //渐变结束点的颜色
        android:gradientRadius="float"  //渐变的半径,只有当渐变类型为radial时才能使用
        android:useLevel=["true" | "false"] />  //使用LevelListDrawable时就要设置为true。设为false时才有渐变效果

    <padding    //内部边距
        android:left="dimension"
        android:top="dimension"
        android:right="dimension"
        android:bottom="dimension" />

    <size   //自定义的图形大小
        android:width="dimension"
        android:height="dimension" />

    <solid  //内部填充颜色
        android:color="color" />

    <stroke     //描边
        android:width="dimension"   //描边的宽度
        android:color="color"   //描边的颜色
        // 以下两个属性设置虚线
        android:dashWidth="dimension"   //虚线的宽度,值为0时是实线
        android:dashGap="dimension" />      //虚线的间隔
</shape>
<!-- 连框颜色值 --><item>   
      <shape>   
            <solid android:color="#ff0000" />   
      </shape>   
</item>   
<!-- 主体背景颜色值 -->  
<item android:bottom="3dp" android:right="3dp">   
     <shape>   
           <solid android:color="#ffffff" />  

           <padding android:bottom="10dp"  
                android:left="10dp"  
                android:right="10dp"  
                android:top="10dp" />  
     </shape>       
</item>  
</layer-list> 


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

    <!-- 圆角 -->
    <corners
        android:radius="9dp"
        android:topLeftRadius="2dp"
        android:topRightRadius="2dp"
        android:bottomLeftRadius="2dp"
        android:bottomRightRadius="2dp"/><!-- 设置圆角半径 -->

    <!-- 渐变 -->
    <gradient
        android:startColor="@android:color/white"
        android:centerColor="@android:color/black"
        android:endColor="@android:color/black"
        android:useLevel="true"
        android:angle="45"
        android:type="radial"
        android:centerX="0"
        android:centerY="0"
        android:gradientRadius="90"/>

    <!-- 间隔 -->
    <padding
        android:left="2dp"
        android:top="2dp"
        android:right="2dp"
        android:bottom="2dp"/><!-- 各方向的间隔 -->

    <!-- 大小 -->
    <size
        android:width="50dp"
        android:height="50dp"/><!-- 宽度和高度 -->

    <!-- 填充 -->
    <solid
        android:color="@android:color/white"/><!-- 填充的颜色 -->

    <!-- 描边 -->
    <stroke
        android:width="2dp"
        android:color="@android:color/black"
        android:dashWidth="1dp"
        android:dashGap="2dp"/>

</shape>



<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape=["rectangle" | "oval" | "line" | "ring"] >   --- 默认为rectangle
    <corners  -- shape=“rectangle”时使用, 
        android:radius="integer"  -- 半径,会被下边的属性覆盖,默认为1dpandroid: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    -- 指定大小,一般用在imageview配合scaleType属性使用。大小一般会适配滴
        android:width="integer"
        android:height="integer" />
    <solid    -- 填充颜色,可是是十六进制颜色。(比如想设置半透明效果,直接使用十六就只就OKandroid:color="color" />
    <stroke    -- 指定边框,borderdashWidthdashGap有一个为0dp则为实线
        android:width="integer"
        android:color="color"
        android:dashWidth="integer"    -- 虚线宽度
        android:dashGap="integer" />    -- 虚线间隔宽度
</shape>
### 回答1: 您可以使用以下代码设置控件边框线宽度为1dp,颜色为灰背景颜色为白: ```xml <LinearLayout ... android:background="@android:color/white" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="16dp" android:orientation="vertical" android:outlineProvider="background" android:clipToOutline="true" android:elevation="4dp" android:backgroundTint="@color/gray" android:backgroundTintMode="src_over" android:foreground="?attr/selectableItemBackground" android:foregroundTint="@color/gray" android:foregroundTintMode="src_over"> <!-- Your other views here --> </LinearLayout> ``` 这里的关键是使用 `android:backgroundTint` 属性设置边框线的颜色使用 `android:elevation` 属性添加阴影效果,并使用 `android:clipToOutline` 和 `android:outlineProvider` 属性将视图剪切为圆角矩形。 请注意,这里的颜色值是示例,您需要根据您的项目需求选择合适的颜色值。 ### 回答2: 要设置控件边框线宽度为1dp,颜色为灰背景颜色为白,我们可以通过代码或者使用XML来实现。 如果使用代码,可以在控件的相应地方添加以下属性设置: 控件名称.setBorderStyle(BorderStyle.SOLID); 控件名称.setBorderWidth(1); 控件名称.setBorderColor(Color.GRAY); 控件名称.setBackgroundColor(Color.WHITE); 如果使用XML布局文件,可以在控件的相应位置添加以下属性设置: android:background="@color/white" android:borderWidth="1dp" android:borderColor="@color/gray" 以上就是设置控件边框线宽度为1dp,颜色为灰背景颜色为白的方法。 ### 回答3: 要设置一个控件边框线的宽度为1dp,颜色为灰背景颜色为白,我们可以通过在布局文件中设置控件的属性来实现。首先,选取要设置的控件,比如一个TextView,然后在其对应的布局文件中添加以下属性: ```xml <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:background="#FFFFFF" android:layout_margin="8dp" android:padding="4dp" android:gravity="center" android:text="示例文本" android:textSize="16sp" android:background="#ffffff" android:background="@drawable/border_gray"/> ``` 上述代码中,我们设置了TextView的宽度为match_parent,高度为wrap_content,背景颜色为白控件的边距为8dp,内边距为4dp。我们还设置了文字居中显示,文字大小为16sp。关键的部分是设置了控件背景为一个自定义的drawable:border_gray。 要实现这个效果,我们可以在res/drawable文件夹下创建一个名为border_gray.xml的文件,文件内容如下: ```xml <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <solid android:color="#FFFFFF" /> <!-- 控件背景色 --> <stroke android:color="#999999" android:width="1dp" /> <!-- 边框线宽度和颜色 --> </shape> ``` 上述代码中,我们用shape元素定义了一个矩形形状。使用solid元素来定义控件背景色,设置为白使用stroke元素来定义边框线的颜色为灰,宽度为1dp。 通过上述设置,我们就成功地将控件边框线的宽度定义为了1dp,颜色为灰背景颜色为白。这样就实现了题目中的要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值