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

Side by Side Diff: views/widget/widget.cc

Issue 6756043: Consolidate Widget Event code, other cleanup. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Sync and merge. Created 9 years, 8 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
« no previous file with comments | « views/widget/widget.h ('k') | views/widget/widget_gtk.h » ('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 (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 "views/widget/widget.h" 5 #include "views/widget/widget.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/message_loop.h" 8 #include "base/message_loop.h"
9 #include "ui/gfx/compositor/compositor.h" 9 #include "ui/gfx/compositor/compositor.h"
10 #include "views/focus/view_storage.h" 10 #include "views/focus/view_storage.h"
(...skipping 29 matching lines...) Expand all
40 delete_on_destroy(true), 40 delete_on_destroy(true),
41 mirror_origin_in_rtl(true), 41 mirror_origin_in_rtl(true),
42 has_dropshadow(false), 42 has_dropshadow(false),
43 native_widget(NULL) { 43 native_widget(NULL) {
44 } 44 }
45 45
46 //////////////////////////////////////////////////////////////////////////////// 46 ////////////////////////////////////////////////////////////////////////////////
47 // Widget, public: 47 // Widget, public:
48 48
49 Widget::Widget() 49 Widget::Widget()
50 : native_widget_(NULL), 50 : is_mouse_button_pressed_(false),
51 last_mouse_event_was_move_(false),
52 native_widget_(NULL),
51 widget_delegate_(NULL), 53 widget_delegate_(NULL),
52 dragged_view_(NULL) { 54 dragged_view_(NULL) {
53 } 55 }
54 56
55 Widget::~Widget() { 57 Widget::~Widget() {
56 } 58 }
57 59
58 // Unconverted methods (see header) -------------------------------------------- 60 // Unconverted methods (see header) --------------------------------------------
59 61
60 void Widget::Init(gfx::NativeView parent, const gfx::Rect& bounds) { 62 void Widget::Init(gfx::NativeView parent, const gfx::Rect& bounds) {
(...skipping 235 matching lines...) Expand 10 before | Expand all | Expand 10 after
296 298
297 bool Widget::HasFocusManager() const { 299 bool Widget::HasFocusManager() const {
298 return !!focus_manager_.get(); 300 return !!focus_manager_.get();
299 } 301 }
300 302
301 void Widget::OnNativeWidgetPaint(gfx::Canvas* canvas) { 303 void Widget::OnNativeWidgetPaint(gfx::Canvas* canvas) {
302 GetRootView()->Paint(canvas); 304 GetRootView()->Paint(canvas);
303 RefreshCompositeTree(); 305 RefreshCompositeTree();
304 } 306 }
305 307
308 bool Widget::OnMouseEvent(const MouseEvent& event) {
309 switch (event.type()) {
310 case ui::ET_MOUSE_PRESSED:
311 last_mouse_event_was_move_ = false;
312 if (GetRootView()->OnMousePressed(event)) {
313 is_mouse_button_pressed_ = true;
314 if (!native_widget_->HasMouseCapture())
315 native_widget_->SetMouseCapture();
316 return true;
317 }
318 return false;
319 case ui::ET_MOUSE_RELEASED:
320 last_mouse_event_was_move_ = false;
321 is_mouse_button_pressed_ = false;
322 // Release capture first, to avoid confusion if OnMouseReleased blocks.
323 if (native_widget_->HasMouseCapture() &&
324 ShouldReleaseCaptureOnMouseReleased()) {
325 native_widget_->ReleaseMouseCapture();
326 }
327 GetRootView()->OnMouseReleased(event);
328 return (event.flags() & ui::EF_IS_NON_CLIENT) ? false : true;
329 case ui::ET_MOUSE_MOVED:
330 case ui::ET_MOUSE_DRAGGED:
331 if (native_widget_->HasMouseCapture() && is_mouse_button_pressed_) {
332 last_mouse_event_was_move_ = false;
333 GetRootView()->OnMouseDragged(event);
334 } else if (!last_mouse_event_was_move_ ||
335 last_mouse_event_position_ != event.location()) {
336 last_mouse_event_position_ = event.location();
337 last_mouse_event_was_move_ = true;
338 GetRootView()->OnMouseMoved(event);
339 }
340 return false;
341 case ui::ET_MOUSE_EXITED:
342 last_mouse_event_was_move_ = false;
343 GetRootView()->OnMouseExited(event);
344 return false;
345 default:
346 return false;
347 }
348 return true;
349 }
350
351 void Widget::OnMouseCaptureLost() {
352 if (is_mouse_button_pressed_)
353 GetRootView()->OnMouseCaptureLost();
354 is_mouse_button_pressed_ = false;
355 }
356
357
306 //////////////////////////////////////////////////////////////////////////////// 358 ////////////////////////////////////////////////////////////////////////////////
307 // Widget, FocusTraversable implementation: 359 // Widget, FocusTraversable implementation:
308 360
309 FocusSearch* Widget::GetFocusSearch() { 361 FocusSearch* Widget::GetFocusSearch() {
310 return root_view_->GetFocusSearch(); 362 return root_view_->GetFocusSearch();
311 } 363 }
312 364
313 FocusTraversable* Widget::GetFocusTraversableParent() { 365 FocusTraversable* Widget::GetFocusTraversableParent() {
314 // We are a proxy to the root view, so we should be bypassed when traversing 366 // We are a proxy to the root view, so we should be bypassed when traversing
315 // up and as a result this should not be called. 367 // up and as a result this should not be called.
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after
369 // TODO(sad): If there is a parent Widget, then use the same compositor 421 // TODO(sad): If there is a parent Widget, then use the same compositor
370 // instead of creating a new one here. 422 // instead of creating a new one here.
371 gfx::AcceleratedWidget widget = native_widget_->GetAcceleratedWidget(); 423 gfx::AcceleratedWidget widget = native_widget_->GetAcceleratedWidget();
372 if (widget != gfx::kNullAcceleratedWidget) 424 if (widget != gfx::kNullAcceleratedWidget)
373 compositor_ = ui::Compositor::Create(widget); 425 compositor_ = ui::Compositor::Create(widget);
374 426
375 return compositor_.get() != NULL; 427 return compositor_.get() != NULL;
376 } 428 }
377 429
378 } // namespace views 430 } // namespace views
OLDNEW
« no previous file with comments | « views/widget/widget.h ('k') | views/widget/widget_gtk.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698