如何在AppCompatActivity中屏蔽系统的ActionBar使用自定义的ActionBar获得兼容性

本文介绍如何在Android开发中使用AppCompatActivity控制Actionbar,通过修改主题属性和添加Toolbar控件来实现更好的兼容性。文章还详细解释了如何设置Menu布局及其属性,确保Actionbar正常显示。此外,提供了图标包下载链接,并指导如何调整Gradle Build文件以适应从Activity迁移至AppCompatActivity的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在用Android Studio 学习android app开发,但是看见很多资料开发的activity都是从activity类中继承的。但是Android Studio 默认创建创建的activity是继承自AppCompatActivity。一直在学,暂时不觉得两者有太大的区别。但是据说AppCompatActivity的兼容性要比Activity要好。直到学到ActionBar的时候,终于发现了一些问题。
本博客就是关于如何使用AppCompatActivity控制AcitonBar。以下这种做法可以获得更好的兼容性

分为以下几步:
1. 修改清单文件 Application 或者 Activity 的Theme属性至任一 NoAcitonBar,这样做的原因取消原来AcitonBar的设置,使得后面可以使用自己创建的ActionBar

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.winphred.myapplication">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        // 修改Theme主题
           android:theme="@style/Theme.AppCompat.Light.NoActionBar">

        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>
  1. 布局文件中添加一个 Toolbar 控件 如下:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.winphred.myapplication.MainActivity">

    <android.support.v7.widget.Toolbar
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:id="@+id/main_action_bar"
        android:background="?attr/colorPrimary"
        android:elevation="4dp"
        android:theme="@style/ThemeOverlay.AppCompat.ActionBar"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
        />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!" />
</RelativeLayout>
  1. 设置Menu布局 必须对每个ShowAsAction属性进行赋值 否则显示不了效果,具体属性意义请看说明文档
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

    <item android:id="@+id/mi1"
        android:title="It1"
        android:icon="@drawable/ic_free_breakfast_black_24dp"
        app:showAsAction="always"
        />
    <item android:id="@+id/mi2"
        android:title="it2"
        android:icon="@drawable/ic_casino_black_24dp"
        app:showAsAction="ifRoom"
        />
    <item android:id="@+id/mi3"
        android:title="it3"
        android:icon="@drawable/ic_smoking_rooms_black_24dp"
        app:showAsAction="ifRoom"

        />
    <item android:id="@+id/mi4"
        android:title="it4"
        app:showAsAction="never"
        />
</menu>
  1. 在Java文件创建Toolbar(即生成ActionBar)
package com.winphred.myapplication;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
// 引入toolbar需要的包
import android.support.v7.widget.Toolbar;
import android.view.Menu;

public class MainActivity extends AppCompatActivity {

    // Tool bar
    private android.support.v7.widget.Toolbar tb;

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

        // 设置Toolbar
        tb = (Toolbar)findViewById(R.id.main_action_bar);
        setSupportActionBar(tb);

    }
    // 创建菜单
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.main_menu, menu);
        return  true;
    }
}

弄这个问题的时候 顺便发现了一个很好用的图标包 顺带把地址发一下
https://codeload.github.com/google/material-design-icons/zip/2.1

如果是从Activity迁移过来的 还需要确保调整了Gradle Build文件的以下项目:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 23
    buildToolsVersion "23.0.2"

    defaultConfig {
        applicationId "com.winphred.myapplication"
        minSdkVersion 15
        targetSdkVersion 23
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    //确保以下支持包存在
    compile 'com.android.support:appcompat-v7:23.1.1'
}

效果如下:
竖屏:
这里写图片描述
横屏:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值