Android之shape与selector实现圆角
shape和selector是Android UI设计中经常用到的,比如我们要自定义一个圆角Button,点击Button有些效果的变化,就要用到shape和selector。可以这样说,shape和selector在美化控件中的作用是至关重要的。
1.Shape
简介
作用:XML中定义的几何形状
位置:res/drawable/文件的名称.xml
使用的方法:
Java代码中:R.drawable.文件的名称
XML中:android:background="@drawable/文件的名称"
属性:
- <shape> android:shape=["rectangle" | "oval" | "line" | "ring"]
 - 其中rectagle矩形,oval椭圆,line水平直线,ring环形
 - <shape>中子节点的常用属性:
 - <gradient> 渐变
 - android:startColor 起始颜色
 - android:endColor 结束颜色
 - android:angle 渐变角度,0从上到下,90表示从左到右,数值为45的整数倍默认为0;
 - android:type 渐变的样式 liner线性渐变 radial环形渐变 sweep
 - <solid > 填充
 - android:color 填充的颜色
 - <stroke > 描边
 - android:width 描边的宽度
 - android:color 描边的颜色
 - android:dashWidth 表示'-'横线的宽度
 - android:dashGap 表示'-'横线之间的距离
 - <corners > 圆角
 - android:radius 圆角的半径 值越大角越圆
 - android:topRightRadius 右上圆角半径
 - android:bottomLeftRadius 右下圆角角半径
 - android:topLeftRadius 左上圆角半径
 - android:bottomRightRadius 左下圆角半径
 
2.Selector 简介位置:res/drawable/文件的名称.xml使用的方法:Java代码中:R.drawable.文件的名称XML中:android:background="@drawable/文件的名称"selector.xml
- <?xml version="1.0" encoding="utf-8"?>
 - <selector xmlns:android="http://schemas.android.com/apk/res/android">
 - <item android:state_selected="true">
 - <shape>
 - <gradient android:angle="270" android:endColor="#99BD4C"
 - android:startColor="#A5D245" />
 - <size android:height="60dp" android:width="320dp" />
 - <corners android:radius="8dp" />
 - </shape>
 - </item>
 - <item android:state_pressed="true">
 - <shape>
 - <gradient android:angle="270" android:endColor="#99BD4C"
 - android:startColor="#A5D245"/>
 - <size android:height="60dp" android:width="320dp" />
 - <corners android:radius="8dp" />
 - </shape>
 - </item>
 - <item>
 - <shape>
 - <gradient android:angle="270" android:endColor="#A8C3B0"
 - android:startColor="#C6CFCE"/>
 - <size android:height="60dp" android:width="320dp" />
 - <corners android:radius="8dp" />
 - </shape>
 - </item>
 - </selector>
 
list_item.xml
- <?xml version="1.0" encoding="utf-8"?>
 - <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 - android:orientation="horizontal"
 - android:layout_width="fill_parent"
 - android:layout_height="wrap_content"
 - android:background="@drawable/selector"
 - >
 - <ImageView
 - android:id="@+id/img"
 - android:layout_width="wrap_content"
 - android:layout_height="wrap_content"
 - android:layout_gravity="center_vertical"
 - android:layout_marginLeft="20dp"
 - />
 - <TextView
 - android:text="data"
 - android:id="@+id/title"
 - android:layout_width="fill_parent"
 - android:layout_height="wrap_content"
 - android:gravity="center_vertical"
 - android:layout_marginLeft="20dp"
 - android:layout_marginTop="20dp"
 - android:textSize="14sp"
 - android:textStyle="bold"
 - android:textColor="@color/black"
 - >
 - </TextView>
 - </LinearLayout>
 
main.xml
- <?xml version="1.0" encoding="utf-8"?>
 - <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 - android:orientation="vertical"
 - android:layout_width="fill_parent"
 - android:layout_height="wrap_content"
 - android:background="#253853"
 - >
 - <ListView
 - android:id="@+id/list"
 - android:layout_width="match_parent"
 - android:layout_height="match_parent"
 - android:cacheColorHint="#00000000"
 - android:divider="#2A4562"
 - android:dividerHeight="3px"
 - android:listSelector="#264365"
 - android:drawSelectorOnTop="false"
 - >
 - </ListView>
 - </LinearLayout>
 
colors.xml
- <?xml version="1.0" encoding="utf-8"?>
 - <resources>
 - <color name="white">#FFFFFFFF</color>
 - <color name="transparency">#00000000</color>
 - <color name="title_bg">#1C86EE</color>
 - <color name="end_color">#A0cfef83</color>
 - <color name="black">#464646</color>
 - </resources>
 
MainActivity
- package com.lingdududu.customlist;
 - import java.util.ArrayList;
 - import java.util.HashMap;
 - import xb.customlist.R;
 - import android.R.array;
 - import android.app.Activity;
 - import android.os.Bundle;
 - import android.widget.ArrayAdapter;
 - import android.widget.ListView;
 - import android.widget.SimpleAdapter;
 - public class MainActivity extends Activity {
 - ListView list;
 - String data[] = new String[]{
 - "China","UK","USA","Japan","German","Canada","ET","Narotu"
 - };
 - @Override
 - public void onCreate(Bundle savedInstanceState) {
 - super.onCreate(savedInstanceState);
 - setContentView(R.layout.main);
 - list =(ListView) findViewById(R.id.list);
 - SimpleAdapter adapter = new SimpleAdapter(this, getData(), R.layout.list_item,
 - new String[]{"title","img"}, new int[]{R.id.title,R.id.img});
 - list.setAdapter(adapter);
 - }
 - private ArrayList<HashMap<String, Object>> getData() {
 - ArrayList<HashMap<String, Object>> dlist = new ArrayList<HashMap<String,Object>>();
 - for(int i =0;i<data.length;i++){
 - HashMap<String, Object>map = new HashMap<String, Object>();
 - map.put("title", data[i]);
 - map.put("img", R.drawable.item_left2);
 - dlist.add(map);
 - }
 - return dlist;
 - }
 - }
 
Android之shape与selector实现圆角的更多相关文章
- 44.Android之Shape设置虚线、圆角和渐变学习
		
Shape在Android中设定各种形状,今天记录下,由于比较简单直接贴代码. Shape子属性简单说明一下: gradient -- 对应颜色渐变. startcolor.endcolor就不多说 ...
 - [Android UI] shape和selector的结合使用
		
shape和selector是Android UI设计中经常用到的,比如我们要自定义一个圆角Button,点击Button有些效果的变化,就要用到shape和selector.可以这样说,shape和 ...
 - android使用shape做selector按钮按下和弹起的动画
		
平时效果: 按下效果: selector代码: <?xml version="1.0" encoding="utf-8"?> <selec ...
 - 【Android进阶学习】shape和selector的结合使用(转)
		
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://liangruijun.blog.51cto.com/3061169/732310 ...
 - Android开发教程:shape和selector的结合使用
		
shape和selector是Android UI设计中经常用到的,比如我们要自定义一个圆角Button,点击Button有些效果的变化,就要用到shape和selector.可以这样说,shape和 ...
 - android 开发:shape和selector和layer-list的(详细说明)
		
目录(?)[+] Shape 简介 使用的方法 属性 Selector 简介 使用的方法 layer-list 简介 例子 最后 <shape>和<selector>在An ...
 - shape和selector是Android UI设计中经常用到的
		
shape和selector是Android UI设计中经常用到的,比如我们要自定义一个圆角Button,点击Button有些效果的变化,就要用到shape和selector.可以这样说,shape和 ...
 - 【Android进阶学习】shape和selector的结合使用
		
shape和selector是Android UI设计中经常用到的,比如我们要自定义一个圆角Button,点击Button有些效果的变化,就要用到shape和selector.可以这样说,shape和 ...
 - android 开发 xml绘制shape与Selector与layer-list 一 基础篇
		
首先我们先来了解状态效果 android:state_pressed=["true" | "false"] 按下状态 android:state_focuse ...
 
随机推荐
- Augmented reality in natural scenes
			
Augmented reality in natural scenes (Iryna Gordon and David Lowe)2006年关于AR的研究成果 项目主页 http://www.cs.u ...
 - talib 中文文档(九):Volume Indicators 成交量指标
			
Volume Indicators 成交量指标 AD - Chaikin A/D Line 量价指标 函数名:AD 名称:Chaikin A/D Line 累积/派发线(Accumulation/Di ...
 - oracle(十二)redo 与 undo
			
1.undo:回滚未提交的事务.未提交前,内存不够用时,DBWR将脏数据写入数据文件中,以腾出内存空间. 这就是undo存在的原因. redo:恢复所有已提交的事务 2.实例失败(如主机掉电)可能出现 ...
 - uchome 不从缓存中读取模板
			
/source/function_common.php中的代码 //模板调用 function template($name) { global $_SCONFIG, $_SGLOBAL; if($_ ...
 - SQL Server简洁查询正在运行SQL(等待事件)
			
通常我们可以使用 sp_who2 我们希望更加简洁的信息,下面这个查询使用系统表sys.sysprocesses,以及sys.dm_exec_sql_text做OUTER APPLY. T-SQL是这 ...
 - 【开发者笔记】C#连接mysql问题记录
			
1.概述:C#在调用mysql.data.dll连接本地数据库时报错,连接远程Linux服务器上的mysql服务器正常 2.报错记录,当前连接字符串 <add key="dbStrin ...
 - makefile中ifeq与ifneq  dev/null和dev/zero简介  dd命令
			
ifeq语法是ifeq "<arg1>;" "<arg2>;" ,功能是比较参数“arg1”和“arg2”的值是否相同,相同时为1 i ...
 - 自动化测试中级篇——LazyAndroid UI自动化测试框架使用指南
			
原文地址https://blog.csdn.net/iamhuanggua/article/details/53104345 简介 一直以来,安卓UI自动化测试都存在以下两个障碍,一是测试工具Mo ...
 - OAuth 白话简明教程 4.刷新 Access Token
			
转自:http://www.cftea.com/c/2016/11/6705.asp OAuth 白话简明教程 1.简述 OAuth 白话简明教程 2.授权码模式(Authorization Code ...
 - js 中的[] {}是什么意思
			
<div id="aa1">aaaaa</div><div id="aa2">bbbb</div><div ...