Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了

这篇具有很好参考价值的文章主要介绍了Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

/**

  • 1. 绘制椭圆
    */
    canvas.drawOval(RectF(100f,500f,600f,800f),mPaint)

/**

  • 2. 绘制圆
    */
    mPaint.setColor(Color.YELLOW)
    mPaint.alpha = 100
    canvas.drawCircle(400f,400f,200f,mPaint)
绘制 Bitmap

//
val bitmap = BitmapFactory.decodeResource(context.resources, R.mipmap.gild_3)
//第二个,第三个参数代表起点位置
canvas.drawBitmap(bitmap,100f,100f,mPaint)

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

绘制 Text

//1.
void drawText(@NonNull char[] text, int index, int count, float x, float y,
@NonNull Paint paint)
//2.
void drawText(@NonNull String text, float x, float y, @NonNull Paint paint)
//3.
void drawText(@NonNull String text, int start, int end, float x, float y,
@NonNull Paint paint)
//4.
void drawText(@NonNull CharSequence text, int start, int end, float x, float y,
@NonNull Paint paint)

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

/**

  • 取 0 ~ 5 位置的 text 进行绘制
    */
    mPaint.textSize = 100f
    canvas.drawText(charArrayOf(‘1’,‘2’,‘3’,‘4’,‘5’),0,5,200f,200f,mPaint)

/**

*/
canvas.drawText(“12345”,300f,300f,mPaint)

/**

  • 3.取 0 ~ 5 位置的 text 进行绘制
    */
    canvas.drawText(“12345”,0,5,400f,400f,mPaint)
根据路径绘制 Text

//从 hOffset 向外偏移 vOffset px 来绘制 text
void drawTextOnPath(@NonNull String text, @NonNull Path path, float hOffset,
float vOffset, @NonNull Paint paint)
复制代码

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

mPaint.setColor(Color.GREEN)
mPaint.alpha = 100

mPaint.textSize = 100f
var path = Path()
//1. 设置起始点
path.moveTo(300f, 300f)
//2. 第二条线的起点就是moveTo 设置的启动
path.lineTo(300f,500f)
//3. 第三条线的起点就是第二条的终点,依次类推
path.lineTo(500f,800f)
path.lineTo(800f,200f)
//4. 闭合
path.close()
canvas.drawPath(path,mPaint)
//从0偏移100px的像素
canvas.drawTextOnPath(“12345asodnaspdnfpoashfeuinfapjn”,path,0f,100f,mPaint)

绘制 弧/扇形

//1.
void drawArc(@NonNull RectF oval, float startAngle, float sweepAngle, boolean useCenter,
@NonNull Paint paint)
//2.
void drawArc(float left, float top, float right, float bottom, float startAngle,
float sweepAngle, boolean useCenter, @NonNull Paint paint)

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

var rectF = RectF(100f, 100f, 500f, 500f)
/**

  • 1. 绘制弧
  • @param ovar : 矩形坐标
  • @param startAngle : 开始的角度
  • @param sweepAngle : 结束的角度
  • @param userCenter : 如果为true,则将椭圆的中心包括在圆弧中
  • @param paint : 画笔
    */
    canvas.drawArc(rectF, 0f, 90f, true, mPaint)

/**

  • 2. 绘制弧
    */
    canvas.drawArc(100f,500f,500f,900f,0f,90f,false,mPaint)
绘制圆角矩形

//1.
void drawRoundRect(@NonNull RectF rect, float rx, float ry, @NonNull Paint paint)
//2.
void drawRoundRect(float left, float top, float right, float bottom, float rx, float ry,
@NonNull Paint paint)

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

/**

  • 1. 根据 RectF 绘制圆角矩形
  • @param rx: x 轴上的圆角半径
  • @param ry: y 轴上的圆角半径
    /
    canvas.drawRoundRect(rectF,50f,50f,mPaint)
    /
    *
  • 2. 根据输入矩形位置绘制圆角矩形
    */
    canvas.drawRoundRect(100f,600f,500f,900f,100f,100f,mPaint)
Canvas 变换
translate - 图层平移

//dx/dy:x/y 点新位置
void translate(float dx, float dy)

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

scale- 图层缩小 0~1

//x,y 缩小系数 0~1 之间 越大说明越接近原始图像
void scale(float sx, float sy)
复制代码

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

/**

  • 1. 原始矩形
    */
    mPaint.color = Color.RED
    mPaint.alpha = 100
    canvas.drawRoundRect(rectF,50f,50f,mPaint)

/**

  • 2.将原始图形缩小 0.5 倍
    */
    var rectF2 = RectF(100f, 100f, 500f, 500f)
    mPaint.color = Color.BLUE
    mPaint.alpha = 100
    canvas.scale(0.5f,0.5f)
    canvas.drawRoundRect(rectF2,50f,50f,mPaint)
rotate - 图层旋转

//1.
void rotate(float degrees)
//2.
void rotate(float degrees, float px, float py)

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

/**

  • 1. 原始矩形
    */
    mPaint.color = Color.RED
    mPaint.alpha = 100
    canvas.drawRoundRect(rectF,50f,50f,mPaint)

/**

  • 2.将原始图形旋转 45°
    */
    mPaint.color = Color.BLUE
    mPaint.alpha = 100
    canvas.rotate(45f)
    canvas.drawRoundRect(rectF,50f,50f,mPaint)

/**

  • 3.将原始图形旋转 280°
  • 以 坐标点 500,100 顺时针旋转 280°
    */
    mPaint.color = Color.YELLOW
    mPaint.alpha = 100
    canvas.rotate(280f,500f,100f)
    canvas.drawRoundRect(rectF,50f,50f,mPaint)
skew - 图层错切

//错切是在某方向上,按照一定的比例对图形的每个点到某条平行于该方向的直线的有向距离做放缩得到的平面图形。水平错切(或平行于X轴的错切)是一个将任一点(x,y)映射到点(x+my,y)的操作,m是固定参数,称为错切因子
//sx和sy分就是错切因子,为倾斜角度tan值,这里倾斜45度值为1
void skew (float sx, float sy)

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

/**

  • 1. 原始图形
    /
    mPaint.color = Color.RED
    mPaint.alpha = 100
    canvas.drawRoundRect(rectF,50f,50f,mPaint)
    /
    *
  • 2.图层开始错切
    */
    canvas.skew(0f,0.5f)
    mPaint.color = Color.BLUE
    mPaint.alpha = 100
    canvas.drawRoundRect(rectF,50f,50f,mPaint)
Matrix

api详细使用

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

/**

  • 原始图形
    /
    canvas.drawBitmap(mBitmap,100f,100f,mPaint)
    /
    *
    *1. 矩阵平移 500,500
    */
    var matrix = Matrix()
    matrix.setTranslate(500f,500f)
    canvas.drawBitmap(mBitmap,matrix,mPaint)

/**

  • 2. 矩阵缩放 0.5 倍
    */
    var matrix2 = Matrix()
    matrix2.setScale(0.5f,0.5f)
    canvas.drawBitmap(mBitmap,matrix2,mPaint)

/**

  • 3. 矩阵旋转 125°
    */
    var matrix3 = Matrix()
    matrix3.setRotate(125f,500f,500f)
    canvas.drawBitmap(mBitmap,matrix3,mPaint)

/**

  • 4. 错切
    */
    var matrix4 = Matrix()
    matrix4.setSkew(0.5f,0.5f)
    canvas.drawBitmap(mBitmap,matrix4,mPaint)
裁剪画布

//裁剪
boolean clipRect(RectF rect, Region.Op op);
boolean clipRect(Rect rect, Region.Op op);
boolean clipRect(RectF rect);
boolean clipRect(Rect rect);
boolean clipRect(float left, float top, float right, float bottom, Region.Op op);
boolean clipRect(float left, float top, float right, float bottom);
boolean clipRect(int left, int top, int right, int bottom);
boolean clipPath(Path path, Region.Op op);
boolean clipPath(Path path);
boolean clipRegion(Region region, Region.Op op);
boolean clipRegion(Region region);

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

上图中的 1 代表原始的图层,未被裁剪;2 代表已经裁剪了的图层;3,不管怎么绘制只能在该区域内部绘制。

/**

  • 1. 原始图形
    /
    mPaint.color = Color.RED
    mPaint.alpha = 100
    canvas.drawRect(300f,300f,700f,700f,mPaint)
    canvas.drawText(“1.原始”,400f,600f,Paint(Paint.ANTI_ALIAS_FLAG).also {
    it.textSize = 100f
    it.color = Color.WHITE
    })
    /
    *
  • 2. 在 RectF 矩形区域裁剪一块画布,绘制图形只能在该区域中绘制
    */
    var rectf2 = RectF(100f, 100f , 500f, 500f);
    canvas.clipRect(rectf2)
    mPaint.color = Color.BLUE
    mPaint.alpha = 100
    canvas.drawColor(mPaint.color)
    canvas.drawText(“2.clip”,200f,200f,Paint(Paint.ANTI_ALIAS_FLAG).also {
    it.textSize = 100f
    it.color = Color.WHITE
    })

/**

  • 3. 在 300,300;700,700 坐标点上绘制矩形
    */
    mPaint.color = Color.YELLOW
    mPaint.alpha = 100
    canvas.drawRect(300f,300f,700f,700f,mPaint)
    canvas.drawText(“3.裁剪之后”,350f,400f,Paint(Paint.ANTI_ALIAS_FLAG).also {
    it.textSize = 30f
    it.color = Color.WHITE
    })
画布的保存与恢复

save 和 restore 一般成对的出现,save 可以保存 canvas 当前的状态,随后进行平移,裁剪等一系列改变 canvas的操作,最后使用 restore 将 canvas 还原成 save 时候的状态。

int save() //每次调用该函数,都会保存当前画布状态,将其放入特定的栈中
void restore() //从栈顶去除这个状态,对画布进行恢复

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

通过在未裁剪的时候先调用 canvas.save 保存图层,裁剪完之后在调用 canvas.restore 来恢复之前的图层

/**

  • 1. 原始图形
    /
    mPaint.color = Color.RED
    mPaint.alpha = 100
    canvas.drawRect(300f,300f,700f,700f,mPaint)
    canvas.drawText(“1.原始”,400f,600f,Paint(Paint.ANTI_ALIAS_FLAG).also {
    it.textSize = 100f
    it.color = Color.WHITE
    })
    /
    *
  • 2. 在 RectF 矩形区域裁剪一块画布,绘制图形只能在该区域中绘制
    */
    var rectf2 = RectF(100f, 100f , 500f, 500f);
    //将未裁剪的图层先进行保存
    canvas.save()
    canvas.clipRect(rectf2)
    mPaint.color = Color.BLUE
    mPaint.alpha = 100
    canvas.drawColor(mPaint.color)
    canvas.drawText(“2.clip”,200f,200f,Paint(Paint.ANTI_ALIAS_FLAG).also {
    it.textSize = 100f
    it.color = Color.WHITE
    })

/**

  • 3. 在 300,300;700,700 坐标点上绘制矩形
    */
    //裁剪完之后出栈
    canvas.restore()
    mPaint.color = Color.YELLOW
    mPaint.alpha = 100
    canvas.drawRect(300f,300f,600f,600f,mPaint)
    canvas.drawText(“3.裁剪之后”,350f,400f,Paint(Paint.ANTI_ALIAS_FLAG).also {
    it.textSize = 30f
    it.color = Color.WHITE
    })
Canvas 与图层

上一小节介绍了 save,restore 可以用来保存图层,下面在来介绍几个 API 同样也可以用于保存图层

//bounds:要保存的区域所对应的举行对象
//saveFlags:取值 ALL_SAVE_FLAG 表示保存全部内容
public int saveLayer(RectF bounds,Paint paint,int saveFlags)
public int saveLayer(float left,float top,float right,float bottom,Paint paint,int saveFlags)

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

上图的意思是绘制一个以红色的裁剪区域,然后在绘制一个圆可看图中注释 2 ,发现只能在裁剪区域绘制了,但是如果调用 canvas.restoreToCount 之后在绘制,就不会受影响了可看图中注释 3 区域。

/**

  • 1. 原始图像
    /
    mPaint.color = Color.RED
    mPaint.alpha = 200
    canvas.drawRect(300f,300f,1000f,1000f,mPaint)
    canvas.drawText(“1. 裁剪图层”,750f,750f,Paint(Paint.ANTI_ALIAS_FLAG).also {
    it.textSize = 30f
    it.color = Color.WHITE
    })
    /
    *
  • 2. 保存
    */
    val saveLayer = canvas.saveLayer(300f, 300f, 1000f, 1000f, mPaint,ALL_SAVE_FLAG)
    mPaint.color = Color.BLUE
    mPaint.alpha = 100
    canvas.drawCircle(500f,500f,300f,mPaint)
    canvas.drawText(“2. 绘制圆”,350f,700f,Paint(Paint.ANTI_ALIAS_FLAG).also {
    it.textSize = 30f
    it.color = Color.WHITE
    })

/**

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui
Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui
Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui
Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

最后

总而言之,Android开发行业变化太快,作为技术人员就要保持终生学习的态度,让学习力成为核心竞争力,所谓“活到老学到老”只有不断的学习,不断的提升自己,才能跟紧行业的步伐,才能不被时代所淘汰。

在这里我分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司19年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。需要的朋友可以私信我【资料】或者 点这里 免费领取

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了,Android程序员,android,ui

还有高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。 领取地址: Android学习PDF+架构视频+最新面试文档+源码笔记文章来源地址https://www.toymoban.com/news/detail-844092.html

在这里我分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司19年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。需要的朋友可以私信我【资料】或者 点这里 免费领取

[外链图片转存中…(img-0itK2jg7-1710506226394)]

[外链图片转存中…(img-0SsS1hkt-1710506226394)]

[外链图片转存中…(img-RVywJF5w-1710506226395)]

还有高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。 领取地址: Android学习PDF+架构视频+最新面试文档+源码笔记

到了这里,关于Android-高级-UI-进阶之路-(五)-看完该篇文章-Canvas-你应该会了的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Android-高级-UI-进阶之路-(七)-SVG-基础使用-+-绘制中国地图,Android面试中常问的MMAP到底是啥东东

    iv.setImageDrawable(animatedVectorDrawable) val animatable = iv.drawable as Animatable animatable.start() } } 输入搜索动画 利用在线绘制 SVG 图标网站 制作搜索图标 可以自己随意捣鼓绘制,绘制好了之后点击视图-源代码,将 SVG 代码复制出来保存成 search_svg.xml 在线转换 svg2vector 点击空白或者直接将

    2024年04月25日
    浏览(25)
  • ai绘画如何使用?看完这篇文章你就知道了

    对于艺术家和创作者来说,AI绘画可以作为一种实用的工具,提供灵感和创意的源泉。它可以分析和学习大量的艺术作品,从中汲取元素和风格,并以独特的方式重新组合和表达。这使得艺术家能够更快速地探索和实验不同的艺术风格,从而推动他们的创造力和艺术表达的边

    2024年02月09日
    浏览(26)
  • 看完这篇文章,保你学会C语言switch case 语句

    我的个人主页: ☆光之梦☆的博客_CSDN博客-C语言基础语法(超详细)领域博主 欢迎各位 👍点赞 ⭐收藏 📝评论 特别标注 :本博主将会长期更新c语言的语法知识,初学c语言的朋友们,可以收藏订阅一下我的专栏: C语言基础语法(超详细)_☆光之梦☆的博客-CSDN博客 (这

    2023年04月26日
    浏览(24)
  • ai绘画生成方法有哪些?看完这篇文章你就知道了

    近年来,随着人工智能技术的不断发展和普及,AI 绘画作为一种新兴的艺术创作方式也逐渐被人们所认知。与传统绘画相比,AI 绘画可以通过计算机算法自动生成,具有高效、便捷的特点,同时也能够更好地满足一些特定场景的需求。 在过去,数字艺术家需要通过绘制、建模

    2024年02月15日
    浏览(29)
  • 软件测试拿到项目之后该怎么做?请仔细看完这篇文章

    学习软件测试最关键的就是项目实战,如果说我们单纯的学了很多的软件测试理论基础或者很多工具和技术的话,但是没有项目实战去演练,那么面试还是被淘汰。 为了解决大家这样的问题,我搭建在自己的阿里云服务器上,其实就和你们企业自己部署在你们自己服务器上完

    2024年02月14日
    浏览(24)
  • 看完这篇文章,才发现我的测试用例写的就是垃圾

    测试用例编写作为测试技能最基础的一个能力,大家应该或多或少都有自己写用例的习惯和思考方式,这里分享一些需求分析和编写用例的经验,主要针对功能测试,旨在尽量降低测试遗漏的可能性,而对于新同学来说,则希望可以达到入门的效果。最后会分享一个小工具,

    2024年02月15日
    浏览(23)
  • Python常用基础语法知识点大全合集,看完这一篇文章就够了

    Python 是一门独特的语言,快速浏览一下他的要点: 面向对象:每一个变量都是一个类,有其自己的属性(attribute)与方法(method)。 语法块:用缩进(四个空格)而不是分号、花括号等符号来标记。因此,行首的空格不能随意书写。 注释:行内用“#”号,行间注释写在两

    2023年04月22日
    浏览(34)
  • 在工作中怎么保持稳定的情绪?看完这篇文章一定对你有帮助!!

    近期发生的新闻热点再度引发公众对稳定情绪和心理健康的关注。有时候我们遇到的最大的敌人,不是运气也不是能力,而是失控的情绪和口无遮拦的自己。如何在工作中保持稳定的情绪? 目录 一.什么是情绪? 二.在工作中怎么调节情绪? 三.怎么在工作中保持一个愉快的心

    2024年02月12日
    浏览(31)
  • 怎么用ai绘画二次元拍同款?看完这篇文章你就懂了

    在我们的二次元世界里,每一张优质的插图都能够引发无尽的想象和瞬间的心动。而现如今,随着人工智能技术的飞速发展,ai绘画已经成为一个备受瞩目的领域。在使用ai绘画生成二次元作品时,ai绘画二次元描述词就显得相当重要。那么,究竟ai绘画二次元描述词怎么写呢

    2024年02月16日
    浏览(25)
  • RabbitMQ如何保证消息可靠性,看完这篇文章佬会有新的理解

    前言:大家好,我是小威,24届毕业生,在一家满意的公司实习。本篇文章将详细介绍RabbitMQ的消息可靠性机制,如消息丢失,消息重复性消费,消息积压等问题。 如果文章有什么需要改进的地方还请大佬不吝赐教 👏👏。 小威在此先感谢各位大佬啦~~🤞🤞 🏠个人主页:小

    2024年02月03日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包