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

Side by Side Diff: Source/core/editing/GranularityStrategy.h

Issue 1123563003: Improving direction-based selection strategy. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Fixing the slow extend and expanding tests a bit. Created 5 years, 7 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef GranularityStrategy_h 5 #ifndef GranularityStrategy_h
6 #define GranularityStrategy_h 6 #define GranularityStrategy_h
7 7
8 #include "core/editing/SelectionStrategy.h" 8 #include "core/editing/SelectionStrategy.h"
9 #include "core/editing/VisibleSelection.h" 9 #include "core/editing/VisibleSelection.h"
10 10
11 namespace blink { 11 namespace blink {
12 12
13 class GranularityStrategy { 13 class GranularityStrategy {
14 public: 14 public:
15 virtual ~GranularityStrategy(); 15 virtual ~GranularityStrategy();
16 virtual SelectionStrategy GetType() const = 0; 16 virtual SelectionStrategy GetType() const = 0;
17 virtual void Clear() = 0; 17 virtual void Clear() = 0;
18 18
19 // Calculates and returns the new selection based on the updated user 19 // Calculates and returns the new selection based on the updated extent
20 // selection extent |extentPosition| and the granularity strategy. 20 // location in contents-space coordinates.
21 virtual VisibleSelection updateExtent(const VisiblePosition& extentPosition, const VisibleSelection&) = 0; 21 virtual VisibleSelection updateExtent(const IntPoint&, LocalFrame*) = 0;
22 22
23 protected: 23 protected:
24 GranularityStrategy(); 24 GranularityStrategy();
25 }; 25 };
26 26
27 // Always uses character granularity. 27 // Always uses character granularity.
28 class CharacterGranularityStrategy final : public GranularityStrategy { 28 class CharacterGranularityStrategy final : public GranularityStrategy {
29 public: 29 public:
30 CharacterGranularityStrategy(); 30 CharacterGranularityStrategy();
31 ~CharacterGranularityStrategy() final; 31 ~CharacterGranularityStrategy() final;
32 32
33 // GranularityStrategy: 33 // GranularityStrategy:
34 SelectionStrategy GetType() const final; 34 SelectionStrategy GetType() const final;
35 void Clear() final; 35 void Clear() final;
36 VisibleSelection updateExtent(const VisiblePosition& extentPosition, const V isibleSelection&) final; 36 VisibleSelection updateExtent(const IntPoint&, LocalFrame*) final;
37 }; 37 };
38 38
39 // "Expand by word, shrink by character" selection strategy. 39 // "Expand by word, shrink by character" selection strategy.
40 // Uses character granularity when selection is shrinking. If the selection is 40 // Uses character granularity when selection is shrinking. If the selection is
41 // expanding, granularity doesn't change until a word boundary is passed, after 41 // expanding, granularity doesn't change until a word boundary is passed, after
42 // which the granularity switches to "word". 42 // which the granularity switches to "word".
43 // In word granularity, the word is not selected until the extent passes the
44 // middle of the word. If the selection is shrunk when there is a distance
45 // between the extent and the selection end on extent's side of the base, then
46 // this distance is applied to the extent as an offset for the purpose of
47 // determining the selection bound. This prevents the selection edge from
48 // "jumping" back to extent position when it is shrunk after extending. This
49 // offset can be reduced or set to 0 if the extent is moved in the opposite
50 // direction.
51 //
52 // Example:
53 // ^ marks base, | marks extent passed in updateExtent, > marks selection end:
54 // Lorem ip^sum|> dolor sit amet, consectetur
55 //
56 // Move extent over the middle of "dolor", granularity should change to word
57 // granularity and the selection end should jump to the end of the word.
58 // Lorem ip^sum dolo|r> sit amet, consectetur
59 //
60 // Move extent back one character. Granularity changes to "character". The
61 // selection end should move back one character as well. Note an offset between
62 // the extent and the selection end.
63 // Lorem ip^sum dol|o>r sit amet, consectetur
64 //
65 // Move extent forward one character. The offset is reduced to 0. Selection end
66 // doesn't change.
67 // Lorem ip^sum dolo|>r sit amet, consectetur
68 //
69 // Move forward one character. End moves with extent in character granularity.
70 // Lorem ip^sum dolor|> sit amet, consectetur
43 class DirectionGranularityStrategy final : public GranularityStrategy { 71 class DirectionGranularityStrategy final : public GranularityStrategy {
44 public: 72 public:
45 DirectionGranularityStrategy(); 73 DirectionGranularityStrategy();
46 ~DirectionGranularityStrategy() final; 74 ~DirectionGranularityStrategy() final;
47 75
48 // GranularityStrategy: 76 // GranularityStrategy:
49 SelectionStrategy GetType() const final; 77 SelectionStrategy GetType() const final;
50 void Clear() final; 78 void Clear() final;
51 VisibleSelection updateExtent(const VisiblePosition&, const VisibleSelection &) final; 79 VisibleSelection updateExtent(const IntPoint&, LocalFrame*) final;
52 80
53 private: 81 private:
82 enum class StrategyState {
83 // Starting state.
84 // Selection was cleared and there were no extent updates since then.
85 // One an update is performed, the strategy goes into the Expanding
86 // state unless the upate shrinks the selection without changing
87 // relative base/extent order, in which case the strategy goes into the
88 // Shrinking state.
89 Cleared,
90 // Last time the selection was changed by updateExtent - it was expanded
91 // or the relative base/extent order was changed.
92 Expanding,
93 // Last time the selection was changed by updateExtent - it was shrunk
94 // (without changing relative base/extent order).
95 Shrinking
96 };
54 enum class BoundAdjust {CurrentPosIfOnBound, NextBoundIfOnBound}; 97 enum class BoundAdjust {CurrentPosIfOnBound, NextBoundIfOnBound};
55 enum class SearchDirection {SearchBackwards, SearchForward}; 98 enum class SearchDirection {SearchBackwards, SearchForward};
56 99
100 // Order is specified using the same contract as comparePositions.
101 bool arePositionsInSpecifiedOrder(const VisiblePosition& vp1, const VisibleP osition& vp2, int specifiedOrder);
102
57 // Returns the next word boundary starting from |pos|. |direction| specifies 103 // Returns the next word boundary starting from |pos|. |direction| specifies
58 // the direction in which to search for the next bound. nextIfOnBound 104 // the direction in which to search for the next bound. nextIfOnBound
59 // controls whether |pos| or the next boundary is returned when |pos| is 105 // controls whether |pos| or the next boundary is returned when |pos| is
60 // located exactly on word boundary. 106 // located exactly on word boundary.
61 VisiblePosition nextWordBound(const VisiblePosition& /*pos*/, SearchDirectio n /*direction*/, BoundAdjust /*nextIfOnBound*/); 107 VisiblePosition nextWordBound(const VisiblePosition& /*pos*/, SearchDirectio n /*direction*/, BoundAdjust /*nextIfOnBound*/);
62 108
109 StrategyState m_state;
63 // Current selection granularity being used 110 // Current selection granularity being used
64 TextGranularity m_granularity; 111 TextGranularity m_granularity;
65 // Set to true if the selection was shrunk (without changing relative 112 // The vector defining the location of the extent point in contents-space
leviw_travelin_and_unemployed 2015/05/26 20:25:50 What vector? This content doesn't help me understa
mfomitchev 2015/05/26 22:32:47 Is there a more appropriate class than IntSize to
leviw_travelin_and_unemployed 2015/05/26 22:47:49 IntSize is the most appropriate in Blink, but we d
mfomitchev 2015/05/27 17:24:29 Acknowledged.
mfomitchev 2015/06/03 18:57:54 Done.
66 // base/extent order) as a result of the most recent updateExtent call. 113 // coordinates relative to the extent's VisiblePosition.
67 bool m_lastMoveShrunkSelection; 114 IntSize m_subPositionCorrection;
115 // Offset applied to the extent point.
leviw_travelin_and_unemployed 2015/05/26 20:25:50 This is always going to be an x offset, right? Not
mfomitchev 2015/05/26 22:32:47 Acknowledged.
mfomitchev 2015/06/03 18:57:54 Done.
116 int m_offset;
68 }; 117 };
69 118
70 } // namespace blink 119 } // namespace blink
71 120
72 #endif // GranularityStrategy_h 121 #endif // GranularityStrategy_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698