Android 自定义 标题栏 进度条

本方法中,一定要在 sytle 文件加入如下代码,否则启动后会抛出异常:

<item name="windowActionBar">true</item> 

这是因为 AppCompatActivity 的默认 style 中含有如下设置:

<item name="windowActionBar">false</item> 

调整之后的 style 代码像下面的样子:

<resources>

    <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="windowNoTitle">true</item>

        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

</resources>

style 代码部分我们可以根据自己的实际情况调整,就不再赘述。

接下来是 自定义 toolbar 的布局文件:

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <ProgressBar
        android:id="@+id/progress_circular"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="end"
        android:indeterminate="true"
        android:visibility="gone" />

    <LinearLayout
        android:id="@+id/progress_horizontal"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:visibility="gone"
        >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/app_name"
            android:layout_gravity="center_vertical"
            style="@style/TextAppearance.Widget.AppCompat.Toolbar.Title"
            />

        <ProgressBar
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:indeterminate="true"
            style="@style/Widget.AppCompat.ProgressBar.Horizontal"
            />

    </LinearLayout>

</android.support.v7.widget.Toolbar>

主布局文件:

<?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:orientation="vertical">

    <include layout="@layout/toolbar"/>


    <Button
        android:id="@+id/change_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/horizontal"
        android:layout_marginTop="40dp"
        android:layout_gravity="center_horizontal"
        android:onClick="onClicked"
        />

</LinearLayout>

主程序代码:

package com.toby.personal.testlistview;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.ProgressBar;

public class MainActivity extends AppCompatActivity {

    final private static String TAG = "Toby_Test";

    private ProgressBar progress_circular = null;
    private LinearLayout progress_horizontal = null;
    private Button change_button = null;

    private boolean CircularEnabled = true;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        progress_circular = (ProgressBar) findViewById(R.id.progress_circular);
        progress_horizontal = (LinearLayout) findViewById(R.id.progress_horizontal);
        change_button = (Button) findViewById(R.id.change_button);

        progress_circular.setVisibility(View.VISIBLE);
    }

    public void onClicked(View view) {

        if (CircularEnabled) {
            progress_circular.setVisibility(View.GONE);
            progress_horizontal.setVisibility(View.VISIBLE);
            change_button.setText(R.string.horizontal);
        } else {
            progress_horizontal.setVisibility(View.GONE);
            progress_circular.setVisibility(View.VISIBLE);
            change_button.setText(R.string.circular);
        }

        CircularEnabled = !CircularEnabled;
    }
}

启动之后的显示效果:


首次启动运行效果

点击按钮之后的运行效果:


点击按钮之后的运行效果
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,138评论 25 709
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,694评论 0 17
  • 原文地址:http://www.android100.org/html/201606/06/241682.html...
    AFinalStone阅读 1,029评论 0 1
  • 最近迷上了去森林公园夜跑。打“夜跑”这个词的时候弹出来了“野炮”,欲哭无泪。 夜晚的森林公园少了白天的喧嚣,特别是...
    银昕阅读 378评论 0 0
  • 你舞动着的妩媚的腰肢 你缄默着的红色的嘴唇 我的小情人 你若捉起了迷藏 真叫人心慌 你黄昏张着的贪婪的口 你夜莺睁...
    阆苑寒梅阅读 199评论 0 0