Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(396)

Issue 2695013011: Fix miter clipping of borders with large radius opposite a wide edge (Closed)

Created:
3 years, 10 months ago by Stephen Chennney
Modified:
3 years, 10 months ago
Reviewers:
f(malita)
CC:
chromium-reviews, blink-reviews, dshwang, blink-reviews-paint_chromium.org
Target Ref:
refs/pending/heads/master
Project:
chromium
Visibility:
Public.

Description

Fix miter clipping of borders with large radius opposite a wide edge The previous clipping approach for anti-aliasing miter joints between border edges generated concave clipping quads that would clip out the border itself in cases where a wide border was opposite a large border radius. This change switches the code from a parallelogram-derived clip to a trapezoidal clip that will always include all of the border, and is not prone to divide by zero under pathological cases. New test fast/borders/border-large-radius-opposite-wide-edge.html covers the previously failing cases. Some existing test results change along single pixel anti-aliased lines due to slightly different clips for the miters. R=fmalita@chromium.org BUG=331004 CQ_INCLUDE_TRYBOTS=master.tryserver.chromium.linux:linux_layout_tests_slimming_paint_v2 Review-Url: https://codereview.chromium.org/2695013011 Cr-Commit-Position: refs/heads/master@{#451889} Committed: https://chromium.googlesource.com/chromium/src/+/fc37a436628053178de0179e8d4566d3e1ea9800

Patch Set 1 #

Total comments: 2

Patch Set 2 : Fix offsets #

Patch Set 3 : Need bigger offset as before. #

Patch Set 4 : New image baselines #

Unified diffs Side-by-side diffs Delta from patch set Stats (+267 lines, -107 lines) Patch
M third_party/WebKit/LayoutTests/fast/backgrounds/background-leakage-expected.png View 1 2 3 Binary file 0 comments Download
A third_party/WebKit/LayoutTests/fast/borders/border-large-radius-opposite-wide-edge.html View 1 chunk +35 lines, -0 lines 0 comments Download
A third_party/WebKit/LayoutTests/fast/borders/border-large-radius-opposite-wide-edge-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/border-mixed-alpha-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/border-radius-groove-01-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/border-radius-groove-02-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/border-radius-groove-03-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/border-radius-inset-outset-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/border-radius-wide-border-02-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/border-radius-wide-border-03-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/border-radius-wide-border-04-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusArcs01-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDashed04-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDashed05-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDashed06-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDotted04-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDotted05-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDotted06-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDouble04-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDouble05-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDouble06-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDouble07-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDouble08-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusDouble09-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusGroove01-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusGroove02-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusInset01-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusOutset01-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusRidge01-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/borderRadiusSlope-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/fieldsetBorderRadius-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/fast/borders/mixed-border-styles-radius-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/css2.1/t0805-c5517-brdr-s-00-c-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/backgrounds/background-leakage-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/backgrounds/border-radius-split-background-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/backgrounds/border-radius-split-background-image-expected.png View 1 2 3 Binary file 0 comments Download
A third_party/WebKit/LayoutTests/platform/linux/fast/borders/border-large-radius-opposite-wide-edge-expected.png View 1 2 3 Binary file 0 comments Download
A third_party/WebKit/LayoutTests/platform/linux/fast/borders/border-large-radius-opposite-wide-edge-expected.txt View 1 2 3 1 chunk +17 lines, -0 lines 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/borders/border-mixed-alpha-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/borders/border-radius-inline-flow-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/borders/border-radius-inset-outset-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/borders/border-radius-split-inline-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/borders/border-styles-split-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/borders/borderRadiusAllStylesAllCorners-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/borders/different-color-borders-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/borders/mixed-border-styles-radius-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/box-shadow/inset-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/box-shadow/inset-subpixel-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/forms/search/search-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/forms/submit/submit-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/forms/text/text-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/replaced/border-radius-clip-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/writing-mode/border-radius-clipping-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/writing-mode/border-styles-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/writing-mode/border-styles-vertical-rl-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/linux/fast/writing-mode/border-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.10/fast/forms/search/search-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.10/fast/forms/submit/submit-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.10/fast/forms/text/text-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.10/fast/writing-mode/border-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.9/fast/forms/search/search-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.9/fast/forms/submit/submit-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.9/fast/forms/text/text-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.9/fast/replaced/border-radius-clip-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.9/fast/writing-mode/border-radius-clipping-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac-mac10.9/fast/writing-mode/border-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/css2.1/t0805-c5517-brdr-s-00-c-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/backgrounds/border-radius-split-background-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/backgrounds/border-radius-split-background-image-expected.png View 1 2 3 Binary file 0 comments Download
A third_party/WebKit/LayoutTests/platform/mac/fast/borders/border-large-radius-opposite-wide-edge-expected.txt View 1 2 3 1 chunk +17 lines, -0 lines 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/borders/border-radius-inline-flow-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/borders/border-radius-split-inline-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/borders/border-styles-split-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/borders/borderRadiusAllStylesAllCorners-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/borders/different-color-borders-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/box-shadow/inset-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/box-shadow/inset-subpixel-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/forms/search/search-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/forms/submit/submit-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/forms/text/text-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/replaced/border-radius-clip-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/writing-mode/border-radius-clipping-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/writing-mode/border-styles-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/writing-mode/border-styles-vertical-rl-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/fast/writing-mode/border-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/mac/paint/roundedrects/input-with-rounded-rect-and-shadow-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/css1/box_properties/border_style-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/css2.1/t0805-c5517-brdr-s-00-c-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/backgrounds/border-radius-split-background-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/backgrounds/border-radius-split-background-image-expected.png View 1 2 3 Binary file 0 comments Download
A third_party/WebKit/LayoutTests/platform/win/fast/borders/border-large-radius-opposite-wide-edge-expected.txt View 1 2 3 1 chunk +17 lines, -0 lines 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/borders/border-radius-inline-flow-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/borders/border-radius-split-inline-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/borders/border-styles-split-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/borders/borderRadiusAllStylesAllCorners-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/borders/different-color-borders-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/box-shadow/inset-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/box-shadow/inset-subpixel-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/forms/search/search-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/forms/submit/submit-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/forms/text/text-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/replaced/border-radius-clip-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/writing-mode/border-radius-clipping-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/writing-mode/border-styles-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/writing-mode/border-styles-vertical-rl-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/fast/writing-mode/border-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win/paint/roundedrects/input-with-rounded-rect-and-shadow-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win7/fast/forms/search/search-appearance-basic-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/LayoutTests/platform/win7/fast/writing-mode/border-vertical-lr-expected.png View 1 2 3 Binary file 0 comments Download
M third_party/WebKit/Source/core/paint/BoxBorderPainter.cpp View 1 2 2 chunks +181 lines, -107 lines 0 comments Download

Messages

Total messages: 25 (11 generated)
Stephen Chennney
The test result changes are all anti-aliasing differences due to minor clip changes. There are ...
3 years, 10 months ago (2017-02-17 20:51:07 UTC) #2
f(malita)
https://codereview.chromium.org/2695013011/diff/1/third_party/WebKit/Source/core/paint/BoxBorderPainter.cpp File third_party/WebKit/Source/core/paint/BoxBorderPainter.cpp (right): https://codereview.chromium.org/2695013011/diff/1/third_party/WebKit/Source/core/paint/BoxBorderPainter.cpp#newcode1356 third_party/WebKit/Source/core/paint/BoxBorderPainter.cpp:1356: clippingQuad[1] += extensionOffset; I don't fully follow the extension ...
3 years, 10 months ago (2017-02-17 21:43:45 UTC) #3
Stephen Chennney
Thanks, you spotted my mistake. I'll get a new version up on Tuesday. https://codereview.chromium.org/2695013011/diff/1/third_party/WebKit/Source/core/paint/BoxBorderPainter.cpp File ...
3 years, 10 months ago (2017-02-17 21:56:26 UTC) #4
f(malita)
On 2017/02/17 21:56:26, Stephen Chennney wrote: > Thanks, you spotted my mistake. I'll get a ...
3 years, 10 months ago (2017-02-17 21:57:09 UTC) #5
Stephen Chennney
On 2017/02/17 21:57:09, f(malita) wrote: > On 2017/02/17 21:56:26, Stephen Chennney wrote: > > Thanks, ...
3 years, 10 months ago (2017-02-17 22:03:17 UTC) #6
Stephen Chennney
New baselines are in. No crack visible so I think it's ready to go. The ...
3 years, 10 months ago (2017-02-21 18:48:26 UTC) #9
f(malita)
On 2017/02/21 18:48:26, Stephen Chennney wrote: > New baselines are in. No crack visible so ...
3 years, 10 months ago (2017-02-21 20:04:25 UTC) #10
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/v2/patch-status/codereview.chromium.org/2695013011/60001
3 years, 10 months ago (2017-02-21 20:25:16 UTC) #13
Stephen Chennney
On 2017/02/21 20:04:25, f(malita) wrote: > On 2017/02/21 18:48:26, Stephen Chennney wrote: > > New ...
3 years, 10 months ago (2017-02-21 20:25:41 UTC) #14
commit-bot: I haz the power
Try jobs failed on following builders: linux_chromium_chromeos_rel_ng on master.tryserver.chromium.linux (JOB_TIMED_OUT, no build URL) linux_layout_tests_slimming_paint_v2 on ...
3 years, 10 months ago (2017-02-21 20:52:02 UTC) #16
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/v2/patch-status/codereview.chromium.org/2695013011/60001
3 years, 10 months ago (2017-02-21 20:57:11 UTC) #18
commit-bot: I haz the power
Try jobs failed on following builders: linux_chromium_asan_rel_ng on master.tryserver.chromium.linux (JOB_TIMED_OUT, no build URL)
3 years, 10 months ago (2017-02-21 23:00:02 UTC) #20
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/v2/patch-status/codereview.chromium.org/2695013011/60001
3 years, 10 months ago (2017-02-22 03:34:57 UTC) #22
commit-bot: I haz the power
3 years, 10 months ago (2017-02-22 05:46:06 UTC) #25
Message was sent while issue was closed.
Committed patchset #4 (id:60001) as
https://chromium.googlesource.com/chromium/src/+/fc37a436628053178de0179e8d45...

Powered by Google App Engine
This is Rietveld 408576698