WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
132593
[Mac] Allow focus rings to redraw themselves if necessary
https://bugs.webkit.org/show_bug.cgi?id=132593
Summary
[Mac] Allow focus rings to redraw themselves if necessary
Dean Jackson
Reported
2014-05-05 18:01:29 PDT
Mac allows focus rings to animate, changing their appearance over time. Expose this to the render code, such that it can be notified if a focused element wants to redraw itself, as well as remember how long it has been since the element was focused.
Attachments
Patch
(35.83 KB, patch)
2014-05-05 19:00 PDT
,
Dean Jackson
no flags
Details
Formatted Diff
Diff
Patch
(35.77 KB, patch)
2014-05-05 19:52 PDT
,
Dean Jackson
no flags
Details
Formatted Diff
Diff
Patch
(38.88 KB, patch)
2014-05-06 15:45 PDT
,
Dean Jackson
simon.fraser
: review+
buildbot
: commit-queue-
Details
Formatted Diff
Diff
Archive of layout-test-results from webkit-ews-06 for mac-mountainlion
(567.19 KB, application/zip)
2014-05-06 18:04 PDT
,
Build Bot
no flags
Details
Show Obsolete
(2)
View All
Add attachment
proposed patch, testcase, etc.
Dean Jackson
Comment 1
2014-05-05 19:00:13 PDT
Created
attachment 230879
[details]
Patch
Dean Jackson
Comment 2
2014-05-05 19:00:48 PDT
This patch won't build until the new WKSI has landed. I'll do that now. It is ready for review though.
Jon Lee
Comment 3
2014-05-05 19:46:42 PDT
Comment on
attachment 230879
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=230879&action=review
Unofficial r=me.
> Source/WebCore/page/FocusController.cpp:928 > + focusedElement->renderer()->repaint();
Need to check the renderer()?
Tim Horton
Comment 4
2014-05-05 19:51:53 PDT
Comment on
attachment 230879
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=230879&action=review
> Source/WebCore/ChangeLog:16 > + to port the code from their into WebKit.
s/their/there/
> Source/WebCore/page/FocusController.cpp:933 > + return currentTime() - m_focusSetTime;
I think you want monotonicallyIncreasingTime, not currentTime!!
> Source/WebCore/rendering/RenderView.cpp:106 > + , m_maximalOutlineSize(9)
this seems ... unfortunate. does this inflate layers too?
Dean Jackson
Comment 5
2014-05-05 19:52:54 PDT
Created
attachment 230883
[details]
Patch
Dean Jackson
Comment 6
2014-05-05 19:53:22 PDT
Now that the WKSI parts have landed, the build should be happy.
Dean Jackson
Comment 7
2014-05-05 20:00:52 PDT
Comment on
attachment 230879
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=230879&action=review
>> Source/WebCore/page/FocusController.cpp:928 >> + focusedElement->renderer()->repaint(); > > Need to check the renderer()?
Will do.
>> Source/WebCore/page/FocusController.cpp:933 >> + return currentTime() - m_focusSetTime; > > I think you want monotonicallyIncreasingTime, not currentTime!!
Yes
>> Source/WebCore/rendering/RenderView.cpp:106 >> + , m_maximalOutlineSize(9) > > this seems ... unfortunate. does this inflate layers too?
Yep :( All layers will grow by 6px on each side. And we'll be repainting more area too.
Dean Jackson
Comment 8
2014-05-05 20:01:47 PDT
I've made the changes from Tim and Jon's review locally, but won't upload a new patch until landing time.
Simon Fraser (smfr)
Comment 9
2014-05-05 20:22:13 PDT
Comment on
attachment 230883
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=230883&action=review
> Source/WebCore/rendering/RenderView.cpp:107 > +#if PLATFORM(MAC) > + , m_maximalOutlineSize(9) > +#else
We can't do this. It will bloat all layers, and make all opaque things non-opaque. Why can't you just do this when a focus ring is showing?
Dean Jackson
Comment 10
2014-05-05 20:27:06 PDT
(In reply to
comment #9
)
> (From update of
attachment 230883
[details]
) > View in context:
https://bugs.webkit.org/attachment.cgi?id=230883&action=review
> > > Source/WebCore/rendering/RenderView.cpp:107 > > +#if PLATFORM(MAC) > > + , m_maximalOutlineSize(9) > > +#else > > We can't do this. It will bloat all layers, and make all opaque things non-opaque.
We already do this, it's just that the value has increased from 3 to 9. Yes, it bloats the layers.
> Why can't you just do this when a focus ring is showing?
Because the crazy logic that determines repaint size and layer size doesn't actually care about whether or not a focus ring is showing. It applies this fudge factor to everything. Fixing that would be a pretty huge change.
Dean Jackson
Comment 11
2014-05-06 15:45:13 PDT
Created
attachment 230940
[details]
Patch
Simon Fraser (smfr)
Comment 12
2014-05-06 15:58:13 PDT
Comment on
attachment 230940
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=230940&action=review
> Source/WebCore/page/FocusController.cpp:172 > + m_focusRepaintTimer.stop();
I think timers stop themselves on destruction.
> Source/WebCore/page/FocusController.cpp:915 > + m_focusRepaintTimer.startOneShot(0);
Why repaint at > 60fps?
> Source/WebCore/page/FocusController.h:93 > + void focusedElementNeedsRepaint();
This sounds like it is returning state. I think it should be setFocusedElementNeedsRepaintSoon().
> Source/WebCore/page/FocusController.h:94 > + double timeSinceFocusWasSet() const;
Aren't the cool kids using std::chromo these days?
> Source/WebCore/platform/ControlStates.h:108 > + double m_timeSinceFocusWasSet;
Hmm, wouldn't this value be continually changing? Seems odd to store it. Is it something else here, like time used for painting the next focus ring state?
> Source/WebCore/platform/graphics/mac/GraphicsContextMac.mm:73 > +void GraphicsContext::drawFocusRing(const Path& path, int /* width */, int /*offset*/, const Color&)
Spacing in comments is inconsistent.
> Source/WebCore/platform/graphics/mac/GraphicsContextMac.mm:91 > + for (IntRect rect : rects)
const IntRect& ? Or auto&?
> Source/WebCore/platform/graphics/mac/GraphicsContextMac.mm:107 > + for (IntRect rect : rects)
Ditto.
> Source/WebCore/platform/mac/ThemeMac.mm:287 > - { 3, 4, 4, 2 }, > - { 4, 3, 3, 3 }, > - { 4, 3, 3, 3 }, > + { 7, 8, 8, 6 }, > + { 8, 7, 7, 7 }, > + { 8, 8, 7, 7 },
Why aren't these different on different OSes?
> Source/WebCore/rendering/RenderElement.cpp:374 > + view().setMaximalOutlineSize(std::max(theme().platformFocusRingMaxWidth(), static_cast<int>(m_style->outlineSize())));
So m_style->outlineSize() is a lie now? Won't that break repainting, e.g. in RenderElement::styleWillChange() which does if (m_parent && (newStyle.outlineSize() < m_style->outlineSize()...
Build Bot
Comment 13
2014-05-06 18:04:37 PDT
Comment on
attachment 230940
[details]
Patch
Attachment 230940
[details]
did not pass mac-ews (mac): Output:
http://webkit-queues.appspot.com/results/4990262187130880
New failing tests: svg/text/non-bmp-positioning-lists.svg compositing/geometry/ancestor-overflow-change.html compositing/layer-creation/overlap-animation-container.html compositing/contents-opaque/control-layer.html
Build Bot
Comment 14
2014-05-06 18:04:41 PDT
Created
attachment 230961
[details]
Archive of layout-test-results from webkit-ews-06 for mac-mountainlion The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: webkit-ews-06 Port: mac-mountainlion Platform: Mac OS X 10.8.5
Dean Jackson
Comment 15
2014-05-06 18:08:43 PDT
Committed
r168397
: <
http://trac.webkit.org/changeset/168397
>
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug