如何使用Espresso测试矢量图形?

3

我有一个矢量图,想用espresso进行测试。

  <TextView
                android:id="@+id/text_video_call"
                style="@style/UserDetails.TextView.Actions"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginTop="24dp"
                android:drawableTop="@drawable/ic_video_24dp"
                android:text="@string/msg_video_call"
                android:visibility="gone"
                app:layout_constraintEnd_toEndOf="parent"
                app:layout_constraintStart_toEndOf="@+id/text_message"
                app:layout_constraintTop_toBottomOf="@+id/text_username"
                tools:visibility="visible" />

矢量图标:ic_video_24dp

<vector xmlns:android="http://schemas.android.com/apk/res/android"
    android:width="24dp"
    android:height="24dp"
    android:viewportWidth="20"
    android:viewportHeight="20">

    <path
        android:fillColor="#1d74f5"
        android:fillType="evenOdd"
        android:pathData="M16.538,13.564l-3.388,-1.09v-2.07l3.394,-1.085 -0.006,4.245zM11.696,14.56L3.454,14.56L3.454,8.32h8.242v6.24zM17.428,8.107c0.362,0.261 0.57,0.69 0.57,1.176v4.312c0,0.487 -0.209,0.914 -0.57,1.175a1.37,1.37 0,0 1,-0.808 0.254c-0.164,0 -0.331,-0.026 -0.498,-0.08l-2.972,-0.956L13.15,16L2,16L2,6.88h11.15v2.01l2.973,-0.956c0.468,-0.15 0.943,-0.087 1.305,0.173zM4.424,5.44L4.424,4h6.302v1.44L4.424,5.44z" />
</vector>

有什么方法可以使用Espresso测试矢量图形绘制的UI吗?非常感谢您的帮助。

1个回答

0

最好不要比较位图,而是遵循这个答案的建议:https://dev59.com/iW855IYBdhLWcg3wHweH#14474954

在设置图像视图的可绘制对象时,还应使用setTag(R.drawable.your_drawable)将可绘制对象ID存储在其标记中。然后使用Espresso的withTagValue(equalTo(R.drawable.your_drawable))匹配器来检查正确的标记。

请查看我找到的这个教程。看起来非常好用 https://medium.com/@dbottillo/android-ui-test-espresso-matcher-for-imageview-1a28c832626f#4snjg8frw

这里是复制粘贴的摘要;-)

public class DrawableMatcher extends TypeSafeMatcher<View> {

    private final int expectedId;
    String resourceName;

    public DrawableMatcher(int expectedId) {
        super(View.class);
        this.expectedId = expectedId;
    }

    @Override
    protected boolean matchesSafely(View target) {
        if (!(target instanceof ImageView)){
            return false;
        }
        ImageView imageView = (ImageView) target;
        if (expectedId < 0){
            return imageView.getDrawable() == null;
        }
        Resources resources = target.getContext().getResources();
        Drawable expectedDrawable = resources.getDrawable(expectedId);
        resourceName = resources.getResourceEntryName(expectedId);

        if (expectedDrawable == null) {
            return false;
        }

        Bitmap bitmap = ((BitmapDrawable) imageView.getDrawable()).getBitmap();
        Bitmap otherBitmap = ((BitmapDrawable) expectedDrawable).getBitmap();
        return bitmap.sameAs(otherBitmap);
    }


    @Override
    public void describeTo(Description description) {
        description.appendText("with drawable from resource id: ");
        description.appendValue(expectedId);
        if (resourceName != null) {
            description.appendText("[");
            description.appendText(resourceName);
            description.appendText("]");
        }
    }
}

请注意,这仅适用于您的Drawable是BitmapDrawable时才有效。如果您还有VectorDrawable或其他Drawable,则必须进行检查(imageView.getDrawable() instanceOf XXXDrawable),并从中获取位图。除非您有某种简单的Drawable,其中只有一种颜色或类似的内容,您可以进行比较。
为了获得VectorDrawable的位图,即您必须将VectorDrawable绘制到画布上并将其保存到位图中。如果您有一个StateListDrawable,则可以获取所选状态的Drawable并重复if instance Of级联。

谢谢Aqib,但我需要测试50多个可绘制对象,设置标签不是一个选项。还有其他方法吗? - GOVIND DIXIT
由于我正在使用VectorDrawable,需要用什么替代XXXDrawable,我尝试过使用VectorDrawable。 - GOVIND DIXIT
你需要将你的vectorDrawable转换为BitmapDrawable,以下是如何操作的 | 从矢量图形转换为位图 - Aqib Farid

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接