Android自定义控件之基本图形绘制
入门示例代码
在Android中Paint类就是画笔,Canvas 就是画布
对于画笔的大小,粗细,颜色,透明度都在paint类中设置,对于画出的成品,比如圆,方形,等在canvas类中的函数生成
入门案例:
package com.loaderman.customviewdemo.paint; import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.View;
public class BasisView extends View {
public BasisView(Context context) {
super(context);
} public BasisView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
} public BasisView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
} @Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
Paint paint = new Paint();//画笔
paint.setColor(Color.RED);//设置颜色
paint.setStyle(Paint.Style.STROKE); // 填充样式//Paint.Style.FILL填充内部 Paint.Style.FILL_AND_STROKE 填充内部和描边 Paint.Style.STROKE 仅描边
paint.setStrokeWidth(50);//描边宽度值
canvas.drawCircle(190,200,150,paint);//绘制圆
}
}
画笔的基本设置
- setColor(int color)设置画笔颜色
参数color由0xAARRGGBB 组成 ,A代表透明度,R代表红色值,G代表绿色值,B代表蓝色值
- setStyle(tStyle style)设置填充样式
参数styl取值如下:
- Paint.Style.FILL 填充内部
- Paint.Style.FILL_AND_STROKE 填充内部和描边
- Paint.Style.STROKE 仅描边
- setStrokeWidth(float width)
width参数单位是px,当画笔的样式不为FILl时有效
- setAntiAlias(boolean aa)
是否打开抗锯齿功能,一般在绘制不规则的图形中使用,比如圆文字等,在绘制菱角分明的图形中是不需要开启的
canvas基本使用
画布背景设置
drawColor(int color)
drawARGB(int a, int r, int g, int b)
drawRGB(int r, int g, int b)
画一条直线
drawLine(float startX, float startY, float stopX, float stopY, Paint paint)
//画一条直线
如 canvas.drawLine(100,100,200,200,paint);
注意:画直线的错写和画布的style是没有关系
画多条直线
drawLines(float[] pts, Paint paint)
//pts是点的集合,这里不是形成连接线,而是每两个点形成两条直线,ps的组织方式为{x1,y1,x2,y2,x3,y3.....}
//如:
float[] pts ={10,10,100,100,200,200,400,400};
canvas.drawLines(pts,paint);//效果是两条直线
drawLines(float[] pts, int offset, int count, Paint paint)
//如:
float[] pts ={10,10,100,100,200,200,400,400};
canvas.drawLines(pts,2,4,paint);
//表示从pts数据中索引问的数组开始绘制,有4个数组参与绘图,也就是点100,100 和点200,200 效果就是这两个点的直线
画点
drawPoint(float x, float y, Paint paint) //点x代表x坐标 y代表点y坐标
//如:
canvas.drawPoint(100,100,paint);
画多个点
drawPoints(float[] pts, Paint paint)
drawPoints(float[] pts, int offset, int count, Paint paint)
//说明:pts为点的集合 offset指集合中跳过数值的个数,不是点的个数,点的个数有二个数值
//如:
float[] pts ={10,10,100,100,200,200,400,400};
canvas.drawPoints(pts,paint);
canvas.drawPoints(pts,2,4,paint);
画矩形
Rect构造函数
Rect()
Rect(int left, int top, int right, int bottom)
Rect(Rect r)
RectF构造函数
public RectF()
public RectF(float left, float top, float right, float bottom)
public RectF(RectF r)
public RectF(Rect r)
其实这两个构造函数基本相同只是参数的数据类型不同而已
构造矩形结构一般如下
//直接构造
canvas.drawRect(10, 10, 100, 100, paint);
//间接构造
Rect rect = new Rect();
rect.set(10,10,100,100)
绘制矩形
public void drawRect(RectF rect, Paint paint)
public void drawRect(Rect r, Paint paint)
public void drawRect(float left, float top, float right, float bottom, Paint paint)
绘制圆角矩形
drawRoundRect(RectF rect, float rx, float ry, Paint paint)
drawRoundRect(float left, float top, float right, float bottom, float rx, float ry, Paint paint)
//其中rx代表x轴的圆角半径,ry代表y轴的圆角半径
绘制圆形
drawCircle(float cx, float cy, float radius, Paint paint)//cx代表x轴坐标,cy代表y轴坐标,radius代表圆的半径
//如
canvas.drawCircle(200,200,100,paint);
绘制椭圆
RectF rectF = new RectF(100,10,300,100);
canvas.drawOval(rectF,paint);
绘制弧
drawArc(RectF oval, float startAngle, float sweepAngle, boolean useCenter, Paint paint)
drawArc(float left, float top, float right, float bottom, float startAngle, float sweepAngle, boolean useCenter, Paint paint)
说明:
startAngle 代表弧开始的角度
sweepAngle 弧持续的角度
useCenter 是否有弧的两边,为true则有,false只有一条
color
android 定义了很多常量的颜色值可以直接使用
public static final int BLACK = -16777216;
public static final int BLUE = -16776961;
public static final int CYAN = -16711681;
public static final int DKGRAY = -12303292;
public static final int GRAY = -7829368;
public static final int GREEN = -16711936;
public static final int LTGRAY = -3355444;
public static final int MAGENTA = -65281;
public static final int RED = -65536;
public static final int TRANSPARENT = 0;
public static final int WHITE = -1;
public static final int YELLOW = -256;
上面可以通过Color.XXX来直接使用这些颜色
还有其他构造颜色
public static int alpha(int color)) //提取颜色分量
public static int red(int color) ) //提取颜色分量
public static int green(int color)) //提取颜色分量
public static int blue(int color) //提取颜色分量
public static int rgb(int red, int green, int blue) //不带有透明度颜色
public static int rgb(float red, float green, float blue) //不带有透明度颜色
public static int argb(int alpha, int red, int green, int blue) //带有透明度颜色
public static int argb(float alpha, float red, float green, float blue) //带有透明度颜色
Android自定义控件之基本图形绘制的更多相关文章
- 自定义控件之Canvas图形绘制基础练习-青春痘笑脸^_^
对于自定义控件的意义不言而喻,所以对它的深入研究是很有必要的,前些年写过几篇关于UI效果的学习过程,但是中途比较懒一直就停滞了,而对于实际工作还是面试来说系统深入的了解自定义控件那是很有必要的,所以接 ...
- Android自定义控件7--自定义开关--绘制界面内容
本文实现全自定义控件--自定义开关 本文地址:http://www.cnblogs.com/wuyudong/p/5922316.html,转载请注明源地址. 自定义开关 (View),本文完成下面内 ...
- Android 利用SurfaceView进行图形绘制
SurfaceView使用介绍 SurfaceView是View的一个特殊子类,它的目的是另外提供一个线程进行绘制操作. 要使用SurfaceView进行绘制,步骤如下: 1.用SurfaceView ...
- Android 4.0的图形硬件加速及绘制技巧
转:http://zuiniuwang.blog.51cto.com/3709988/721798 从Android 3.0开始,Android 2D的绘制流程就设计为能够更好地支持硬件加速.使用GP ...
- Android自定义控件:图形报表的实现(折线图、曲线图、动态曲线图)(View与SurfaceView分别实现图表控件)
图形报表很常用,因为展示数据比较直观,常见的形式有很多,如:折线图.柱形图.饼图.雷达图.股票图.还有一些3D效果的图表等. Android中也有不少第三方图表库,但是很难兼容各种各样的需求. 如果第 ...
- Android OpenGL ES 开发:绘制图形
OpenGL 绘制图形步骤 上一篇介绍了 OpenGL 的相关概念,今天来实际操作,使用 OpenGL 绘制出图形,对其过程有一个初步的了解. OpenGL 绘制图形主要概括成以下几个步骤: 创建程序 ...
- Android自定义控件
开发自定义控件的步骤: 1.了解View的工作原理 2. 编写继承自View的子类 3. 为自定义View类增加属性 4. 绘制控件 5. 响应用户消息 6 .自定义回调函数 一.Vie ...
- [Android自定义控件] Android自定义控件
转载自:http://blog.163.com/ppy2790@126/blog/static/103242241201382210910473/ 开发自定义控件的步骤: 1.了解View的工作原理 ...
- 【转】Android自定义控件
原文网址:http://blog.163.com/ppy2790@126/blog/static/103242241201382210910473/ 开发自定义控件的步骤: 1.了解View的工作原理 ...
随机推荐
- GC案例
FGC----jmap -histo:live导致 线上某服务的老年代配置了CMS,但却在gc.log发现连续Full GC的问题.JVM参数配置如下: -XX:+UseCMSInitiatingOc ...
- 转:IDEA中如何使用debug调试项目 一步一步详细教程
原文链接:http://www.yxlzone.top/show_blog_details_by_id?id=2bf6fd4688e44a7eb560f8db233ef5f7 在现在的开发中,我们经常 ...
- 《数据结构与算法之美》 <04>链表(上):如何实现LRU缓存淘汰算法?
今天我们来聊聊“链表(Linked list)”这个数据结构.学习链表有什么用呢?为了回答这个问题,我们先来讨论一个经典的链表应用场景,那就是 LRU 缓存淘汰算法. 缓存是一种提高数据读取性能的技术 ...
- Python使用selenium模拟点击(一)
本文适合有点Python基础阅读,(没基础的话,相对的比较蒙蔽,争取能让小白能一步一步跟上来) 2019-03-05 14:53:05 前几天由于需要到一个网站进行签到~~听说Python能够模拟请求 ...
- Ubuntu系统---开机总会显示错误报告处理
Ubuntu系统---开机总会显示错误报告处理 使用ubuntu16.04,开机总会显示错误报告,略烦人,查找方法关闭.一.临时关闭sudo service apport stop(重启后失效) 二. ...
- Git学习笔记08-远程仓库
因为想在家里和公司都能用到一套代码,所以选择上传到github,记录一下使用经验. 需要安装git,和注册github 以下操作是第一次将自己的代码上传到GitHub上 1)创建github项目 1. ...
- python学习之模块(pip),列表生成式,模块操作mysql,excel
python基础 生成式 列表生成式 格式 [表达式 for 表达式 in 迭代对象 (可加判断)] 原: res1 = [] for i in range(1,5): res1.append(i) ...
- 多线程锁:Mutex互斥体,Semaphore信号量,Monitor监视器,lock,原子操作InterLocked
Mutex类 “mutex”是术语“互相排斥(mutually exclusive)”的简写形式,也就是互斥量.互斥量跟临界区中提到的Monitor很相似,只有拥有互斥对象的线程才具有访问资源的权限, ...
- 配置文件的属性ENC加密
转载:https://www.cnblogs.com/zqyx/p/9687136.html 在micro service体系中,有了config server,我们可以把配置存放在git.svn.数 ...
- Mysql 高可用集群PXC
PXC是percona公司的percona xtraDB cluster,简称PXC.它是基于Galera协议的高可用集群方案.可以实现多个节点间的数据同步复制以及读写,并且可保障数据库的服务高可 ...