在导航上应用单击事件使用数据绑定在xml中的工具栏图标

时间:2018-02-10 10:31:25

标签: android xml data-binding

我是数据绑定的新手,有没有想法如何使用数据绑定直接在xml中的工具栏导航图标上应用click事件。

我的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>

如何在viewholder中处理clickevent。 有什么想法......谢谢

2 个答案:

答案 0 :(得分:3)

默认情况下,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" />

答案 1 :(得分:1)

我认为你可以使用绑定适配器在工具栏导航图标上应用click事件。 这里是您的工具栏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}” 并返回任何你想要的参数。

在你的viewmodel中添加一个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..
            }
        });
    }
}