自定义view里面的onDraw方法,在这里我们可以绘制各种图形,onDraw里面有两个API我们需要了解清楚他们的用法:Canvas 和 Paint.

Canvas翻译成中文就是画布的意思,Canvas负责进行绘制各种各样的图形,它有如下的一些绘制图形方法:

  • drawArc 绘制弧

  • drawBitmap 绘制位图

  • drawCircle 绘制圆形

  • drawLine 绘制线

  • drawOval 绘制椭圆

  • drawPath 绘制路径

  • drawPoint 绘制一个点

  • drawPoints 绘制多个点

  • drawRect 绘制矩形

  • drawRoundRect 绘制圆角矩形

  • drawText 绘制字符串

  • drawTextOnPath 沿着路径绘制字符串

更多的绘制方法参考:https://developer.android.com/reference/android/graphics/Canvas.html.

Paint翻译成中文有油漆涂料的意思,Paint主要负责设置绘图的风格,包括画笔的颜色,粗细,填充风格等,它有如下的一些设置方法:

  • setARGB/setColor 设置颜色

  • setAlpha 设置透明度

  • setAntiAlias 设置是否抗锯齿

  • setShader 设置画笔的填充效果

  • setShadowLayer 设置阴影

  • setStyle 设置画笔风格

  • setStrokeWidth 设置空心边框的宽度

  • setTextSize 设置绘制文本时文字的大小

  • setStrokeCap(Paint.Cap.ROUND) 设置为圆角

更多的设置方法参考:https://developer.android.com/reference/android/graphics/Paint.html

绘制圆形:drawCircle(float cx, float cy, float radius, Paint paint)

cx: 圆心的x坐标 
cy: 圆心的y坐标 
radius: 圆的半径 
paint: 绘制风格

@Override
protected void onDraw(Canvas canvas) {
   super.onDraw(canvas);
   Paint paint=new Paint();
   //去锯齿
   paint.setAntiAlias(true);
   //设置颜色
   paint.setColor(getResources().getColor(android.R.color.holo_blue_light));
   //绘制普通圆
   canvas.drawCircle(200,200,100,paint);
   //设置空心Style
   paint.setStyle(Paint.Style.STROKE);
   //设置空心边框的宽度
   paint.setStrokeWidth(20);
   //绘制空心圆
   canvas.drawCircle(200,500,90,paint);
}

绘制矩形:drawRect(float left, float top, float right, float bottom, Paint paint) / drawRect(RectF rect, Paint paint)

left: 矩形left的x坐标 
top: 矩形top的y坐标 
right: 矩形right的x坐标 
bottom: 矩形bottom的y坐标 
paint: 绘制风格

@Override
protected void onDraw(Canvas canvas) {
   super.onDraw(canvas);
   Paint paint = new Paint();
   //去锯齿
   paint.setAntiAlias(true);
   //设置颜色
   paint.setColor(getResources().getColor(android.R.color.holo_blue_light));
   //绘制正方形
   canvas.drawRect(100, 100, 300, 300, paint);
   //上面代码等同于
   //RectF rel=new RectF(100,100,300,300);
   //canvas.drawRect(rel, paint);    //设置空心Style
   paint.setStyle(Paint.Style.STROKE);
   //设置空心边框的宽度
   paint.setStrokeWidth(20);
   //绘制空心矩形
   canvas.drawRect(100, 400, 600, 800, paint);
}

绘制圆角矩形:drawRoundRect(float left, float top, float right, float bottom, float rx, float ry, Paint paint) / drawRoundRect(RectF rect, float rx, float ry, Paint paint)

left: 图形left的x坐标 
top: 图形top的y坐标 
right: 图形right的x坐标 
bottom: 图形bottom的y坐标 
rx: x方向的圆角半径 
ry: y方向的圆角半径 
paint > 绘制风格

@Override
protected void onDraw(Canvas canvas) {
   super.onDraw(canvas);
   Paint paint = new Paint();
   //去锯齿
   paint.setAntiAlias(true);
   //设置颜色
   paint.setColor(getResources().getColor(android.R.color.holo_blue_light));
   //绘制圆角矩形
   canvas.drawRoundRect(100, 100, 300, 300, 30, 30, paint);
   //上面代码等同于
   //RectF rel=new RectF(100,100,300,300);
   //canvas.drawRoundRect(rel,30,30,paint);
   //设置空心Style
   paint.setStyle(Paint.Style.STROKE);
   //设置空心边框的宽度
   paint.setStrokeWidth(20);
   //绘制空心圆角矩形
   canvas.drawRoundRect(100, 400, 600, 800, 30, 30, paint);
}

绘制椭圆:drawOval(float left, float top, float right, float bottom, Paint paint)

left: 图形left的x坐标 
top: 图形top的y坐标 
right: 图形right的x坐标 
bottom: 图形bottom的y坐标 
paint: 绘制风格

@Override
protected void onDraw(Canvas canvas) {
   super.onDraw(canvas);
   Paint paint = new Paint();
   //去锯齿
   paint.setAntiAlias(true);
   //设置颜色
   paint.setColor(getResources().getColor(android.R.color.holo_orange_dark));
   //绘制椭圆
   canvas.drawOval(100, 100, 500, 300, paint);
   //设置空心Style
   paint.setStyle(Paint.Style.STROKE);
   //设置空心边框的宽度
   paint.setStrokeWidth(20);
   //绘制空心椭圆
   canvas.drawOval(100, 400, 600, 800, paint);
}

绘制弧:drawArc(RectF oval, float startAngle, float sweepAngle, boolean useCenter, Paint paint)

oval: 指定圆弧的外轮廓矩形区域 
startAngle: 圆弧起始角度,单位为度 
sweepAngle: 圆弧扫过的角度,顺时针方向,单位为度 
useCenter: 如果为True时,在绘制圆弧时将圆心包括在内,通常用来绘制扇形 
paint: 绘制风格

@Override
protected void onDraw(Canvas canvas) {
   super.onDraw(canvas);
   Paint paint = new Paint();
   //去锯齿
   paint.setAntiAlias(true);
   //设置颜色
   paint.setColor(getResources().getColor(android.R.color.holo_orange_dark));
   RectF rel = new RectF(100, 100, 300, 300); 
// 设置为圆角   paint .setStrokeCap(Paint.Cap.ROUND);
     //实心圆弧
   canvas.drawArc(rel, 0, 270, false, paint);
   //实心圆弧 将圆心包含在内
   RectF rel2 = new RectF(100, 400, 300, 600);
   canvas.drawArc(rel2, 0, 270, true, paint);
   //设置空心Style
   paint.setStyle(Paint.Style.STROKE);
   paint.setStrokeWidth(20);
   RectF rel3 = new RectF(100, 700, 300, 900);
   canvas.drawArc(rel3, 0, 270, false, paint);
   RectF rel4 = new RectF(100, 1000, 300, 1200);
   canvas.drawArc(rel4, 0, 270, true, paint);
}

绘制文字:drawText(String text, float x, float y, Paint paint)

text: 文本 
x: 文本origin的x坐标 
y: 文本baseline的y坐标 
paint: 绘制风格

@Override
protected void onDraw(Canvas canvas) {
   super.onDraw(canvas);
   Paint paint = new Paint();
   //去锯齿
   paint.setAntiAlias(true);
   //设置颜色
   paint.setColor(getResources().getColor(android.R.color.holo_orange_dark));
   paint.setTextSize(100);
   //绘制文本
   canvas.drawText("jEh", 80, 150, paint);
}
 

Android为TV端助力 Canvas 和 Paint用法的更多相关文章

  1. Android为TV端助力 转载:Android绘图Canvas十八般武器之Shader详解及实战篇(上)

    前言 Android中绘图离不开的就是Canvas了,Canvas是一个庞大的知识体系,有Java层的,也有jni层深入到Framework.Canvas有许多的知识内容,构建了一个武器库一般,所谓十 ...

  2. Android为TV端助力 转载:Android绘图Canvas十八般武器之Shader详解及实战篇(下)

    LinearGradient 线性渐变渲染器 LinearGradient中文翻译过来就是线性渐变的意思.线性渐变通俗来讲就是给起点设置一个颜色值如#faf84d,终点设置一个颜色值如#CC423C, ...

  3. Android为TV端助力:自定义view之太阳

    先看效果图 package com.hhzt.iptv.lvb_w8.view; import android.content.Context;import android.graphics.Canv ...

  4. Android为TV端助力 转载:android自定义view实战(温度控制表)!

    效果图 package cn.ljuns.temperature.view; import com.example.mvp.R; import android.content.Context;impo ...

  5. Android为TV端助力 转载:RecyclerView分页加载

    package com.android.ryane.pulltoloaddata_recyclerview; import android.os.Handler;import android.os.L ...

  6. Android为TV端助力(转载)

    作者地址http://www.jianshu.com/u/63915ef020e2 针对Android Tv的自定义RecyclerView 作者 wenju_song 关注 2016.12.09 1 ...

  7. Android为TV端助力 不需要Socket的跨进程推送消息AIDL!

    上篇介绍了跨进程实时通讯http://www.cnblogs.com/xiaoxiaing/p/5818161.html 但是他有个缺点就是服务端无法推送消息给客户端,今天这篇文章主要说的就是服务器推 ...

  8. Android为TV端助力之Webview与JS双向交互

    package com.hhzt.iptv.adservice; import android.app.Activity;import android.graphics.Bitmap;import a ...

  9. Android为TV端助力之WebView开发踩坑一

    在Android清单配置文件里面 自定义application时,在4.4系统上面不能加上一个属性,见下图 否则界面将不会显示任何数据,在更高或者更低的系统上面没有测试!

随机推荐

  1. python列表(list)的简单学习

    列表是由一系列按特定顺序排列的元素组成, 是 Python 中使用最频繁的数据类型.列表可以完成大多数集合类的数据结构实现.列表中元素的类型可以不相同,它支持数字,字符串甚至可以包含列表.字典(即嵌套 ...

  2. OS之进程管理---多线程模型和线程库(POSIX PTread)

    多线程简介 线程是CPU使用的基本单元,包括线程ID,程序计数器.寄存器组.各自的堆栈等,在相同线程组中,所有线程共享进程代码段,数据段和其他系统资源. 传统的的单线程模式是每一个进程只能单个控制线程 ...

  3. 【ABP框架系列学习】介绍篇(1)

      0.引言 该系列博文主要在[官方文档]及[tkbSimplest]ABP框架理论研究系列博文的基础上进行总结的,或许大家会质问,别人都已经翻译过了,这不是多此一举吗?原因如下: 1.[tkbSim ...

  4. odoo开发笔记 -- self详解

    python中一切皆对象! odoo基于python开发,那么odoo中也可以理解成一切皆对象. 我们在python中定义类的时候,一般会用到self,用来表示当前对象自己. 那么odoo中的self ...

  5. Java核心技术及面试指南 IO部分的面试题归纳以及答案

    4.6.1 java中有几种类型的流? Java中的流分为两种,一种是字节流,另一种是字符流,分别由四个抽象类来表示(每种流包括输入和输出两种所以一共四个):InputStream,OutputStr ...

  6. 刷完500道BAT面试题,我能去面试大厂了吗?

    面试之前先刷几篇面经,或者做几道热门面试题,想必是大家很熟悉的一种复习方式了,就像我们当年经常做五年高考三年模拟一样.但是可不要把面试题和面经当成你的主要复习方式,它只是锦上添花,绝非雪中送炭! 壹面 ...

  7. 一个前端开发者换电脑的过程(IDE篇)

    一台全新的电脑,需要做出怎样的改变,才可以摇身一变成为前端开发者能用的电脑呢.首先,我们需要安装一个编辑器,这里我们选择目前最火的vscode. 先去到它的官网,把对应版本的vscode下载下来. 然 ...

  8. 项目详解4—haproxy 反向代理负载均衡

    一.企业服务架构图及负载均衡的要求 1.场景说明 在企业生产环境中,每天会有很多的需求变更,比如增加服务器.新业务上线.url路由修改.域名配置等等,对于前端负载均衡设备来说,容易维护,复杂度低,是首 ...

  9. Pytorch1.0入门实战一:LeNet神经网络实现 MNIST手写数字识别

    记得第一次接触手写数字识别数据集还在学习TensorFlow,各种sess.run(),头都绕晕了.自从接触pytorch以来,一直想写点什么.曾经在2017年5月,Andrej Karpathy发表 ...

  10. Spring Cloud Stream如何消费自己生产的消息?

    在上一篇<Spring Cloud Stream如何处理消息重复消费>中,我们通过消费组的配置解决了多实例部署情况下消息重复消费这一入门时的常见问题.本文将继续说说在另外一个被经常问到的问 ...