使用 srcCompat 进行数据绑定
Data Binding with srcCompat
我在 Support Lib v23.2 中使用新的矢量绘图支持 app:srcCompat 并尝试通过数据绑定设置其绘图。
<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>
在尝试构建时,工作室抛出:
Error:(33, 30) Cannot find the setter for attribute 'app:srcCompat' with parameter type android.graphics.drawable.Drawable.
您可能不得不求助于使用具有类似于以下方法签名的绑定适配器:
@BindingAdapter("app:srcCompat")
public static void bindSrcCompat(ImageView imageView, Drawable drawable){
// Your setter code goes here, like setDrawable or similar
}
引用如下:http://developer.android.com/reference/android/databinding/BindingAdapter.html
当你通过DataBinding设置矢量资源时,你可以简单地使用android:src属性而不是compat属性。
DataBinding 库生成 class,在运行时执行 setImageResource 方法。
<ImageView
...
android:src="@{@drawable/your_drawable}"
/>
根据 http://android-developers.blogspot.com/2016/02/android-support-library-232.html setImageResource 方法可以在运行时在旧系统版本上使用,无需任何额外更改。
如果您想使用 app:srcCompat 属性。您必须定义 @BindingMethods 注释,该注释将属性与 ImageView 中的适当 setter 连接起来。例如,在您的 Activity 或 Fragment 中添加。
@BindingMethods({
@BindingMethod(type = android.widget.ImageView.class,
attribute = "app:srcCompat",
method = "setImageDrawable") })
public class MainActivity extends AppCompatActivity {
// your activity body here
}
建议的答案主要对我有用,但我还需要在我的申请中添加这一行:
AppCompatDelegate.setCompatVectorFromResourcesEnabled(true);
这样做可以让我在旧版本中使用矢量绘图,而无需担心兼容性 类 或属性
如果您需要使用 srcCompat 并且还需要通过 xml 在您的可绘制对象上设置色调,最简单的方法是使用 android.support.v7.widget. AppCompatImageView
然后 android:tint 和 app:srcCompat 工作正常。
注意:由于某些我不知道的原因,在使用 ImageView 的片段布局中工作正常。仅在 activity 布局中需要恢复到 AppCompatImageView。
我在 Support Lib v23.2 中使用新的矢量绘图支持 app:srcCompat 并尝试通过数据绑定设置其绘图。
<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>
在尝试构建时,工作室抛出:
Error:(33, 30) Cannot find the setter for attribute 'app:srcCompat' with parameter type android.graphics.drawable.Drawable.
您可能不得不求助于使用具有类似于以下方法签名的绑定适配器:
@BindingAdapter("app:srcCompat")
public static void bindSrcCompat(ImageView imageView, Drawable drawable){
// Your setter code goes here, like setDrawable or similar
}
引用如下:http://developer.android.com/reference/android/databinding/BindingAdapter.html
当你通过DataBinding设置矢量资源时,你可以简单地使用android:src属性而不是compat属性。
DataBinding 库生成 class,在运行时执行 setImageResource 方法。
<ImageView
...
android:src="@{@drawable/your_drawable}"
/>
根据 http://android-developers.blogspot.com/2016/02/android-support-library-232.html setImageResource 方法可以在运行时在旧系统版本上使用,无需任何额外更改。
如果您想使用 app:srcCompat 属性。您必须定义 @BindingMethods 注释,该注释将属性与 ImageView 中的适当 setter 连接起来。例如,在您的 Activity 或 Fragment 中添加。
@BindingMethods({
@BindingMethod(type = android.widget.ImageView.class,
attribute = "app:srcCompat",
method = "setImageDrawable") })
public class MainActivity extends AppCompatActivity {
// your activity body here
}
建议的答案主要对我有用,但我还需要在我的申请中添加这一行:
AppCompatDelegate.setCompatVectorFromResourcesEnabled(true);
这样做可以让我在旧版本中使用矢量绘图,而无需担心兼容性 类 或属性
如果您需要使用 srcCompat 并且还需要通过 xml 在您的可绘制对象上设置色调,最简单的方法是使用 android.support.v7.widget. AppCompatImageView
然后 android:tint 和 app:srcCompat 工作正常。
注意:由于某些我不知道的原因,在使用 ImageView 的片段布局中工作正常。仅在 activity 布局中需要恢复到 AppCompatImageView。