AppCompatActivity的View树

本文详细解析了Android中带有Actionbar及不带Actionbar的样式配置方法,对比了不同样式下视图树的变化,并介绍了如何自定义Toolbar替代Actionbar。

根据activity的style是否有actionbar会有所区别,对应工程ViewTree

1有actionbar的style(ActionbarActivity)

    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

    <!--v21-->
    <style name="AppTheme.NoActionBar">
        <item name="windowActionBar">false</item>
        <item name="windowNoTitle">true</item>
        <item name="android:windowDrawsSystemBarBackgrounds">true</item>
        <item name="android:statusBarColor">@android:color/transparent</item>
    </style>


我们在setContentView里设置进去的layout就是userRoot,实际上是给contentView设了一个child,contentView的特点是id为Android.R.id.content.
//
但是如果把状态栏设置为透明,那么第二行中将没有statusBar,statusBar占用的那部分高度将属于ActionBarOverLayout

2无Actionbar的style

这里分2种,一种是继承自DarkActionBar的NoActionBar

继承自DarkActionBar的NoActionBar(NoActionbarActivity)

<style name="AppTheme.NoActionBar">
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
</style>

没有actionbar的时候,view树结构图,如下所示,其实大部分都一样的,只是上边的ActionBarOverLayout变为了FitWindowsLinearLayout。而上文的Toolbar什么的都扔掉了,此时很可能是我们要自定义toolbar,此时的toolbar就写在userRoot里面,作为userRoot的一部分。

继承自Light的NoActionBar(LightNoActionbarActivity)

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
</style>

这种比较常用,和上边的结构一样

package com.example.a221402305; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.TextView; import androidx.appcompat.app.AppCompatActivity; public class MainActivity extends AppCompatActivity { private TextView tvPoemName1, tvPoem1, tvAuthor1, tvTranslation1; private TextView tvPoemName2, tvPoem2, tvAuthor2, tvTranslation2; private Button btnPoem, btnAuthor, btnTranslation, btnNext, btnExit; private boolean isFirstPoem = true; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); tvPoemName1 = findViewById(R.id.tv_poem_name_1); tvPoem1 = findViewById(R.id.tv_poem_1); tvAuthor1 = findViewById(R.id.tv_author_1); tvTranslation1 = findViewById(R.id.tv_translation_1); tvPoemName2 = findViewById(R.id.tv_poem_name_2); tvPoem2 = findViewById(R.id.tv_poem_2); tvAuthor2 = findViewById(R.id.tv_author_2); tvTranslation2 = findViewById(R.id.tv_translation_2); btnPoem = findViewById(R.id.btn_poem); btnAuthor = findViewById(R.id.btn_author); btnTranslation = findViewById(R.id.btn_translation); btnNext = findViewById(R.id.btn_next); btnExit = findViewById(R.id.btn_exit); btnPoem.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (isFirstPoem) { tvPoemName1.setVisibility(View.VISIBLE); tvPoem1.setVisibility(View.VISIBLE); tvAuthor1.setVisibility(View.GONE); tvTranslation1.setVisibility(View.GONE); tvPoemName2.setVisibility(View.GONE); tvPoem2.setVisibility(View.GONE); tvAuthor2.setVisibility(View.GONE); tvTranslation2.setVisibility(View.GONE); } else { tvPoemName2.setVisibility(View.VISIBLE); tvPoem2.setVisibility(View.VISIBLE); tvAuthor2.setVisibility(View.GONE); tvTranslation2.setVisibility(View.GONE); tvPoemName1.setVisibility(View.GONE); tvPoem1.setVisibility(View.GONE); tvAuthor1.setVisibility(View.GONE); tvTranslation1.setVisibility(View.GONE); } } }); btnAuthor.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (isFirstPoem) { tvPoemName1.setVisibility(View.VISIBLE); tvPoem1.setVisibility(View.GONE); tvAuthor1.setVisibility(View.VISIBLE); tvTranslation1.setVisibility(View.GONE); tvPoemName2.setVisibility(View.GONE); tvPoem2.setVisibility(View.GONE); tvAuthor2.setVisibility(View.GONE); tvTranslation2.setVisibility(View.GONE); } else { tvPoemName2.setVisibility(View.VISIBLE); tvPoem2.setVisibility(View.GONE); tvAuthor2.setVisibility(View.VISIBLE); tvTranslation2.setVisibility(View.GONE); tvPoemName1.setVisibility(View.GONE); tvPoem1.setVisibility(View.GONE); tvAuthor1.setVisibility(View.GONE); tvTranslation1.setVisibility(View.GONE); } } }); btnTranslation.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (isFirstPoem) { tvPoemName1.setVisibility(View.VISIBLE); tvPoem1.setVisibility(View.GONE); tvAuthor1.setVisibility(View.GONE); tvTranslation1.setVisibility(View.VISIBLE); tvPoemName2.setVisibility(View.GONE); tvPoem2.setVisibility(View.GONE); tvAuthor2.setVisibility(View.GONE); tvTranslation2.setVisibility(View.GONE); } else { tvPoemName2.setVisibility(View.VISIBLE); tvPoem2.setVisibility(View.GONE); tvAuthor2.setVisibility(View.GONE); tvTranslation2.setVisibility(View.VISIBLE); tvPoemName1.setVisibility(View.GONE); tvPoem1.setVisibility(View.GONE); tvAuthor1.setVisibility(View.GONE); tvTranslation1.setVisibility(View.GONE); } } }); btnNext.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { isFirstPoem = !isFirstPoem; if (isFirstPoem) { tvPoemName1.setVisibility(View.VISIBLE); tvPoem1.setVisibility(View.VISIBLE); tvAuthor1.setVisibility(View.GONE); tvTranslation1.setVisibility(View.GONE); tvPoemName2.setVisibility(View.GONE); tvPoem2.setVisibility(View.GONE); tvAuthor2.setVisibility(View.GONE); tvTranslation2.setVisibility(View.GONE); } else { tvPoemName2.setVisibility(View.VISIBLE); tvPoem2.setVisibility(View.VISIBLE); tvAuthor2.setVisibility(View.GONE); tvTranslation2.setVisibility(View.GONE); tvPoemName1.setVisibility(View.GONE); tvPoem1.setVisibility(View.GONE); tvAuthor1.setVisibility(View.GONE); tvTranslation1.setVisibility(View.GONE); } } }); btnExit.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { finish(); } }); } } 根据上述代码对此进行修改
最新发布
09-19
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值