Android之自定义View学习(一)

Canvas常用方法:

                                   图片来源

/**
* Created by SiberiaDante on 2017/6/3.
*/ public class BaseViewDraw extends View {
private Paint mPaint1;
private Paint mPaint2;
private Paint mPaint3;
private Paint mPaint4; public BaseViewDraw(Context context) {
super(context);
} public BaseViewDraw(Context context, AttributeSet attrs) {
super(context, attrs);
initPaint();//初始化画笔
} public BaseViewDraw(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
} private void initPaint() {
mPaint1 = new Paint();
mPaint1.setColor(Color.BLUE);//设置画笔颜色
mPaint1.setStrokeWidth(10f);//设置画笔宽度
mPaint1.setStyle(Paint.Style.FILL);//设置画笔填充模式 mPaint2 = new Paint();
mPaint2.setColor(Color.RED);
mPaint2.setStrokeWidth(20f);
mPaint2.setStyle(Paint.Style.FILL_AND_STROKE); mPaint3 = new Paint();
mPaint3.setColor(Color.BLACK);
mPaint3.setStrokeWidth(15f);
mPaint3.setStyle(Paint.Style.STROKE); mPaint4 = new Paint();
mPaint4.setColor(Color.GREEN);
mPaint4.setStrokeWidth(5f);
mPaint4.setStyle(Paint.Style.STROKE);
} @Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
/**
* 画颜色
* 了解更多canvas前往官方文档:https://developer.android.com/reference/android/graphics/Canvas.html
*/
canvas.drawColor(Color.GRAY);
/**
* 画点
*/
canvas.drawPoint(200, 200, mPaint1);//画一个点----200,200分别代表在想,x,y轴上的坐标
canvas.drawPoints(
new float[]{//画多个点
300, 300,
300, 400,
300, 500
}, mPaint1);
/**
* 画线条
*/
canvas.drawLine(10, 10, 200, 500, mPaint1);//10,10代表起点,200,500代表终点
canvas.drawLines(new float[]{//画多条线段
20, 20, 600, 20,
50, 200, 50, 600}, mPaint1); /**
* 画矩形,三种写法
* 了解更多 Rect前往官方文档:https://developer.android.com/reference/android/graphics/Rect.html
* 了解更多 RectF前往官方文档:http://developer.android.com/reference/android/graphics/RectF.html
*/
//第一种
canvas.drawRect(500, 100, 800, 400, mPaint1);
//第二种
final Rect rect = new Rect(500, 500, 800, 800);
canvas.drawRect(rect, mPaint1);
//第三种
final RectF rectF = new RectF(500, 900, 800, 1200);
canvas.drawRect(rectF, mPaint1);
/**
* 绘制圆角矩形
*/
//方法一
final RectF rectF1 = new RectF(100, 900, 400, 1200);
//10,30分别代表圆弧的半径
canvas.drawRoundRect(rectF1, 10, 30, mPaint2);
//方法二
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
//这种写法仅支持API21+
canvas.drawRoundRect(100, 900, 400, 1200, 10, 30, mPaint2);
} /**
* 画椭圆
* 350为矩形x轴长度的一半
* 150为矩形y轴长度的一半
*/
final RectF rectF2 = new RectF(100, 500, 800, 800);
canvas.drawRoundRect(rectF2, 350, 150, mPaint3); /**
* 画圆
* 350为矩形x轴长度的一半
* 350为矩形y轴长度的一半
* 当矩形的长和宽相等时,即为圆
*/
//方法一:利用矩形绘制椭圆技巧
final RectF rectF3 = new RectF(100, 500, 800, 1200);
canvas.drawRoundRect(rectF3, 350, 350, mPaint3);
//方法二:550,800代表圆心位置,400代表圆半径
canvas.drawCircle(550, 800, 400, mPaint3); /**
* 画圆弧
* 0,90分别代表弧度的起始和结束弧度,顺时针为正,区分数学中的逆时针为正
* 第三个Boolean型参数:true为使用中心点,false为不使用中心点,即为一段弧线(不填充状态下)
*/
final RectF rectF4 = new RectF(400, 400, 800, 1200);
canvas.drawArc(rectF4, 0, 90, true, mPaint4); final RectF rectF5 = new RectF(100, 400, 400, 1200);
canvas.drawArc(rectF5, 0, 90, false, mPaint4); }
}

github地址:https://github.com/SiberiaDante/DrawView

Android之自定义View学习(一)的更多相关文章

  1. Android读取自定义View属性

    Android读取自定义View属性 attrs.xml : <?xml version="1.0" encoding="utf-8"?> < ...

  2. Android 自己定义View学习(2)

    上一篇学习了基本使用方法,今天学一下略微复杂一点的.先看一下效果图 为了完毕上面的效果还是要用到上一期开头的四步 1,属性应该要有颜色,要有速度 <?xml version="1.0& ...

  3. 简单说说Android自定义view学习推荐的方式

    这几天比较受关注,挺开心的,嘿嘿. 这里给大家总结一下学习自定义view的一些技巧.  以后写自定义view可能不会写博客了,但是可以开源的我会把源码丢到github上我的地址:https://git ...

  4. Android自定义View学习(四)

    硬件加速 参考:HenCoder Android 自定义 View 1-8 硬件加速 硬件加速能够让绘制变快,主要有三个原因: 本来由 CPU 自己来做的事,分摊给了 GPU 一部分,自然可以提高效率 ...

  5. Android自定义View学习(二)

    绘制顺序 参考:HenCoder Android 开发进阶:自定义 View 1-5 绘制顺序 绘制过程 包括 背景 主体(onDraw()) 子 View(dispatchDraw()) 滑动边缘渐 ...

  6. Android自定义View学习笔记(一)

    绘制基础 参考:HenCoder Android 开发进阶: 自定义 View 1-1 绘制基础 Paint详解 参考:HenCoder Android 开发进阶: 自定义 View 1-2 Pain ...

  7. Android之自定义View的实现

    对于学习Android开发的小童鞋对于自定义View一定不会陌生,相信大家对它是又爱又恨,爱它可以跟随我们的心意设计出漂亮的效果:恨它想要完全流畅掌握,需要一定的功夫.对于初学者来说确实很不容易,网上 ...

  8. 20170831工作日记--自定义View学习

    学习了LayoutInflater的原理分析.视图的绘制流程.视图的状态及重绘等知识,按类型来划分的话,自定义View的实现方式大概可以分为三种,自绘控件.组合控件.以及继承控件.那么下面我们就来依次 ...

  9. android开发:Android 中自定义View的应用

    大家好我们今天的教程是在Android 教程中自定义View 的学习,对于初学着来说,他们习惯了Android 传统的页面布局方式,如下代码: <?xml version="1.0&q ...

随机推荐

  1. 关于Quartus+Modelsim 门级仿真 Warning (vopt-2216) Cannot find instance 'NA' specified in sdf.的解决办法

    本文操作环境:Win 7 32位系统, Quartus II 11.1 ,Modelsim SE 10.1a 在Quartus II中调用Modelsim SE做Gate Level Simulait ...

  2. 【FJOI2016】建筑师

    安利另外一篇\(blog\) 密码泥萌都知道 题面 题解 为了描述方便,这里将建筑称作\(zsy\) 高度为\(n\)的\(zsy\)无论如何都能从左右两侧看到.剩下的部分,从左边看到的是前缀\(ma ...

  3. CF1111E Tree 树链剖分,DP

    CF1111E Tree 过年了,洛咕还没爬这次的题,先放个CF的链接吧. 补个LG传送门. 对于每个询问点\(x\),设它的祖先即不能和它放在同一个集合中的点的个数为\(f[x]\),设\(dp[i ...

  4. 提高你的Python编码效率的“武林秘籍”

    我用Python编程有几年了, 并且我仍然经常惊讶于Python代码可以如何的简洁,如何的 DRY . 我学到了很多小贴士和技巧,大多数来自于阅读开源项目的源代码,像Django, Flask, Re ...

  5. vs2019编译redis

    版本信息 使用Redis源码版本,解压工程右键生成hiredis项目正常,编译Win32_Interop项目报下图错误(error C2039:system_error:不是std成员;error C ...

  6. 自动化运维工具saltstack04 -- 之jinja模板

    jinjia模板 需求:想让saltstack的file模块分发到minion端的配置文件监听minion端的IP和端口,如何用变量实现?看下面!! 1.jinja模板加grains使apache监听 ...

  7. 快速稀疏角点光流框架(Fast sparse corner optical flow framework)

    光流适用在连续的图像系列(视频流)中,描述本身或画面目标的运动状态:在目标跟踪.运动分析.甚至slam中都有广泛应用. opencv里就有不少光流算法,其中很经典也是当前被调用最多的的Lucas-Ka ...

  8. Java线程wait和sleep的区别

    Java中调用wait方法或者sleep方法都可以让线程进入waitint或者time-waiting状态,但是它们还是 有所不同的: wait是Object中的方法,而sleep则是Thread中的 ...

  9. appium 元素定位方法汇总

    以上图为例,要定位到右下角的 我的 ,并点击 # appium的webdriver提供了11种元素定位方法,在selenium的基础上扩展了三个,可以在pycharm里面输入driver.find_e ...

  10. HPCMS V9使用ajax方式提交表单

    一.前台模板(注:需要引入jquery文件) <form id="myform" class="subscribe-form subscription" ...