博客
关于我
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/

    你可能感兴趣的文章
    oracle 课堂笔记
    查看>>
    Oracle 返回结果集的 存储过程
    查看>>
    Oracle 递归
    查看>>
    Oracle 递归函数与拼接
    查看>>
    oracle 逻辑优化,提升高度,综合SQL上下文进行逻辑优化
    查看>>
    oracle 闪回关闭,关闭闪回即disable flashback的操作步骤
    查看>>
    oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
    查看>>
    oracle--用户,权限,角色的管理
    查看>>
    Oracle-定时任务-JOB
    查看>>
    oracle.dataaccess 连接池,asp.net使用Oracle.DataAccess.dll连接Oracle
    查看>>
    oracle00205报错,Oracle控制文件损坏报错场景
    查看>>
    Oracle10g EM乱码之快速解决
    查看>>
    Oracle10g下载地址--多平台下的32位和64位
    查看>>
    Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
    查看>>
    oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
    查看>>
    Oracle11G基本操作
    查看>>
    Oracle11g服务详细介绍及哪些服务是必须开启的?
    查看>>
    Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
    查看>>
    oracle12安装软件后安装数据库,然后需要自己配置监听
    查看>>
    Oracle——08PL/SQL简介,基本程序结构和语句
    查看>>