使用srcCompat进行数据绑定 [英] Data Binding with srcCompat

查看:20
本文介绍了使用srcCompat进行数据绑定的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在通过app:srcCompat&;使用Support Lib v23.2中新的矢量可绘制支持,尝试通过数据绑定设置其可绘制。

<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

<data>
    <variable
        name="mediaPojo"
        type="in.ishaan.pika.data_binding.MediaPojo"/>
</data>

<RelativeLayout
    android:background="@color/black"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <VideoView
        ... />

    <ImageView
        ...
        app:srcCompat="@{mediaPojo.isPlaying ? @drawable/ic_pause_24dp : @drawable/ic_play_arrow_24dp}"
    />

    <ProgressBar
        .../>
</RelativeLayout>
</layout>

在尝试生成时,Studio引发:

错误:(33,30)找不到参数类型为android.graph ics.Drawable的属性‘app:srcCompat’的设置器。

推荐答案

数据绑定设置向量资源时,只需使用android:src属性即可。

数据绑定库生成在运行时执行setImageResource方法的类。

<ImageView
        ...
        android:src="@{@drawable/your_drawable}"
/>

根据http://android-developers.blogspot.com/2016/02/android-support-library-232.htmlsetImageResource方法可以在运行时在旧系统版本上使用,无需任何其他更改。

如果要使用app:srcCompat属性。您必须定义@BindingMethods注释,该注释将属性与ImageView中的相应setter连接起来。例如,在您的活动或片段添加中。

@BindingMethods({
    @BindingMethod(type = android.widget.ImageView.class,
            attribute = "app:srcCompat",
            method = "setImageDrawable") })
public class MainActivity extends AppCompatActivity {
   // your activity body here

}

这篇关于使用srcCompat进行数据绑定的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆