这些只是自己测试的一些发现和理解做个记录,如果那里不对还请不吝赐教
onDraw()先于dispatchDraw()执行,用于本身控件的绘制,dispatchDraw()用于子控件的绘制
onDraw()绘制的内容可能会被子控件覆盖而dispatchDraw()是子控件的绘制,所以是覆盖在onDraw()上的
布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity">
<com.example.myviewpage.ViewPagerIndicator
android:layout_width="match_parent"
android:layout_height="50dp"
android:background="#999999"
android:id="@+id/main_vpi">
<TextView
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="标题1"
android:background="#f00"
android:gravity="center"/>
<TextView
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="标题2"
android:gravity="center"/>
<TextView
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="标题3"
android:gravity="center"/>
</com.example.myviewpage.ViewPagerIndicator>
<android.support.v4.view.ViewPager
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/mian_vp"/>
</LinearLayout>ViwPagerIndicator是继承自LinearLayout的自定义控件目的是绘制一个三角形的指示器
ViwPagerIndicator使用dispatchDraw():
@Override protected void dispatchDraw(Canvas canvas) { super.dispatchDraw(canvas); canvas.save(); canvas.translate(minitTrianslationX+mTrianslationX,getHeight()); canvas.drawPath(path,paint); canvas.restore(); Log.i(TAG, "dispatchDraw: "); }
效果:

ViwPagerIndicator使用dispatchDraw():
@Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); canvas.save(); canvas.translate(minitTrianslationX+mTrianslationX,getHeight()); canvas.drawPath(path,paint); canvas.restore(); Log.i(TAG, "onDraw: "); }
效果:

可以看出,这种情况是应该使用dispatchDraw()保证绘制的内容不被子控件覆盖
本文通过一个具体的自定义View示例,展示了Android中onDraw()与dispatchDraw()的区别及应用。onDraw()用于控件本身的绘制,而dispatchDraw()则负责子控件的绘制。文章强调了使用dispatchDraw()来确保自定义View的绘制不会被子控件覆盖。
427

被折叠的 条评论
为什么被折叠?



