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

Unified Diff: third_party/WebKit/Source/core/editing/FrameCaret.h

Issue 2665823002: Invalidate caret during paint invalidation (Closed)
Patch Set: NeedsRebaseline Created 3 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/core/editing/FrameCaret.h
diff --git a/third_party/WebKit/Source/core/editing/FrameCaret.h b/third_party/WebKit/Source/core/editing/FrameCaret.h
index cbe7ead1804cc3b831d1a45a04d6299c70f24b72..b546a8082bddb9e160d52a19651becfc3d4986dc 100644
--- a/third_party/WebKit/Source/core/editing/FrameCaret.h
+++ b/third_party/WebKit/Source/core/editing/FrameCaret.h
@@ -26,33 +26,31 @@
#ifndef FrameCaret_h
#define FrameCaret_h
+#include <memory>
#include "core/CoreExport.h"
-#include "core/dom/SynchronousMutationObserver.h"
#include "core/editing/PositionWithAffinity.h"
#include "platform/Timer.h"
#include "platform/geometry/LayoutRect.h"
+#include "platform/graphics/PaintInvalidationReason.h"
#include "platform/heap/GarbageCollected.h"
#include "platform/heap/Member.h"
-#include <memory>
namespace blink {
class CaretDisplayItemClient;
-class CharacterData;
class DisplayItemClient;
class Document;
+class FrameCaret;
class GraphicsContext;
-class Node;
+class LayoutBlock;
class LocalFrame;
class SelectionEditor;
+struct PaintInvalidatorContext;
enum class CaretVisibility { Visible, Hidden };
class CORE_EXPORT FrameCaret final
- : public GarbageCollectedFinalized<FrameCaret>,
- public SynchronousMutationObserver {
- USING_GARBAGE_COLLECTED_MIXIN(FrameCaret);
-
+ : public GarbageCollectedFinalized<FrameCaret> {
public:
FrameCaret(LocalFrame&, const SelectionEditor&);
~FrameCaret();
@@ -60,7 +58,6 @@ class CORE_EXPORT FrameCaret final
const DisplayItemClient& displayItemClient() const;
bool isActive() const { return caretPosition().isNotNull(); }
- void documentAttached(Document*);
void updateAppearance();
// Used to suspend caret blinking while the mouse is down.
@@ -70,24 +67,27 @@ class CORE_EXPORT FrameCaret final
bool isCaretBlinkingSuspended() const { return m_isCaretBlinkingSuspended; }
void stopCaretBlinkTimer();
void startBlinkCaret();
-
void setCaretVisibility(CaretVisibility);
- void setCaretRectNeedsUpdate();
- // If |forceInvalidation| is true the caret's previous and new rectangles
- // are forcibly invalidated regardless of the state of the blink timer.
- void invalidateCaretRect(bool forceInvalidation);
IntRect absoluteCaretBounds() const;
bool shouldShowBlockCursor() const { return m_shouldShowBlockCursor; }
void setShouldShowBlockCursor(bool);
- void paintCaret(GraphicsContext&, const LayoutPoint&);
+ // Paint invalidation methods delegating to DisplayItemClient.
+ void clearPreviousVisualRect(const LayoutBlock&);
+ void layoutBlockWillBeDestroyed(const LayoutBlock&);
+ void updateStyleAndLayoutIfNeeded();
+ void invalidatePaintIfNeeded(const LayoutBlock&,
+ const PaintInvalidatorContext&,
+ PaintInvalidationReason);
- void dataWillChange(const CharacterData&);
+ bool shouldPaintCaret(const LayoutBlock&) const;
+ void paintCaret(GraphicsContext&, const LayoutPoint&) const;
- // For unittests
+ // For unit tests.
+ const DisplayItemClient& caretDisplayItemClientForTesting() const;
+ const LayoutBlock* caretLayoutBlockForTesting() const;
bool shouldPaintCaretForTesting() const { return m_shouldPaintCaret; }
- bool isPreviousCaretDirtyForTesting() const { return m_previousCaretNode; }
DECLARE_TRACE();
@@ -100,23 +100,14 @@ class CORE_EXPORT FrameCaret final
void caretBlinkTimerFired(TimerBase*);
bool caretPositionIsValidForDocument(const Document&) const;
- // Implementation of |SynchronousMutationObserver| member functions.
- void contextDestroyed(Document*) final;
- void nodeWillBeRemoved(Node&) final;
+ void scheduleVisualUpdateForPaintInvalidationIfNeeded();
const Member<const SelectionEditor> m_selectionEditor;
const Member<LocalFrame> m_frame;
const std::unique_ptr<CaretDisplayItemClient> m_caretBase;
- // The last node which painted the caret. Retained for clearing the old
- // caret when it moves.
- Member<Node> m_previousCaretNode;
- Member<Node> m_previousCaretAnchorNode;
- LayoutRect m_previousCaretRect;
CaretVisibility m_caretVisibility;
- CaretVisibility m_previousCaretVisibility;
// TODO(https://crbug.com/668758): Consider using BeginFrame update for this.
TaskRunnerTimer<FrameCaret> m_caretBlinkTimer;
- bool m_caretRectDirty : 1;
bool m_shouldPaintCaret : 1;
bool m_isCaretBlinkingSuspended : 1;
bool m_shouldShowBlockCursor : 1;
« no previous file with comments | « third_party/WebKit/Source/core/editing/EditingUtilities.cpp ('k') | third_party/WebKit/Source/core/editing/FrameCaret.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698