(Android) Метод onNavigationItemSelected не вызывается - PullRequest
1 голос
/ 30 ноября 2019

Я работаю над приложением для Android для проекта Engineering Design, который включает в себя ящик. Один из членов моей группы решил использовать API android.support.design.widget.NavigationView для этого, и это вызывает у нас некоторые проблемы. Наш класс MainActivity реализует onNavigationItemSelectedListener, который, как я понимаю, действует как прослушиватель для элементов в панели и других панелях навигации. Проблема в том, что при выборе одного из этих элементов навигации реализованный метод onNavigationItemSelected не вызывается (я знаю это, потому что он должен выдавать сообщение через LogCat, если оно вызывается). Все ссылки, которые я нашел для этого API, говорят о том, что я все сделал правильно, но я, по-видимому, что-то упустил, поэтому любая помощь приветствуется.

Вот соответствующий код из класса MainActivity:

@Override
protected void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    setUpNavComponents();
    setUpMapComponents();
    PathfinderDataHandler handler = new PathfinderDataHandler();
}

private void setUpNavComponents()
{
    Toolbar toolbar = findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);
    DrawerLayout drawer = findViewById(R.id.drawer_layout);
    NavigationView navigationView = findViewById(R.id.nav_view);
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
            this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
    drawer.addDrawerListener(toggle);
    toggle.syncState();
    navigationView.setNavigationItemSelectedListener(this);
}

private void setUpMapComponents()
{
    mapFrag = (SupportMapFragment)getSupportFragmentManager().findFragmentById(R.id.map);
    mapFrag.getMapAsync(this);
}

@Override
public boolean onNavigationItemSelected(MenuItem item)
{
    // Handle navigation view item clicks here.
    int id = item.getItemId();
    Log.d(null, "onNavigationItemSelected Called");

    if (id == R.id.buildings)
    {
        // Handle the camera action
        Log.d(null, "Buildings selected");
    }
    else if (id == R.id.blue_phones)
    {
        Log.d(null, "Blue Phones selected");
    }
    else if (id == R.id.bus_stops)
    {
        Log.d(null, "Bus Stops selected");
    }
    else if (id == R.id.pedways)
    {
        Log.d(null, "Pedways selected");
    }

    DrawerLayout drawer = findViewById(R.id.drawer_layout);
    drawer.closeDrawer(GravityCompat.START);
    return true;
}

Вот код из Activity_main_drawer.xml (который содержит все элементы для ящика)

<?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"
    xmlns:tools="http://schemas.android.com/tools"
    tools:showIn="navigation_view">

<group
    android:checkableBehavior="all"
    android:enabled="true">
    <item
        android:id="@+id/buildings"
        android:title="@string/building_show_select"
        app:actionLayout="@layout/switch_item"
        app:showAsAction="always" />
    <item
        android:id="@+id/blue_phones"
        android:title="@string/blue_phone_select"
        app:actionLayout="@layout/switch_item"
        app:showAsAction="always" />
    <item
        android:id="@+id/bus_stops"
        android:title="@string/bus_stop_select"
        app:actionLayout="@layout/switch_item"
        app:showAsAction="always" />
    <item
        android:id="@+id/pedways"
        android:title="@string/pedway_select"
        app:actionLayout="@layout/switch_item"
        app:showAsAction="always" />
</group>

Вот код для Activity_main. xml, который добавляет activity_main_drawer в NavigationView.

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout 
    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"
    android:id="@+id/drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    tools:openDrawer="start">

<include
    layout="@layout/app_bar_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:visibility="visible" />

<android.support.design.widget.NavigationView
    android:id="@+id/nav_view"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    android:fitsSystemWindows="true"
    app:headerLayout="@layout/nav_header_main"
    app:menu="@menu/activity_main_drawer">

</android.support.design.widget.NavigationView>


</android.support.v4.widget.DrawerLayout>

Еще одна вещь, которую стоит отметить, это то, что я использую элементы Switch вместо обычных элементов меню.

И прежде чем кто-либо что-то скажет, ДАЯ знаю, что этот API устарел, и я должен использовать NavigationUI в AndroidX, но у меня нет времени на рефакторинг приложения, поэтому я должен с этим справиться.

1 Ответ

1 голос
/ 01 декабря 2019

Вы должны предоставить не null тег для Log.d (String, String), иначе в Logcat ничего не будет записано.

Я пытался использовать

Log.d(null, "HelloWorld");
Log.d("TEST", " HelloWorld");

и получил только одну строку в Logcat:

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...