| OLD | NEW | 
|---|
| 1 // Copyright (c) 2010 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/controls/link.h" | 5 #include "views/controls/link.h" | 
| 6 | 6 | 
| 7 #if defined(OS_LINUX) | 7 #if defined(OS_LINUX) | 
| 8 #include <gdk/gdk.h> | 8 #include <gdk/gdk.h> | 
| 9 #endif | 9 #endif | 
| 10 | 10 | 
| 11 #include "base/logging.h" | 11 #include "base/logging.h" | 
| (...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 90 } | 90 } | 
| 91 | 91 | 
| 92 void Link::SetController(LinkController* controller) { | 92 void Link::SetController(LinkController* controller) { | 
| 93   controller_ = controller; | 93   controller_ = controller; | 
| 94 } | 94 } | 
| 95 | 95 | 
| 96 const LinkController* Link::GetController() { | 96 const LinkController* Link::GetController() { | 
| 97   return controller_; | 97   return controller_; | 
| 98 } | 98 } | 
| 99 | 99 | 
| 100 bool Link::OnMousePressed(const MouseEvent& e) { | 100 bool Link::OnMousePressed(const MouseEvent& event) { | 
| 101   if (!enabled_ || (!e.IsLeftMouseButton() && !e.IsMiddleMouseButton())) | 101   if (!enabled_ || (!event.IsLeftMouseButton() && !event.IsMiddleMouseButton())) | 
| 102     return false; | 102     return false; | 
| 103   SetHighlighted(true); | 103   SetHighlighted(true); | 
| 104   return true; | 104   return true; | 
| 105 } | 105 } | 
| 106 | 106 | 
| 107 bool Link::OnMouseDragged(const MouseEvent& e) { | 107 bool Link::OnMouseDragged(const MouseEvent& event) { | 
| 108   SetHighlighted(enabled_ && | 108   SetHighlighted(enabled_ && | 
| 109                  (e.IsLeftMouseButton() || e.IsMiddleMouseButton()) && | 109                  (event.IsLeftMouseButton() || event.IsMiddleMouseButton()) && | 
| 110                  HitTest(e.location())); | 110                  HitTest(event.location())); | 
| 111   return true; | 111   return true; | 
| 112 } | 112 } | 
| 113 | 113 | 
| 114 void Link::OnMouseReleased(const MouseEvent& e, bool canceled) { | 114 void Link::OnMouseReleased(const MouseEvent& event) { | 
| 115   // Change the highlight first just in case this instance is deleted | 115   // Change the highlight first just in case this instance is deleted | 
| 116   // while calling the controller | 116   // while calling the controller | 
| 117   SetHighlighted(false); | 117   SetHighlighted(false); | 
| 118   if (enabled_ && !canceled && | 118   if (enabled_ && (event.IsLeftMouseButton() || event.IsMiddleMouseButton()) && | 
| 119       (e.IsLeftMouseButton() || e.IsMiddleMouseButton()) && | 119       HitTest(event.location())) { | 
| 120       HitTest(e.location())) { |  | 
| 121     // Focus the link on click. | 120     // Focus the link on click. | 
| 122     RequestFocus(); | 121     RequestFocus(); | 
| 123 | 122 | 
| 124     if (controller_) | 123     if (controller_) | 
| 125       controller_->LinkActivated(this, e.flags()); | 124       controller_->LinkActivated(this, event.flags()); | 
| 126   } | 125   } | 
| 127 } | 126 } | 
| 128 | 127 | 
| 129 bool Link::OnKeyPressed(const KeyEvent& e) { | 128 void Link::OnMouseCaptureLost() { | 
| 130   bool activate = ((e.key_code() == ui::VKEY_SPACE) || | 129   SetHighlighted(false); | 
| 131                    (e.key_code() == ui::VKEY_RETURN)); | 130 } | 
|  | 131 | 
|  | 132 bool Link::OnKeyPressed(const KeyEvent& event) { | 
|  | 133   bool activate = ((event.key_code() == ui::VKEY_SPACE) || | 
|  | 134                    (event.key_code() == ui::VKEY_RETURN)); | 
| 132   if (!activate) | 135   if (!activate) | 
| 133     return false; | 136     return false; | 
| 134 | 137 | 
| 135   SetHighlighted(false); | 138   SetHighlighted(false); | 
| 136 | 139 | 
| 137   // Focus the link on key pressed. | 140   // Focus the link on key pressed. | 
| 138   RequestFocus(); | 141   RequestFocus(); | 
| 139 | 142 | 
| 140   if (controller_) | 143   if (controller_) | 
| 141     controller_->LinkActivated(this, e.flags()); | 144     controller_->LinkActivated(this, event.flags()); | 
| 142 | 145 | 
| 143   return true; | 146   return true; | 
| 144 } | 147 } | 
| 145 | 148 | 
| 146 bool Link::SkipDefaultKeyEventProcessing(const KeyEvent& e) { | 149 bool Link::SkipDefaultKeyEventProcessing(const KeyEvent& event) { | 
| 147   // Make sure we don't process space or enter as accelerators. | 150   // Make sure we don't process space or enter as accelerators. | 
| 148   return (e.key_code() == ui::VKEY_SPACE) || | 151   return (event.key_code() == ui::VKEY_SPACE) || | 
| 149       (e.key_code() == ui::VKEY_RETURN); | 152       (event.key_code() == ui::VKEY_RETURN); | 
| 150 } | 153 } | 
| 151 | 154 | 
| 152 void Link::GetAccessibleState(ui::AccessibleViewState* state) { | 155 void Link::GetAccessibleState(ui::AccessibleViewState* state) { | 
| 153   Label::GetAccessibleState(state); | 156   Label::GetAccessibleState(state); | 
| 154   state->role = ui::AccessibilityTypes::ROLE_LINK; | 157   state->role = ui::AccessibilityTypes::ROLE_LINK; | 
| 155 } | 158 } | 
| 156 | 159 | 
| 157 void Link::SetFont(const gfx::Font& font) { | 160 void Link::SetFont(const gfx::Font& font) { | 
| 158   Label::SetFont(font); | 161   Label::SetFont(font); | 
| 159   ValidateStyle(); | 162   ValidateStyle(); | 
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 222   } else { | 225   } else { | 
| 223     if (font().GetStyle() & gfx::Font::UNDERLINED) { | 226     if (font().GetStyle() & gfx::Font::UNDERLINED) { | 
| 224       Label::SetFont( | 227       Label::SetFont( | 
| 225           font().DeriveFont(0, font().GetStyle() & ~gfx::Font::UNDERLINED)); | 228           font().DeriveFont(0, font().GetStyle() & ~gfx::Font::UNDERLINED)); | 
| 226     } | 229     } | 
| 227     Label::SetColor(disabled_color_); | 230     Label::SetColor(disabled_color_); | 
| 228   } | 231   } | 
| 229 } | 232 } | 
| 230 | 233 | 
| 231 }  // namespace views | 234 }  // namespace views | 
| OLD | NEW | 
|---|