【问题标题】:Apply click event on navigation Icon of toolbar in xml using data binding使用数据绑定在xml中工具栏的导航图标上应用单击事件
【发布时间】:2025-11-23 12:10:02
【问题描述】:

我是数据绑定的新手,是否知道如何使用数据绑定直接在 xml 中应用工具栏导航图标上的点击事件。

我的 xml 是这样的

<?xml version="1.0" encoding="utf-8"?>
<layout 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"
    xmlns:bind="http://schemas.android.com/apk/res-aut">
    <data class="SelectCuisineBinding">
        <variable
            name="viewModel"
            type="com.aman.camellia.kniterider.viewmodel.SelectCuisineViewModel"/>
        <variable
            name="activity"
            type="com.aman.camellia.kniterider.view.activity.SelectCuisineActivity"/>
    </data>

<android.support.design.widget.CoordinatorLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.aman.camellia.kniterider.view.activity.SelectCuisineActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/AppTheme.AppBarOverlay">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            app:navigationIcon="?homeAsUpIndicator"

            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            app:title="@string/Cuisines"
            app:popupTheme="@style/AppTheme.PopupOverlay" />

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

    <include layout="@layout/content_select_cuisine"
        app:viewModel="@{viewModel}"

        app:activity="@{activity}"/>



</android.support.design.widget.CoordinatorLayout>
</layout>

如何处理视图中的点击事件。 有什么想法吗...谢谢

【问题讨论】:

    标签: android xml data-binding


    【解决方案1】:

    Android 默认提供绑定适配器或支持添加点击监听器。我们只需要修改属性app:navigationOnClickListener。并且命名空间是xmlns:app="http://schemas.android.com/apk/res-auto"

    <androidx.appcompat.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                android:background="@color/blue_grey_600"
                app:navigationIcon="@drawable/ic_close_icon_resized"
                app:title="@{viewModel.toolBarText}"
                app:titleTextAppearance="@style/EmiToolbar.Text"
                app:navigationOnClickListener="@{() -> viewModel.onToolbarNavigationClick()}"
                app:contentInsetStart="0dp"
                app:contentInsetStartWithNavigation="0dp"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
    

    【讨论】:

      【解决方案2】:

      我认为您可以使用绑定适配器在工具栏导航图标上应用点击事件。 这里是你的工具栏 xml 代码..

       <android.support.v7.widget.Toolbar
                  android:id="@+id/toolbar"
                  app:navigationIcon="?homeAsUpIndicator"
      
                  android:layout_width="match_parent"
                  android:layout_height="?attr/actionBarSize"
                  android:background="?attr/colorPrimary"
                  app:title="@string/Cuisines"
                  app:onNavigationBackClick="@{1}"
                  app:popupTheme="@style/AppTheme.PopupOverlay" />
      

      我将 BindingAdapter 应用为 app:onNavigationBackClick="@{1}" 并返回任何你想要的参数。

      并在您的视图模型中添加一个 bindigAdapter 作为我添加

      public class YourViewModel ....
      
      @BindingAdapter("onNavigationBackClick")
          public static void onnavigationClicked(Toolbar toolbar,int b){
              toolbar.setNavigationOnClickListener(new View.OnClickListener() {
                  @Override
                  public void onClick(View v) {
                     // do here what you want..
                  }
              });
          }
      }
      

      【讨论】:

      • “b”参数应该是什么?