Android UI效果之绘图篇(一)

作者:_Hi_xiaoyu 时间:2022-03-24 08:30:51 

最近准备整理一套关于UI效果的文章,算是对这段时间的一个总结,主要讲Android开发中的UI效果设计模块。初步分为一下几个篇幅:

  • Android XML绘图(Shape、Layer、Selector)

  • Android Canvas绘图(canvas、point、porterDuffXfermode、shader)

  • Android 动画详解

  • Android 自定义控件
     

今天就当开胃菜,先讲讲最简单的xml绘图,相信这个大家都用的比较熟,这里就当给大家做一个小文档,当那个参数配置忘了,便于查阅
一、Shape


<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
// 此处可以设置shape的形状 不设置默认为rectangle
android:shape=["rectangle"|"oval"|"line"|"ring"|]

>

<!-- 圆角 shape="rectangle"是使用 默认为1dp -->
 <corners
   android:radius="xdp"
   android:topLeftRadius="xdp"
   android:topRightRadius="xdp"
   android:bottomLeftRadius="xdp"
   android:bottomRightRadius="xdp"/>

<!-- 渐变 -->
 <gradient
   android:startColor="color"
   android:centerColor="color"
   android:endColor="color"
   android:useLevel="boolean"
   android:angle="integer"//angle的值必须是45的倍数(包括0),仅在type="linear"有效
   android:type=["linear"|"radial"|"sweep"]
   android:centerX="integer"
   android:centerY="integer"
   android:gradientRadius="integer"/>

<!-- 间隔 -->
 <padding
   android:left="xdp"
   android:top="xdp"
   android:right="xdp"
   android:bottom="xdp"/>

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

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

<!-- 描边 -->
 <stroke
   android:width="dp"
   android:color="color"
   android:dashWidth="dp" //虚线宽度
   android:dashGap="dp"/> //虚线间隔宽度

</shape>

二、Layer
这个用过photoshop的朋友,应该很好理解,用于实现图层效果


<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
 <!-- item1 -->
 <item>
  <bitmap android:src="drawable"
   android:gravity="center" />
 </item>
 <!-- item2 -->
 <item>
  <bitmap android:src="drawable"
   android:gravity="center" />
 </item>
 <!-- item3 -->
 <item
  <bitmap android:src="drawable"
   android:gravity="center" />
 </item>
</layer-list>

三、Selector
这个常用语Button、CheckBox、Radio等控件中,通过不同的事件切换控件效果


<?xml version="1.0" encoding="utf-8" ?>  
<selector xmlns:Android="http://schemas.android.com/apk/res/android">  
<!-- 默认时的背景图片-->  
<item Android:drawable="drawable" />  
<!-- 没有焦点时的背景图片 -->  
<item
 Android:state_window_focused="false"  
 android:drawable="drawable"
 />  
<!-- 非触摸模式下获得焦点并单击时的背景图片 -->  
<item
 Android:state_focused="true"
 android:state_pressed="true"  
 android:drawable= "drawable"
 />  
<!-- 触摸模式下单击时的背景图片-->  
<item
 Android:state_focused="false"
 Android:state_pressed="true"  
 Android:drawable="drawable"
 />  
<!--选中时的图片背景-->  
<item
 Android:state_selected="true"
 android:drawable="drawable"
 />  
<!--获得焦点时的图片背景-->  
<item
 Android:state_focused="true"
 Android:drawable="drawable"
 />  
</selector>
标签:Android,UI,绘图
0
投稿

猜你喜欢

  • SpringBoot使用jasypt加解密密码的实现方法(二)

    2021-10-15 14:16:46
  • 详解OAuth2 Token 一定要放在请求头中吗

    2022-05-01 09:43:15
  • Android编程开发之性能优化技巧总结

    2022-08-26 13:23:00
  • Android短信验证码自动填充功能

    2023-11-25 00:04:20
  • C# 禁用鼠标中间键的方法

    2022-01-24 04:17:24
  • java线程同步操作实例详解

    2023-11-13 14:19:08
  • Java字节码ByteBuddy使用及原理解析上

    2023-08-23 19:33:05
  • java实现学生成绩档案管理系统

    2023-06-29 22:48:43
  • WPF实现控件拖动的示例代码

    2023-04-01 09:36:15
  • Android控件实现图片缩放功能

    2022-06-10 15:59:27
  • Java 8新的时间日期库的20个使用示例

    2022-11-06 06:55:00
  • Java实现单例模式之饿汉式、懒汉式、枚举式

    2022-12-17 17:50:13
  • java 键盘输入一个数,输出数组中指定元素的示例

    2023-11-24 20:31:14
  • spring中12种@Transactional的失效场景(小结)

    2022-04-26 00:06:40
  • Unity 实现鼠标滑过UI时触发动画的操作

    2021-05-31 19:24:18
  • 解析Java线程同步锁的选择方法

    2023-02-08 11:02:32
  • Android开发手册SeekBar拖动条使用实例

    2022-02-21 13:59:45
  • java使用jacob实现word转pdf

    2023-05-12 11:45:33
  • C#实现文件上传与下载功能实例

    2022-11-18 07:59:03
  • C#特性-迭代器(上)及一些研究过程中的副产品

    2023-12-05 18:26:49
  • asp之家 软件编程 m.aspxhome.com