android - getActionBar() возвращает null




android-3.0-honeycomb android-actionbar (15)

Если вы используете библиотеку поддержки

import android.support.v7.app.ActionBarActivity;

public class MainActivity extends ActionBarActivity {

используйте getSupportActionBar() вместо getActionBar()

* Обновить:

Класс ActionBarActivity теперь устарел:

import android.support.v7.app.ActionBarActivity;

Я рекомендую использовать:

import android.support.v7.app.AppCompatActivity

У меня странная проблема. Я делаю приложение с targetdk 13.

В методе onCreate моего основного действия я вызываю getActionBar() для настройки моей панели действий. Это отлично работает при работе на эмуляторе Android 3.2, но при использовании Android 3.0 и 3.1 метод getActionBar() возвращает значение null.

Я нахожу это чрезвычайно странным, и я не вижу причин, почему он это сделает. Это ошибка с эмуляторами или есть что-то, что мне нужно сделать, чтобы убедиться, что у моего приложения есть панель действий?

РЕШЕНИЕ: Думаю, я нашел решение этой проблемы. Я не использовал setContentView для установки макета для этой активности. Вместо этого я использовал fragmentTransaction.add(android.R.id.content, mFragment, mTag) чтобы добавить фрагмент к активности. Это отлично работало в 3.2, но в более ранних версиях сотовой панели панель действия, по-видимому, не установлена, если вы не используете setContentView в onCreate() . Поэтому я исправил его с помощью setContentView() в моем onCreate() и просто предоставил ему макет, содержащий пустой FrameLayout. Я все еще могу использовать метод fragmentTransaction.add(android.R.id.content, mFragment, mTag) же, как и раньше.

Это не самое лучшее исправление, но оно работает.


  1. если вы используете android.support.v7.app.AppCompatActivity

    Открытый класс HomeActivity расширяет AppCompatActivity {

Тогда вы должны использовать android.support.v7.app.ActionBar

  ActionBar ab = getSupportActionBar();
  1. Если вы используете android.support.v4.app.FragmentActivity

    Открытый класс HomeActivity расширяет FragmentActivity {

то вы должны использовать android.app.ActionBar

    ActionBar ab = getActionBar();
  1. Если вы используете android.support.v7.app.ActionBarActivity

    Открытый класс HomeActivity расширяет ActionBarActivity {

вы должны использовать android.support.v7.app.ActionBar

   ActionBar ab = getSupportActionBar();

В моем случае у меня было это в моем коде, который не работал:

@Override
protected void onCreate(Bundle savedInstanceState) {
    context = getApplicationContext();

    requestWindowFeature(Window.FEATURE_ACTION_BAR);

    super.onCreate(savedInstanceState);

    setContentView(R.layout.activity_main);
}

Затем я сыграл с порядком кода:

@Override
protected void onCreate(Bundle savedInstanceState) {
    requestWindowFeature(Window.FEATURE_ACTION_BAR);

    super.onCreate(savedInstanceState);

    setContentView(R.layout.activity_main);

    context = getApplicationContext();
}

И это сработало!

Вывод: requestWindowFeature должен быть первым, что вы вызываете в методе onCreate.


Вы должны определить тип окна как панель действий, прежде чем действие отобразит его представление.

использование

requestWindowFeature(Window.FEATURE_ACTION_BAR);

перед вызовом метода setContentView ().


Может использовать getSupportActionBar() вместо метода getActionBar() .


Одна вещь, которую я хотел добавить, так как я просто столкнулся с этим, если вы пытаетесь getActionBar () для Activity, у которого есть родительский элемент, он возвращает null. Я пытаюсь реорганизовать код, где моя активность содержится внутри ActivityGroup, и мне потребовалось несколько минут, чтобы я пошел «oh duh», посмотрев на источник того, как ActionBar создается в источнике.


Попробуйте расширить класс Activity из ActionBarActivity. Это решило это для меня. Сделайте что-то вроде следующего:

public class MyActivity extends ActionBarActivity
{
  . . .

В моем случае класс расширялся только из Activity.


Просто проверьте реализацию исходного кода командой:

    private void initWindowDecorActionBar() {
    Window window = getWindow();

    // Initializing the window decor can change window feature flags.
    // Make sure that we have the correct set before performing the test below.
    window.getDecorView();

    if (isChild() || !window.hasFeature(Window.FEATURE_ACTION_BAR) || mActionBar != null) {
        return;
    }

    mActionBar = new WindowDecorActionBar(this);
    mActionBar.setDefaultDisplayHomeAsUpEnabled(mEnableDefaultActionBarUp);

    mWindow.setDefaultIcon(mActivityInfo.getIconResource());
    mWindow.setDefaultLogo(mActivityInfo.getLogoResource());
}

requestWindowFeature (Window.FEATURE_ACTION_BAR); Исправлена ​​проблема, когда я видел, что requestWindowFeature (Window.FEATURE_ACTION_BAR) не работает; код используется с открытым исходным кодом!


Чтобы добавить к другим ответам:

Убедитесь, что вы вызываете setActionBar() или setSupportActionBar() в свой onCreate() перед вызовом getActionBar() :

Определите панель инструментов в вашем файле activity.xml, затем в onCreate ():

Toolbar toolbar = (Toolbar) findViewById(R.id.my_toolbar);
setSupportActionBar(toolbar);
// Now you can use the get methods:
getSupportActionBar().setDisplayHomeAsUpEnabled(true);

Это может также помочь некоторым людям.

В моем случае это произошло потому, что я не определил контекст в menu.xml

Попробуй это:

<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
tools:context="com.example.android.ActionBarActivity">

Вместо этого:

<menu xmlns:android="http://schemas.android.com/apk/res/android">

Я была такая же проблема. Он решен путем chaning темы приложения в styles.xml

До

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">

После

<!-- Base application theme. -->
<style name="AppTheme" parent="android:Theme.Holo.Light.DarkActionBar">

Я знаю, что опаздываю на вечеринку (и новую для Android) по этому вопросу, но я нашел здесь полезную информацию и подумал, что должен добавить результаты моих собственных усилий, чтобы заставить ActionBar работать так, как я хотел, чтобы другие, такие как я, пришли ищут помощь.

У меня есть виджет, который является плавающим окном без заголовка окна. Я использую тему стиля для реализации android:windowIsFloating , android:backgroundDimEnabled и android:windowNoTitle . Виджет работал нормально, пока я не захотел добавить кнопку, назвавшую пэджер фрагмента несколькими страницами фрагментов списка, и использовал ActionBar. Это приведет к сбою в активности пейджера с исключением с нулевым указателем. Я сузил его, чтобы ActionBar был пустым. Следуя результатам предыдущих людей, которые внесли свой вклад в этот поток, я удалил свою тему из файла манифеста, и ActionBar работал нормально, но теперь мое окно теперь больше плавает (это был полноэкранный режим), и у него был заголовок страницы, которого я не хотел.

Дальнейшие исследования привели меня в учебное пособие по стилям и темам API, которое привело меня к решению. Я обнаружил, что могу добавить свою собственную тему к отдельным действиям в файле манифеста, тогда как до того, как я применил ее к приложению. Все мои окна теперь имеют желаемый внешний вид.


Я столкнулся с вышеупомянутой проблемой, когда getActionBar() возвращает значение null. Я вызывал getActionBar() после установки setContentView() и все еще возвращал null .

Я решил проблему, установив версию min-sdk в файле манифеста Android, которая была изначально отсутствующей. <uses-sdk android:minSdkVersion="11" />


Я столкнулся с этой проблемой. Я проверял номер версии и включал панель действий, только если она больше или равна Honeycomb, но она возвращала значение null. Я нашел причину и первопричину в том, что я отключил стиль темы Holo в style.xml в папке values-v11.


import android.support.v7.app.AppCompatActivity;

тогда

extends AppCompatActivity

затем используйте

getSupportActionBar().setDisplayHomeAsUpEnabled(true);




android-actionbar