chromium/third_party/blink/web_tests/hittesting/image-with-clip-path.html

<!DOCTYPE HTML>
<script src="../resources/testharness.js"></script>
<script src="../resources/testharnessreport.js"></script>
<style>
    .referenceClipPath {
        -webkit-clip-path: url(#referenceClipPathTopLeft);
        clip-path: url(#referenceClipPathTopLeft);
        width: 100px;
        height: 100px;
        position: absolute;
    }
    .referenceClipPath:hover {
        background: green;
    }
    .shapeClipPath {
        -webkit-clip-path: polygon(0% 0%, 100% 100%, 100% 0%);
        clip-path: polygon(0% 0%, 100% 100%, 100% 0%);
        width: 100px;
        height: 100px;
        position: absolute;
    }
    .shapeClipPath:hover {
        background: green;
    }
    #imageWithReferenceClipPath {
        top: 50px;
        left: 50px;
    }
    #imageWithShapeClipPath {
        top: 50px;
        left: 150px;
    }
    #transformedDivContainer {
        position: absolute;
        top: 0;
        left: 0;
        transform: translate3d(25px, 25px, 0);
    }
    #transformedWithReferenceClipPath {
        top: 125px;
        left: 25px;
        transform: rotateY(60deg);
    }
    #transformedWithShapeClipPath {
        top: 125px;
        left: 125px;
        transform: rotateY(60deg);
    }
</style>
<p>Image hit testing should not include clipped-out regions.</p>
<svg width="100" height="0">
    <defs>
        <clipPath id="referenceClipPathTopLeft" clipPathUnits="objectBoundingBox">
            <path id="path" d="M 0 0 L 100 100 L 100 0Z" />
        </clipPath>
    </defs>
</svg>
<img id="imageWithReferenceClipPath" class="referenceClipPath" src="">
<img id="imageWithShapeClipPath" class="shapeClipPath" src="">
<div id="transformedDivContainer">
    <img id="transformedWithReferenceClipPath" class="referenceClipPath" src="">
    <img id="transformedWithShapeClipPath" class="shapeClipPath" src="">
</div>
<div id="console"></div>
<script>
test(function(t)
{
    // Check that clip path affects hit testing for the first row of images.
    // These images are offset with top/left.
    // (75,125) is outside the triangular clip path, (125,75) is inside it.
    assert_not_equals(document.elementFromPoint(75, 125).id, "imageWithReferenceClipPath");
    assert_equals(document.elementFromPoint(125, 75).id, "imageWithReferenceClipPath");
    // Same test as above but for a shape-based clip path offset by 100px.
    assert_not_equals(document.elementFromPoint(75+100, 125).id, "imageWithShapeClipPath");
    assert_equals(document.elementFromPoint(125+100, 75).id, "imageWithShapeClipPath");

    // Check that clip path affects hit testing for the second row. These
    // images are transformed by a container by (25,25) and each has a
    // 3d rotation causing the images to be horizontally squished. The test
    // coordinates are tight and will fail without the Y rotation.
    // (100,255) and (135,175) are outside the triangular clip path.
    // (115,175) and (120,225) are inside the triangular clip path.
    assert_not_equals(document.elementFromPoint(100, 225).id, "transformedWithReferenceClipPath");
    assert_not_equals(document.elementFromPoint(135, 175).id, "transformedWithReferenceClipPath");
    assert_equals(document.elementFromPoint(115, 175).id, "transformedWithReferenceClipPath");
    assert_equals(document.elementFromPoint(120, 225).id, "transformedWithReferenceClipPath");
    // Same test as above but for a shape-based clip path offset by 100px.
    assert_not_equals(document.elementFromPoint(100+100, 225).id, "transformedWithShapeClipPath");
    assert_not_equals(document.elementFromPoint(135+100, 175).id, "transformedWithShapeClipPath");
    assert_equals(document.elementFromPoint(115+100, 175).id, "transformedWithShapeClipPath");
    assert_equals(document.elementFromPoint(120+100, 225).id, "transformedWithShapeClipPath");
}, "Image hit testing should not include clipped-out regions.");
</script>