博客
关于我
Android自定义View基础之onDraw详解
阅读量:692 次
发布时间:2019-03-17

本文共 1006 字,大约阅读时间需要 3 分钟。

View 绘制过程详解

绘制一个优质的Android View看似简单,却包含了许多复杂的逻辑流程。了解这些流程,能够帮助开发者更好地优化自己的ViewComponent。

在分析了onMeasure和onLayout之后,接下来我们来深入理解onDraw方法,了解这是怎么将View及其子View绘制到屏幕上的。


onDraw方法的核心逻辑

onDraw方法的主要作用是将View绘制到屏幕上。从源码来看,绘制过程分为以下几个关键步骤:

  • 绘制背景:如果View未标记为"脏"(dirty),则会调用drawBackground(canvas)方法绘制背景。

  • 绘制内容:如果View未标记为"脏"且没有顶部或底部的渐变边缘,直接调用onDraw(canvas)。

  • 绘制子View:调用dispatchDraw(canvas)方法,这会递归调用所有子View的draw方法。

  • 绘制装饰:调用onDrawScrollBars(canvas)方法绘制滚动条。

  • 处理渐变边缘:如果有垂直或水平的渐变边缘,则会稍后进行处理。


  • View绘制事件的传递

    View的绘制事件通过dispatchDraw方法传递。这个方法会自动调用所有子View的绘制方法,从而实现层层递进的绘制流程。这种设计使得每个View都能独立处理绘制逻辑,同时避免了紧耦合控制逻辑。


    setWillNotDraw 方法的作用

    setWillNotDraw方法用于标记一个View是否需要自己绘制内容。如果标记为true,系统会对绘制过程进行优化。需要注意的是:

    • View默认不会启用这个标记位。
    • ViewGroup默认会启用这个标记位。
    • 如果一个自定义ViewGroup不需要自行绘制内容,可以启用这个标记位以进行优化。

    当开发者知道ViewGroup需要通过onDraw绘制内容时,必须在前期通过setWillNotDraw(false)将标记位关闭。


    综合优化

    在实际开发中,可以通过以下方法优化View的绘制效率:

  • 谨慎使用setWillNotDraw:只有确定View不需要自行绘制的场景下,才启用此标记位。
  • 确保onDraw和dispatchDraw的逻辑高效:避免在onDraw中执行重复操作或直接绘制图形。
  • 调优背景绘制:如果不需要自定义背景,可以利用系统默认的绘制优化。
  • 通过以上优化,可以有效提升View的绘制性能,进一步提升用户体验。

    转载地址:http://bgxhz.baihongyu.com/

    你可能感兴趣的文章
    npm node pm2相关问题
    查看>>
    npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
    查看>>
    npm run build报Cannot find module错误的解决方法
    查看>>
    npm run build部署到云服务器中的Nginx(图文配置)
    查看>>
    npm run dev 和npm dev、npm run start和npm start、npm run serve和npm serve等的区别
    查看>>
    npm run dev 报错PS ‘vite‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。
    查看>>
    npm scripts 使用指南
    查看>>
    npm should be run outside of the node repl, in your normal shell
    查看>>
    npm start运行了什么
    查看>>
    npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
    查看>>
    npm 下载依赖慢的解决方案(亲测有效)
    查看>>
    npm 安装依赖过程中报错:Error: Can‘t find Python executable “python“, you can set the PYTHON env variable
    查看>>
    npm.taobao.org 淘宝 npm 镜像证书过期?这样解决!
    查看>>
    npm—小记
    查看>>
    npm上传自己的项目
    查看>>
    npm介绍以及常用命令
    查看>>
    NPM使用前设置和升级
    查看>>
    npm入门,这篇就够了
    查看>>
    npm切换到淘宝源
    查看>>
    npm切换源淘宝源的两种方法
    查看>>