OLD | NEW |
(Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 // FindRequestManager manages all of the find-in-page requests/replies |
| 6 // initiated/received through a WebContents. |
| 7 |
| 8 #ifndef CONTENT_BROWSER_FIND_REQUEST_MANAGER_H_ |
| 9 #define CONTENT_BROWSER_FIND_REQUEST_MANAGER_H_ |
| 10 |
| 11 #include <set> |
| 12 #include <vector> |
| 13 |
| 14 #include "content/public/common/stop_find_action.h" |
| 15 #include "third_party/WebKit/public/web/WebFindOptions.h" |
| 16 #include "ui/gfx/geometry/rect.h" |
| 17 #include "ui/gfx/geometry/rect_f.h" |
| 18 |
| 19 namespace content { |
| 20 |
| 21 class RenderFrameHost; |
| 22 class WebContentsImpl; |
| 23 |
| 24 class FindRequestManager { |
| 25 public: |
| 26 explicit FindRequestManager(WebContentsImpl* web_contents); |
| 27 ~FindRequestManager(); |
| 28 |
| 29 // Initiates a find operation for |search_text| with the options specified in |
| 30 // |options|. |request_id| uniquely identifies the find request. |
| 31 void Find(int request_id, |
| 32 const base::string16& search_text, |
| 33 const blink::WebFindOptions& options); |
| 34 |
| 35 // Stops the active find session and clears the general highlighting of the |
| 36 // matches. |action| determines whether the last active match (if any) will be |
| 37 // activated, cleared, or remain highlighted. |
| 38 void StopFinding(StopFindAction action); |
| 39 |
| 40 // Called when a reply is received from a frame with the results from a |
| 41 // find request. |
| 42 void FindReply(RenderFrameHost* rfh, |
| 43 int request_id, |
| 44 int number_of_matches, |
| 45 const gfx::Rect& selection_rect, |
| 46 int active_match_ordinal, |
| 47 bool final_update); |
| 48 |
| 49 #if defined(OS_ANDROID) |
| 50 // Selects and zooms to the find result nearest to the point (x,y) defined in |
| 51 // find-in-page coordinates. |
| 52 void ActivateNearestFindResult(float x, float y); |
| 53 |
| 54 // Requests the rects of the current find matches from the renderer process. |
| 55 void RequestFindMatchRects(int current_version); |
| 56 |
| 57 // Called when a reply is received in response to a request for find match |
| 58 // rects. |
| 59 void FindMatchRectsReply(RenderFrameHost* rfh, |
| 60 int version, |
| 61 const std::vector<gfx::RectF>& rects, |
| 62 const gfx::RectF& active_rect); |
| 63 #endif |
| 64 |
| 65 private: |
| 66 // Reset all of the per-session state for a new find-in-page session. |
| 67 void Reset(int new_request_id, const base::string16& new_search_text); |
| 68 |
| 69 // Send a find IPC to the RenderFrame associated with |rfh| to begin a find |
| 70 // operation with the search text |current_search_text_| and the find options |
| 71 // in |current_find_options_|. |
| 72 void SendFindIPC(int request_id, RenderFrameHost* rfh); |
| 73 |
| 74 // Send a stop finding IPC to the RenderFrame associated with |
| 75 // |render_frame_host|. |
| 76 void SendStopFindingIPC(StopFindAction action, |
| 77 RenderFrameHost* rfh) const; |
| 78 |
| 79 // Send the find results (as they currently are) to the WebContents. |
| 80 void SendFindReply(int request_id, bool final_update) const; |
| 81 |
| 82 #if defined(OS_ANDROID) |
| 83 // Request the latest find match rects from a frame. |
| 84 void SendFindMatchRectsIPC(RenderFrameHost* rfh); |
| 85 |
| 86 // The latest find match rects version known by the requester. |
| 87 int fmr_request_version_; |
| 88 #endif |
| 89 |
| 90 // The WebContents that owns this FindRequestManager. |
| 91 WebContentsImpl* const contents_; |
| 92 |
| 93 // The find request ID that uniquely identifies this find-in-page session (The |
| 94 // ID of the initial request of this session). Request IDs are included in all |
| 95 // find-related IPCs, which allows IPCs containing results from previous |
| 96 // sessions to be easily identified and ignored. |
| 97 int current_request_id_; |
| 98 |
| 99 // The text that is being searched for in the current find-in-page session. |
| 100 base::string16 current_search_text_; |
| 101 |
| 102 // The current set of find options in effect. |
| 103 blink::WebFindOptions current_find_options_; |
| 104 |
| 105 // The total number of matches found in the current find-in-page session. |
| 106 int number_of_matches_; |
| 107 |
| 108 // The overall active match ordinal for the current find-in-page session. |
| 109 int active_match_ordinal_; |
| 110 |
| 111 // The rectangle around the active match, in screen coordinates. |
| 112 gfx::Rect selection_rect_; |
| 113 }; |
| 114 |
| 115 } // namespace content |
| 116 |
| 117 #endif // CONTENT_BROWSER_FIND_REQUEST_MANAGER_H_ |
OLD | NEW |