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

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: Addressing rotated text + comment cleanup 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
« no previous file with comments | « Source/core/editing/FrameSelectionTest.cpp ('k') | Source/core/editing/GranularityStrategy.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 // Returns true if the two supplied positions are in the order defined by
101 // the int parameter:
leviw_travelin_and_unemployed 2015/05/20 22:01:01 This isn't exactly what I meant. I'd probably go
mfomitchev 2015/05/25 23:05:51 Done.
102 // - For int > 0 returns true if the first position is after the second one.
103 // - For int < 0 returns true if the first position is before the second one .
104 // - For int == 0 returns true if the first position is equal to the second one.
105 bool arePositionsInOrder(const VisiblePosition&, const VisiblePosition&, int );
106
57 // Returns the next word boundary starting from |pos|. |direction| specifies 107 // Returns the next word boundary starting from |pos|. |direction| specifies
58 // the direction in which to search for the next bound. nextIfOnBound 108 // the direction in which to search for the next bound. nextIfOnBound
59 // controls whether |pos| or the next boundary is returned when |pos| is 109 // controls whether |pos| or the next boundary is returned when |pos| is
60 // located exactly on word boundary. 110 // located exactly on word boundary.
61 VisiblePosition nextWordBound(const VisiblePosition& /*pos*/, SearchDirectio n /*direction*/, BoundAdjust /*nextIfOnBound*/); 111 VisiblePosition nextWordBound(const VisiblePosition& /*pos*/, SearchDirectio n /*direction*/, BoundAdjust /*nextIfOnBound*/);
62 112
113 StrategyState m_state;
63 // Current selection granularity being used 114 // Current selection granularity being used
64 TextGranularity m_granularity; 115 TextGranularity m_granularity;
65 // Set to true if the selection was shrunk (without changing relative 116 // Coordinates of the previous extent in contents-space.
66 // base/extent order) as a result of the most recent updateExtent call. 117 IntPoint m_extentPoint;
67 bool m_lastMoveShrunkSelection; 118 // Offset applied to the extent.
119 int m_offset;
68 }; 120 };
69 121
70 } // namespace blink 122 } // namespace blink
71 123
72 #endif // GranularityStrategy_h 124 #endif // GranularityStrategy_h
OLDNEW
« no previous file with comments | « Source/core/editing/FrameSelectionTest.cpp ('k') | Source/core/editing/GranularityStrategy.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698