本文介绍了使用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进行数据绑定的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!