android修改控件外观(使用drawable资源)

使用drawable资源这方面是比较容易的,笔者学习并没有花太多时间,但是却是受益匪浅。

之前笔者在做圆角矩形的button的时候,还特意学了PS,想想当时真是天真,android是完全自带这个功能的嘛。

当然android的强大也不仅于此,我们还可以修改seekbar的背景以及移动时的效果,还可以给textview、button等控件加边框,还可以改变它们的形状等等。

本篇文章就做了一个简单的demo,便于大家理解drawable资源的使用:


     



在drawable中创建了比较多的xml文件,在layout中只有activity_main一个:





activity_main:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin">

    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textColor="@drawable/my_image" />

    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textColor="@drawable/my_image" />

    <SeekBar
        android:layout_width="match_parent"
        android:layout_height="100dp"
        android:max="100"
        android:progressDrawable="@drawable/my_bar" />

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/layout_logo" />

    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/my_shape1"
        android:text="Hello World!" />

    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/my_shape2"
        android:text="Hello World!" />

    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/my_shape3"
        android:text="Hello World!" />
</LinearLayout>

my_image:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
   <!--指定获得焦点时的颜色-->
    <item android:state_focused="true"
        android:color="#f44"/>
    <!--指定失去焦点时的颜色-->
    <item android:state_focused="false"
        android:color="#ccf"/>
</selector>

my_bar: (ic_launcher111和ic_launcher222只是两个不一样大的ic_launcher图片)

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
   <!--定义轨道背景-->
    <item
        android:id="@android:id/background"
        android:drawable="@drawable/ic_launcher111" />
    <!--定义轨道上已完成部分的外观-->
    <item
        android:id="@android:id/progress"
        android:drawable="@drawable/ic_launcher222" />
</layer-list>

layout_logo:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!--定义三个层叠-->
    <item>
        <bitmap android:gravity="center" android:src="@mipmap/ic_launcher" />
    </item>
    <item android:left="25dp" android:top="25dp">
        <bitmap android:gravity="center" android:src="@mipmap/ic_launcher" />
    </item>
    <item android:left="50dp" android:top="50dp" >
        <bitmap android:gravity="center" android:src="@mipmap/ic_launcher" />
    </item>
</layer-list>

my_shape1:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <!--设置填充颜色-->
    <solid android:color="#fff"/>
    <!--设置四周的内边距-->
    <padding android:left="7dp"
        android:top="7dp"
        android:right="7dp"
        android:bottom="7dp"/>
    <!--设置边框-->
    <stroke android:width="3dip" android:color="#ff0"/>
</shape>

my_shape2:

<?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>

my_shape3:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <!--定义填充渐变颜色-->
    <gradient
        android:startColor="#ff0"
        android:endColor="#00f"
        android:angle="45"/>
    <!--设置内填充-->
    <padding android:left="7dp"
        android:top="7dp"
        android:right="7dp"
        android:bottom="7dp"/>
    <!--设置圆角矩形-->
    <corners android:radius="8dp"/>
</shape>


最后附上android studio源码:http://download.csdn.net/detail/double2hao/9324287


  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值