前言:  

  自定义控件必需的两个类:Paint与Canvas

  Paint    ---  相当于绘图的"笔"

  Canvas --- 相当于绘图的"纸"

  

一、Paint  

  绘图笔,即用来设定比如 颜色、线条宽度、线条透明度等熟悉的。

  看一下Paint类所有的setXX() 方法

  

  

  其中常用的:

  • paint.setAntiAlias(true);//抗锯齿功能
  • paint.setColor(Color.RED);  //设置画笔颜色
  • paint.setStyle(Style.FILL);//设置填充样式
  • paint.setStrokeWidth(10);//设置画笔宽度 ,单位px
  • paint.setShadowLayer(10, 15, 15, Color.GREEN);//设置阴影

  这里简单介绍下 第3个、第5个 方法的属性

  1、paint.setStyle(Style.XXX); //设置填充样式

  

  Style.FILL ,即 画笔填充 ,比如你要画一个矩形,那么这个矩形内部是填充了的

  

  Style.STROKE ,即画笔画出的只有边框,

  

  Style.FILL_AND_STROKE ,即边框线条和内部填充都有

  

 

  2、paint.setShadowLayer(10, 15, 15, Color.GREEN);//设置阴影

    

   (1)、radius(角度),即阴影的倾斜角度,

     (2)、dx ,即阴影x方向偏移量

   (3)、dy ,即阴影y方向偏移量

     (4)、shadowColor ,即阴影的颜色

  

二、Canvas

  画布、纸。

  Canvas类的主要方法是drawXXX() , 即 画线条,画圆形,画矩形,画文字,画椭圆 等等

  

三、实践

  我们写几个例子,用Paint控制画笔的线条宽度,颜色等属性

          用Canvas控制画出的形状

 首先自定义一个类继承自 View 类 重写三个构造方法

  

 重写onDraw()方法,该方法用于绘制自定义控件

  1.   @Override
  2. protected void onDraw(Canvas canvas) {
  3. super.onDraw(canvas);
  4.  
  5. // 设置画笔的属性
  6. paint = new Paint();
  7. paint.setStyle(Paint.Style.FILL);
  8. paint.setColor(Color.RED);
  9. paint.setStrokeWidth(); //单位px
  10. paint.setTextSize(); //设置文本大小
  11.  
  12. // 设置画布的属性 ,注意这里onDraw()方法参数有Canvas对象了 不要在 new 一个了
  13. canvas.drawRGB(, ,);
  14. canvas.drawLine(,,,,paint); //画一条从坐标(200,200) 到 坐标(600,200) 颜色为红色的 横向直线
  15. canvas.drawRect(,,,,paint); //画一条左上角坐标(200,420) ,宽度400 高度100的 红色实心矩形
  16. canvas.drawCircle(,,,paint); //画一条圆心坐标(400,800) 半径100 的红色实心圆形
  17. canvas.drawText("这是画出来的文本",,,paint); //画一条左侧开始坐标(200,1000)的文本
  18.  
  19. }

 

  在activity中使用

  

效果图:

自定义控件详解(一):Paint类与Canvas类的更多相关文章

  1. 自定义控件详解(三):Canvas效果变换

    Canvas 画布 从前面我们已经知道了 Canvas 类可以绘出 各种形状. 这里学习一下Canvas 类的变换效果(平移,旋转等) 首先需要了解一下Canvas 画布, 我们用Canvas.Dra ...

  2. 自定义控件详解(二):Path类 相关用法

    Path:路径 绘制路径:void drawPath (Path path, Paint paint) Path 可以绘制的路径 一.直线路径 1.基本方法 void moveTo (float st ...

  3. 《Android群英传》读书笔记 (2) 第三章 控件架构与自定义控件详解 + 第四章 ListView使用技巧 + 第五章 Scroll分析

    第三章 Android控件架构与自定义控件详解 1.Android控件架构下图是UI界面架构图,每个Activity都有一个Window对象,通常是由PhoneWindow类来实现的.PhoneWin ...

  4. WindowsPhone自定义控件详解(二) - 模板类库分析

    转自:http://blog.csdn.net/mr_raptor/article/details/7251948 WindowsPhone自定义控件详解(一) - 控件类库分析 上一节主要分析了控件 ...

  5. 自定义控件详解(四):Paint 画笔路径效果

    Paint  画笔 ,即用来绘制图形的"笔" 前面我们知道了Paint的一些基本用法: paint.setAntiAlias(true);//抗锯齿功能 paint.setColo ...

  6. 自定义控件详解(六):Paint 画笔MaskFilter过滤

    首先看一个API:setMaskFilter(MaskFilter maskfilter): 设置MaskFilter,可以用不同的MaskFilter实现滤镜的效果,如滤化,立体等. 以下有两个Ma ...

  7. WindowsPhone自定义控件详解(一) - 控件类库分析

    转自:http://blog.csdn.net/mr_raptor/article/details/7251942 为了让你的应用程序更有个性,我们通常会在WP7开发过程中会自定义自己风格的控件,自定 ...

  8. 安卓中Paint类和Canvas类的方法汇总

    Paint类的常用的方法 1.setColor方法,用于设置画笔的颜色,public void setColor(int color)//参数color为颜色值,也可以使用Color类定义的颜色Col ...

  9. Android 控件架构与自定义控件详解

    架构: PhoneWindow 将一个 DecorView 设置为整个应用窗口的根 View,这里面所有 View 的监听事件,都通过 WindowManagerService 来接收.DecorVi ...

随机推荐

  1. moment.js 学习笔记

    一.安装 / 使用 npm install moment 注:使用版本为 2.22.2 var moment = require('moment'); moment().format(); // 20 ...

  2. Python集成开发工具Pycharm的使用方法:复制,撤销上一步....

    复制行,在代码行光标后,输入Ctrl + d ,即为复制一行,输入多次即为复制多行 撤销上一步操作:Ctrl + z 为多行代码加注释#  代码选中的条件下,同时按住 Ctrl+/,被选中行被注释,再 ...

  3. 记Booking.com iOS开发岗位线上笔试

    今晚参加了Booking的iOS职位线上笔试,结束后方能简单归纳一下. 关于测试内容: Booking采用了HackerRank作为测试平台,测试总时长为75分钟,总计4道题. 测试之前我很紧张,因为 ...

  4. 在浏览器中输入www.baidu.com后执行的全部过程

    1.客户端浏览器通过DNS解析到www.baidu.com 的IP地址220.181.27.48,通过这个IP地址找到客户端到服务器的路径.客户端浏览器发起一个HTTP会话到220.181.27.48 ...

  5. Linux学习笔记之五————Linux常用命令之用户、权限管理

    一.引言 用户是Unix/Linux系统工作中重要的一环,用户管理包括用户与组账号的管理. 在Unix/Linux系统中,不论是由本机或是远程登录系统,每个系统都必须拥有一个账号,并且对于不同的系统资 ...

  6. Django--分页器(paginator)

    1 Django的分页器(paginator)简介 在页面显示分页数据,需要用到Django分页器组件 from django.core.paginator import Paginator Pagi ...

  7. Spring Boot - 修改Tomcat默认的8080端口

    前言 默认情况下,Spring Boot内置的Tomcat服务会使用8080端口启动,我们可以使用以下任何技巧去更改默认的Tomcat端口: 注:我们可以通过server.port=0配置,去自动配置 ...

  8. 如何发布一个npm包(基于vue)

    前言:工作的时候总是使用别人的npm包,然而我有时心底会好奇自己如何发布一个npm包呢,什么时候自己的包能够被很多人喜欢并使用呢...今天我终于迈出了第一步. 前提:会使用 npm,有 vue 基础, ...

  9. CEF C++环境搭建

    第一步:下载CEF 到这里下载最新版本的CEF http://cefbuilds.com/ 下载解压之后,大概会看到如下图所示的文件 cefclient:是一个比较复杂的示例代码cefsimple:是 ...

  10. h5活动页开发总结记录

    前几天在做h5活动页面的时候,有这样一个需求 上面的活动排行点击查看历史排行数据,弹出日期选择框,如下图 点击要查看的日期排行数据,这里需要对还没到的日期做处理,让用户不能选择,只可选择今天或者之前的 ...