am 876d0072: am 447ad6d6: am 317c2bce: (-s ours) DO NOT MERGE Bump CTS versions from 4.4W_r3 to 4.4W_r4.
* commit '876d0072223a57a9d75dce92c0b053fc9ae066ba':
DO NOT MERGE Bump CTS versions from 4.4W_r3 to 4.4W_r4.
diff --git a/tests/tests/uirendering/res/layout/simple_rect_layout.xml b/tests/tests/uirendering/res/layout/simple_rect_layout.xml
index 24c9b6b..e64c4e9 100644
--- a/tests/tests/uirendering/res/layout/simple_rect_layout.xml
+++ b/tests/tests/uirendering/res/layout/simple_rect_layout.xml
@@ -17,11 +17,10 @@
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
- android:layout_height="match_parent"
- android:background="#f00">
+ android:layout_height="match_parent">
- <View android:layout_width="180px"
- android:layout_height="120px"
- android:background="#0f0" />
+ <View android:layout_width="100px"
+ android:layout_height="100px"
+ android:background="#00f" />
</LinearLayout>
diff --git a/tests/tests/uirendering/src/android/uirendering/cts/testclasses/ExactCanvasTests.java b/tests/tests/uirendering/src/android/uirendering/cts/testclasses/ExactCanvasTests.java
index 3088142..afbad65 100644
--- a/tests/tests/uirendering/src/android/uirendering/cts/testclasses/ExactCanvasTests.java
+++ b/tests/tests/uirendering/src/android/uirendering/cts/testclasses/ExactCanvasTests.java
@@ -16,8 +16,6 @@
package android.uirendering.cts.testclasses;
-import com.android.cts.uirendering.R;
-
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
@@ -31,8 +29,7 @@
import android.uirendering.cts.bitmapverifiers.RectVerifier;
import android.uirendering.cts.testinfrastructure.ActivityTestBase;
import android.uirendering.cts.testinfrastructure.CanvasClient;
-import android.uirendering.cts.testinfrastructure.ViewInitializer;
-import android.view.View;
+import com.android.cts.uirendering.R;
public class ExactCanvasTests extends ActivityTestBase {
private final BitmapComparer mExactComparer = new ExactComparer();
@@ -212,14 +209,4 @@
.addLayout(R.layout.blue_padded_square, null)
.runWithVerifier(verifier);
}
-
- @SmallTest
- public void testClipping() {
- createTest().addLayout(R.layout.simple_red_layout, new ViewInitializer() {
- @Override
- public void intializeView(View view) {
- view.setClipBounds(new Rect(0, 0, 50, 50));
- }
- }).runWithComparer(mExactComparer);
- }
}
diff --git a/tests/tests/uirendering/src/android/uirendering/cts/testclasses/PathClippingTests.java b/tests/tests/uirendering/src/android/uirendering/cts/testclasses/PathClippingTests.java
new file mode 100644
index 0000000..8df8057
--- /dev/null
+++ b/tests/tests/uirendering/src/android/uirendering/cts/testclasses/PathClippingTests.java
@@ -0,0 +1,146 @@
+package android.uirendering.cts.testclasses;
+
+import android.graphics.Canvas;
+import android.graphics.Color;
+import android.graphics.Paint;
+import android.graphics.Path;
+import android.graphics.Point;
+import android.graphics.Typeface;
+import android.test.suitebuilder.annotation.SmallTest;
+import android.uirendering.cts.bitmapcomparers.MSSIMComparer;
+import android.uirendering.cts.bitmapverifiers.SamplePointVerifier;
+import android.uirendering.cts.testinfrastructure.ActivityTestBase;
+import android.uirendering.cts.testinfrastructure.CanvasClient;
+import android.uirendering.cts.testinfrastructure.ViewInitializer;
+import android.view.View;
+import android.view.ViewGroup;
+import com.android.cts.uirendering.R;
+
+public class PathClippingTests extends ActivityTestBase {
+ // draw circle with whole in it, with stroked circle
+ static final CanvasClient sCircleDrawCanvasClient = new CanvasClient() {
+ @Override
+ public String getDebugString() {
+ return "StrokedCircleDraw";
+ }
+
+ @Override
+ public void draw(Canvas canvas, int width, int height) {
+ Paint paint = new Paint();
+ paint.setAntiAlias(false);
+ paint.setColor(Color.BLUE);
+ paint.setStyle(Paint.Style.STROKE);
+ paint.setStrokeWidth(20);
+ canvas.drawCircle(50, 50, 40, paint);
+ }
+ };
+
+ // draw circle with whole in it, by path operations + path clipping
+ static final CanvasClient sCircleClipCanvasClient = new CanvasClient() {
+ @Override
+ public String getDebugString() {
+ return "CircleClipDraw";
+ }
+
+ @Override
+ public void draw(Canvas canvas, int width, int height) {
+ canvas.save();
+
+ Path path = new Path();
+ path.addCircle(50, 50, 50, Path.Direction.CW);
+ path.addCircle(50, 50, 30, Path.Direction.CCW);
+
+ canvas.clipPath(path);
+ canvas.drawColor(Color.BLUE);
+
+ canvas.restore();
+ }
+ };
+
+ @SmallTest
+ public void testCircleWithCircle() {
+ createTest()
+ .addCanvasClient(sCircleDrawCanvasClient, false)
+ .addCanvasClient(sCircleClipCanvasClient)
+ .runWithComparer(new MSSIMComparer(0.90));
+ }
+
+ @SmallTest
+ public void testCircleWithPoints() {
+ createTest()
+ .addCanvasClient(sCircleClipCanvasClient)
+ .runWithVerifier(new SamplePointVerifier(
+ new Point[] {
+ // inside of circle
+ new Point(50, 50),
+ // on circle
+ new Point(50 + 32, 50 + 32),
+ // outside of circle
+ new Point(50 + 38, 50 + 38),
+ new Point(100, 100)
+ },
+ new int[] {
+ Color.WHITE,
+ Color.BLUE,
+ Color.WHITE,
+ Color.WHITE,
+ }));
+ }
+
+ @SmallTest
+ public void testViewRotate() {
+ createTest()
+ .addLayout(R.layout.blue_padded_layout, new ViewInitializer() {
+ @Override
+ public void intializeView(View view) {
+ ViewGroup rootView = (ViewGroup) view;
+ rootView.setClipChildren(true);
+ View childView = rootView.getChildAt(0);
+ childView.setPivotX(50);
+ childView.setPivotY(50);
+ childView.setRotation(45f);
+
+ }
+ })
+ .runWithVerifier(new SamplePointVerifier(
+ new Point[] {
+ // inside of rotated rect
+ new Point(50, 50),
+ new Point(50 + 32, 50 + 32),
+ // outside of rotated rect
+ new Point(50 + 38, 50 + 38),
+ new Point(100, 100)
+ },
+ new int[] {
+ Color.BLUE,
+ Color.BLUE,
+ Color.WHITE,
+ Color.WHITE,
+ }));
+ }
+
+ @SmallTest
+ public void testTextClip() {
+ createTest()
+ .addCanvasClient(new CanvasClient() {
+ @Override
+ public void draw(Canvas canvas, int width, int height) {
+ canvas.save();
+
+ Path path = new Path();
+ path.addCircle(0, 50, 50, Path.Direction.CW);
+ path.addCircle(100, 50, 50, Path.Direction.CW);
+ canvas.clipPath(path);
+
+ Paint paint = new Paint();
+ paint.setAntiAlias(true);
+ paint.setTextSize(100);
+ paint.setTypeface(Typeface.defaultFromStyle(Typeface.BOLD));
+ canvas.drawText("STRING", 0, 100, paint);
+
+ canvas.restore();
+ }
+ })
+ .runWithComparer(new MSSIMComparer(0.90));
+ }
+}
diff --git a/tests/tests/uirendering/src/android/uirendering/cts/testclasses/view/UnclippedBlueView.java b/tests/tests/uirendering/src/android/uirendering/cts/testclasses/view/UnclippedBlueView.java
index e2037f7..7a16e3c 100644
--- a/tests/tests/uirendering/src/android/uirendering/cts/testclasses/view/UnclippedBlueView.java
+++ b/tests/tests/uirendering/src/android/uirendering/cts/testclasses/view/UnclippedBlueView.java
@@ -18,12 +18,12 @@
public UnclippedBlueView(Context context, AttributeSet attrs, int defStyleAttr) {
this(context, attrs, defStyleAttr, 0);
- setWillNotDraw(false);
}
public UnclippedBlueView(Context context, AttributeSet attrs,
int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
+ setWillNotDraw(false);
}
@Override