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

Side by Side Diff: content/renderer/external_popup_menu.cc

Issue 501583003: Move external popup menus from WebViewClient to WebFrameClient, part 3/3. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 6 years, 4 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 #include "content/renderer/external_popup_menu.h" 5 #include "content/renderer/external_popup_menu.h"
6 6
7 #include "content/common/view_messages.h" 7 #include "content/common/frame_messages.h"
8 #include "content/renderer/menu_item_builder.h" 8 #include "content/renderer/menu_item_builder.h"
9 #include "content/renderer/render_view_impl.h" 9 #include "content/renderer/render_frame_impl.h"
10 #include "third_party/WebKit/public/platform/WebRect.h" 10 #include "third_party/WebKit/public/platform/WebRect.h"
11 #include "third_party/WebKit/public/web/WebExternalPopupMenuClient.h" 11 #include "third_party/WebKit/public/web/WebExternalPopupMenuClient.h"
12 12
13 namespace content { 13 namespace content {
14 14
15 ExternalPopupMenu::ExternalPopupMenu( 15 ExternalPopupMenu::ExternalPopupMenu(
16 RenderViewImpl* render_view, 16 RenderFrameImpl* render_frame,
17 const blink::WebPopupMenuInfo& popup_menu_info, 17 const blink::WebPopupMenuInfo& popup_menu_info,
18 blink::WebExternalPopupMenuClient* popup_menu_client) 18 blink::WebExternalPopupMenuClient* popup_menu_client)
19 : render_view_(render_view), 19 : render_frame_(render_frame),
20 popup_menu_info_(popup_menu_info), 20 popup_menu_info_(popup_menu_info),
21 popup_menu_client_(popup_menu_client), 21 popup_menu_client_(popup_menu_client),
22 origin_scale_for_emulation_(0) { 22 origin_scale_for_emulation_(0) {
23 } 23 }
24 24
25 void ExternalPopupMenu::SetOriginScaleAndOffsetForEmulation( 25 void ExternalPopupMenu::SetOriginScaleAndOffsetForEmulation(
26 float scale, const gfx::Point& offset) { 26 float scale, const gfx::Point& offset) {
27 origin_scale_for_emulation_ = scale; 27 origin_scale_for_emulation_ = scale;
28 origin_offset_for_emulation_ = offset; 28 origin_offset_for_emulation_ = offset;
29 } 29 }
30 30
31 void ExternalPopupMenu::show(const blink::WebRect& bounds) { 31 void ExternalPopupMenu::show(const blink::WebRect& bounds) {
32 blink::WebRect rect = bounds; 32 blink::WebRect rect = bounds;
33 if (origin_scale_for_emulation_) { 33 if (origin_scale_for_emulation_) {
34 rect.x *= origin_scale_for_emulation_; 34 rect.x *= origin_scale_for_emulation_;
35 rect.y *= origin_scale_for_emulation_; 35 rect.y *= origin_scale_for_emulation_;
36 } 36 }
37 rect.x += origin_offset_for_emulation_.x(); 37 rect.x += origin_offset_for_emulation_.x();
38 rect.y += origin_offset_for_emulation_.y(); 38 rect.y += origin_offset_for_emulation_.y();
39 39
40 ViewHostMsg_ShowPopup_Params popup_params; 40 FrameHostMsg_ShowPopup_Params popup_params;
41 popup_params.bounds = rect; 41 popup_params.bounds = rect;
42 popup_params.item_height = popup_menu_info_.itemHeight; 42 popup_params.item_height = popup_menu_info_.itemHeight;
43 popup_params.item_font_size = popup_menu_info_.itemFontSize; 43 popup_params.item_font_size = popup_menu_info_.itemFontSize;
44 popup_params.selected_item = popup_menu_info_.selectedIndex; 44 popup_params.selected_item = popup_menu_info_.selectedIndex;
45 for (size_t i = 0; i < popup_menu_info_.items.size(); ++i) { 45 for (size_t i = 0; i < popup_menu_info_.items.size(); ++i) {
46 popup_params.popup_items.push_back( 46 popup_params.popup_items.push_back(
47 MenuItemBuilder::Build(popup_menu_info_.items[i])); 47 MenuItemBuilder::Build(popup_menu_info_.items[i]));
48 } 48 }
49 popup_params.right_aligned = popup_menu_info_.rightAligned; 49 popup_params.right_aligned = popup_menu_info_.rightAligned;
50 popup_params.allow_multiple_selection = 50 popup_params.allow_multiple_selection =
51 popup_menu_info_.allowMultipleSelection; 51 popup_menu_info_.allowMultipleSelection;
52 render_view_->Send( 52 render_frame_->Send(
53 new ViewHostMsg_ShowPopup(render_view_->routing_id(), popup_params)); 53 new FrameHostMsg_ShowPopup(render_frame_->GetRoutingID(), popup_params));
54 } 54 }
55 55
56 void ExternalPopupMenu::close() { 56 void ExternalPopupMenu::close() {
57 render_view_->Send(new ViewHostMsg_HidePopup(render_view_->routing_id())); 57 render_frame_->Send(
58 render_view_->DidHideExternalPopupMenu(); 58 new FrameHostMsg_HidePopup(render_frame_->GetRoutingID()));
59 render_frame_->DidHideExternalPopupMenu();
59 // |this| was deleted. 60 // |this| was deleted.
60 } 61 }
61 62
62 #if defined(OS_MACOSX) 63 #if defined(OS_MACOSX)
63 void ExternalPopupMenu::DidSelectItem(int index) { 64 void ExternalPopupMenu::DidSelectItem(int index) {
64 if (!popup_menu_client_) 65 if (!popup_menu_client_)
65 return; 66 return;
66 if (index == -1) 67 if (index == -1)
67 popup_menu_client_->didCancel(); 68 popup_menu_client_->didCancel();
68 else 69 else
69 popup_menu_client_->didAcceptIndex(index); 70 popup_menu_client_->didAcceptIndex(index);
70 } 71 }
71 #endif 72 #endif
72 73
73 #if defined(OS_ANDROID) 74 #if defined(OS_ANDROID)
74 void ExternalPopupMenu::DidSelectItems(bool canceled, 75 void ExternalPopupMenu::DidSelectItems(bool canceled,
75 const std::vector<int>& indices) { 76 const std::vector<int>& indices) {
76 if (!popup_menu_client_) 77 if (!popup_menu_client_)
77 return; 78 return;
78 if (canceled) 79 if (canceled)
79 popup_menu_client_->didCancel(); 80 popup_menu_client_->didCancel();
80 else 81 else
81 popup_menu_client_->didAcceptIndices(indices); 82 popup_menu_client_->didAcceptIndices(indices);
82 } 83 }
83 #endif 84 #endif
84 85
85 } // namespace content 86 } // namespace content
OLDNEW
« no previous file with comments | « content/renderer/external_popup_menu.h ('k') | content/renderer/external_popup_menu_browsertest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698