juz*_*ode 1 lifecycle android view android-activity
android中有两个生命周期,一个是Activity生命周期,一个是View LifeCycle,但是View LifeCycle在Activity生命周期的哪个阶段启动?从 View Lifecycle 开始的那一刻起,它是一直贯穿整个生命周期还是在 Activity Lifecycle 的各个部分完成?(如果是这样,那么请说明在哪些部分调用了哪些方法)
特此是一个不是 100% 的官方图表,它是我从官方活动生命周期图和视图生命周期中混合而成的,因为我在 android 文档中没有看到任何关于视图生命周期的图表(以防我们称之为生命周期)循环)。
所以,在图中,橙色箭头是根据以下演示应用程序的观察添加的,仅用于演示两个生命周期的关系;在那里我创建了一个虚拟自定义TextView并记录了它的超类生命周期方法以及它的持有活动生命周期方法;并相应地添加橙色箭头。
因此,如图中所示,活动由它创建,onCreate()并且在活动的布局由 膨胀之后setContentView(),系统调用布局视图的构造函数以构建它们。
现在刚刚创建了活动并构建了视图的实例;屏幕上仍然看不到任何东西;然后分别调用活动的onStart(), &onResume()方法,因此活动现在在屏幕上可见;仍然没有绘制任何内容。
然后,当活动的窗口附加到窗口管理器时,活动的窗口被onAttachedToWindow()调用,向要在活动上绘制的底层视图发出绿灯。
此时,Activity 的生命周期被视为处于 running/active 状态。在活动的 之后onAttachedToWindow(),当视图onAttachedToWindow()附加到活动的窗口时被调用,现在视图可以开始在屏幕上绘制。
在屏幕上绘制视图通过一系列调用来确定一些测量值,如大小和属性;宽度、高度、颜色、文本、填充等内容。这需要调用measure()几次;随后onMeasure()被称为
最终,onDraw()调用具有作为绘制视图的目标表面的画布参数。
您可以找到图中描绘的其余绘图相关方法,您可以在此处深入了解它们。
当使用 销毁活动时onDestroy(),在活动的主窗口与窗口管理器分离之前,底层视图将首先趁机与活动的窗口分离;当它到位时,onDetachedFromWindow()调用视图来声明它从屏幕上移除,因此活动现在可以从窗口管理器中分离出来;当这种情况发生时,活动onDetachedFromWindow()将被相应地调用。
因此,除非首先将所有视图与窗口分离,否则活动不会与窗口管理器分离。
因此,视图上没有类似的东西onDestroy(),视图可以从活动的窗口附加或分离;你可以检查这个答案。此外onDetachedFromWindow(),视图与它们的活动高度耦合onDestroy(),如果活动onStop()被调用,视图仍然附加到活动的窗口。
所以,没有这样的事情我们可以称之为视图被销毁,但视图是分离的。
另请注意,onAttachedToWindow()活动和视图的 与活动的非常耦合onCreate();所以当onRestart()活动的 被调用时,活动及其视图已经与窗口相关联,所以 onAttachedToWindow()没有被调用(这在图中不太清楚)。
同样,onDetachedFromWindow()of views & activity 仅与onDestroy(); 所以当活动暂停或停止时,onDetachedFromWindow()不会调用,因此视图仍然附加到窗口。
您还可以使用parentLayout.removeView(customView);和观察回调。
下面是用于进行此观察的演示示例
布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical">
<com.example.android.androidxtest.CustomTextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/long_text"
android:textSize="22sp" />
</LinearLayout>
Run Code Online (Sandbox Code Playgroud)
活动
public class LifeCycleActivity extends AppCompatActivity {
private static final String TAG = "LOG_TAG_ACTIVITY";
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.d(TAG, "onCreate: ");
setContentView(R.layout.activity_view_lifecycle);
Log.d(TAG, "onCreate: after setContentView()");
}
@Override
protected void onPause() {
super.onPause();
Log.d(TAG, "onPause: ");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.d(TAG, "onDestroy: ");
}
@Override
protected void onResume() {
super.onResume();
Log.d(TAG, "onResume: ");
}
@Override
protected void onStop() {
super.onStop();
Log.d(TAG, "onStop: ");
}
@Override
protected void onStart() {
super.onStart();
Log.d(TAG, "onStart: ");
}
@Override
protected void onRestart() {
super.onRestart();
Log.d(TAG, "onRestart: ");
}
@Override
public void onAttachedToWindow() {
super.onAttachedToWindow();
Log.d(TAG, "onAttachedToWindow: ");
}
@Override
public boolean isDestroyed() {
Log.d(TAG, "isDestroyed: ");
return super.isDestroyed();
}
@Override
public void onDetachedFromWindow() {
super.onDetachedFromWindow();
Log.d(TAG, "onDetachedFromWindow: ");
}
}
Run Code Online (Sandbox Code Playgroud)
自定义视图
public class CustomTextView extends TextView {
private static final String TAG = "LOG_TAG_VIEW";
public CustomTextView(Context context) {
super(context);
Log.d(TAG, "CustomTextView: Constructor");
}
public CustomTextView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
Log.d(TAG, "CustomTextView: Constructor");
}
public CustomTextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
Log.d(TAG, "CustomTextView: Constructor");
}
public CustomTextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
Log.d(TAG, "CustomTextView: Constructor");
}
@Override
protected void onAttachedToWindow() {
super.onAttachedToWindow();
Log.d(TAG, "onAttachedToWindow: ");
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
Log.d(TAG, "onMeasure: ");
}
@Override
public void layout(int l, int t, int r, int b) {
super.layout(l, t, r, b);
Log.d(TAG, "layout: ");
}
@Override
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
super.onLayout(changed, left, top, right, bottom);
Log.d(TAG, "onLayout: ");
}
@Override
protected void dispatchDraw(Canvas canvas) {
super.dispatchDraw(canvas);
Log.d(TAG, "dispatchDraw: ");
}
@Override
public void draw(Canvas canvas) {
super.draw(canvas);
Log.d(TAG, "draw: ");
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
Log.d(TAG, "onDraw: ");
}
@Override
protected void onDetachedFromWindow() {
super.onDetachedFromWindow();
Log.d(TAG, "onDetachedFromWindow: ");
}
}
Run Code Online (Sandbox Code Playgroud)
登录应用程序启动
2020-02-25 14:09:41.859 2043-2043/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onCreate:
2020-02-25 14:09:41.945 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: CustomTextView: Constructor
2020-02-25 14:09:41.945 2043-2043/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onCreate: after setContentView()
2020-02-25 14:09:41.947 2043-2043/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onStart:
2020-02-25 14:09:41.954 2043-2043/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onResume:
2020-02-25 14:09:41.984 2043-2043/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onAttachedToWindow:
2020-02-25 14:09:41.985 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onAttachedToWindow:
2020-02-25 14:09:41.993 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onMeasure:
2020-02-25 14:09:42.005 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onMeasure:
2020-02-25 14:09:42.006 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onLayout:
2020-02-25 14:09:42.006 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: layout:
2020-02-25 14:09:42.032 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onDraw:
2020-02-25 14:09:42.032 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: dispatchDraw:
2020-02-25 14:09:42.032 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: draw:
Run Code Online (Sandbox Code Playgroud)
登录菜单按钮(应用程序的历史记录)
2020-02-25 13:44:44.462 32357-32357/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onPause:
2020-02-25 13:44:44.511 32357-32357/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onStop:
Run Code Online (Sandbox Code Playgroud)
从菜单按钮重新登录我们的应用程序(应用程序的历史记录)
2020-02-25 14:11:23.387 2043-2043/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onRestart:
2020-02-25 14:11:23.392 2043-2043/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onStart:
2020-02-25 14:11:23.394 2043-2043/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onResume:
2020-02-25 14:11:23.405 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onMeasure:
2020-02-25 14:11:23.420 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onLayout:
2020-02-25 14:11:23.420 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: layout:
2020-02-25 14:11:23.424 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onDraw:
2020-02-25 14:11:23.424 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: dispatchDraw:
2020-02-25 14:11:23.424 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: draw:
2020-02-25 14:11:23.455 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onMeasure:
2020-02-25 14:11:23.460 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onMeasure:
2020-02-25 14:11:23.460 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onLayout:
2020-02-25 14:11:23.460 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: layout:
2020-02-25 14:11:23.461 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: onDraw:
2020-02-25 14:11:23.461 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: dispatchDraw:
2020-02-25 14:11:23.462 2043-2043/com.example.android.androidxtest D/LOG_TAG_VIEW: draw:
Run Code Online (Sandbox Code Playgroud)
登录配置更改(轮换)
2020-02-25 17:05:00.481 8058-8058/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onPause:
2020-02-25 17:05:00.492 8058-8058/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onStop:
2020-02-25 17:05:00.493 8058-8058/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onDestroy:
2020-02-25 17:05:00.512 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: onDetachedFromWindow:
2020-02-25 17:05:00.517 8058-8058/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onDetachedFromWindow:
2020-02-25 17:05:00.563 8058-8058/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onCreate:
2020-02-25 17:05:00.600 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: CustomTextView: Constructor
2020-02-25 17:05:00.601 8058-8058/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onCreate: after setContentView()
2020-02-25 17:05:00.604 8058-8058/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onStart:
2020-02-25 17:05:00.611 8058-8058/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onResume:
2020-02-25 17:05:00.626 8058-8058/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onAttachedToWindow:
2020-02-25 17:05:00.626 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: onAttachedToWindow:
2020-02-25 17:05:00.629 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: onMeasure:
2020-02-25 17:05:00.659 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: onMeasure:
2020-02-25 17:05:00.659 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: onLayout:
2020-02-25 17:05:00.660 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: layout:
2020-02-25 17:05:00.674 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: onDraw:
2020-02-25 17:05:00.674 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: dispatchDraw:
2020-02-25 17:05:00.674 8058-8058/com.example.android.androidxtest D/LOG_TAG_VIEW: draw:
Run Code Online (Sandbox Code Playgroud)
背压
2020-02-25 16:10:24.743 7314-7314/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onPause:
2020-02-25 16:10:25.341 7314-7314/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onStop:
2020-02-25 16:10:25.343 7314-7314/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onDestroy:
2020-02-25 16:10:25.343 7314-7314/com.example.android.androidxtest D/LOG_TAG_VIEW: onDetachedFromWindow:
2020-02-25 16:10:25.344 7314-7314/com.example.android.androidxtest D/LOG_TAG_ACTIVITY: onDetachedFromWindow:
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1116 次 |
| 最近记录: |