相关阅读:矢山代码阅读器
从onDraw向上找
android.view.ViewRootImpl.TraversalRunnable.run:::
android.view.ViewRootImpl.doTraversal:::
android.view.ViewRootImpl.performTraversals:::
android.view.ViewRootImpl.performDraw::SurfaceSyncGroup:
android.view.ViewRootImpl.draw::boolean,SurfaceSyncGroup,boolean:
android.view.ViewRootImpl.drawSoftware::Surface,View.AttachInfo,int,int,boolean,Rect,Rect:
android.view.View.draw::Canvas:
// recursion start
android.view.View.dispatchDraw::Canvas:
android.view.ViewGroup.dispatchDraw::Canvas:
android.view.ViewGroup.drawChild::Canvas,View,long:
android.view.View.draw::Canvas,ViewGroup,long:
android.view.View.draw::Canvas:
// recursion end
android.view.View.onDraw::Canvas:
TraversalRunnable继承自Runnbale,只有一个实例:ViewRootImpl.mTraversalRunnable,那么下一步就是搜索数据流动
android.view.ViewRootImpl.mTraversalRunnable
android.view.Choreographer.postCallback::int,Runnable,Object:action
android.view.Choreographer.postCallbackDelayed::int,Runnable,Object,long:action
android.view.Choreographer.postCallbackDelayedInternal::int,Object,Object,long:action
android.view.Choreographer.CallbackQueue.addCallbackLocked::long,Object,Object:action
android.view.Choreographer.obtainCallbackLocked::long,Object,Object:return#
android.view.Choreographer.CallbackQueue.mHead
android.view.Choreographer.CallbackQueue.extractDueCallbacksLocked::long:return
// 在android.view.Choreographer.doCallbacks::int,long:中使用
接下来搜索包含doCallbacks的调用栈
android.view.Choreographer.postCallback::int,Runnable,Object:
android.view.Choreographer.postCallbackDelayed::int,Runnable,Object,long:
android.view.Choreographer.postCallbackDelayedInternal::int,Object,Object,long:
android.view.Choreographer.scheduleFrameLocked::long:
android.os.Handler.sendMessageAtTime::Message,long:
// android.view.Choreographer.MSG_DO_SCHEDULE_VSYNC
android.view.Choreographer.FrameHandler.handleMessage::Message:
android.view.Choreographer.doScheduleVsync:::
android.view.Choreographer.scheduleVsyncLocked:::
android.view.DisplayEventReceiver.scheduleVsync:::
android.view.DisplayEventReceiver.nativeScheduleVsync::long:
// Called from native code.
android.view.DisplayEventReceiver.dispatchVsync::long,long,int:
android.view.DisplayEventReceiver.onVsync::long,long,int,DisplayEventReceiver.VsyncEventData:
android.view.Choreographer.FrameDisplayEventReceiver.onVsync::long,long,int,DisplayEventReceiver.VsyncEventData:
android.os.Handler.sendMessageAtTime::Message,long:
// message callback
android.view.Choreographer.FrameDisplayEventReceiver.run:::
android.view.Choreographer.doFrame::long,int,DisplayEventReceiver.VsyncEventData:
android.view.Choreographer.doCallbacks::int,long:
android.view.Choreographer.CallbackRecord.run::Choreographer.FrameData:
android.view.Choreographer.CallbackRecord.run::long:
java.lang.Runnable.run:::
// ViewRootImpl.mTraversalRunnable 被执行了