diff options
Diffstat (limited to 'mojo/examples/browser/browser.cc')
-rw-r--r-- | mojo/examples/browser/browser.cc | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/mojo/examples/browser/browser.cc b/mojo/examples/browser/browser.cc index 85a6bcb..9757d0f 100644 --- a/mojo/examples/browser/browser.cc +++ b/mojo/examples/browser/browser.cc @@ -9,19 +9,24 @@ #include "mojo/services/public/cpp/view_manager/view_manager_delegate.h" #include "mojo/services/public/cpp/view_manager/view_observer.h" #include "mojo/services/public/cpp/view_manager/view_tree_node.h" +#include "mojo/services/public/interfaces/launcher/launcher.mojom.h" #include "mojo/views/native_widget_view_manager.h" #include "mojo/views/views_init.h" #include "ui/views/controls/textfield/textfield.h" +#include "ui/views/controls/textfield/textfield_controller.h" #include "ui/views/layout/fill_layout.h" #include "ui/views/widget/widget.h" #include "ui/views/widget/widget_delegate.h" +#include "url/gurl.h" namespace mojo { namespace examples { // This is the basics of creating a views widget with a textfield. // TODO: cleanup! -class Browser : public Application, public view_manager::ViewManagerDelegate { +class Browser : public Application, + public view_manager::ViewManagerDelegate, + public views::TextfieldController { public: Browser() : view_manager_(NULL), view_(NULL) {} @@ -34,10 +39,13 @@ class Browser : public Application, public view_manager::ViewManagerDelegate { views_init_.reset(new ViewsInit); view_manager::ViewManager::Create(this, this); + + ConnectTo("mojo:mojo_launcher", &launcher_); } void CreateWidget() { views::Textfield* textfield = new views::Textfield; + textfield->set_controller(this); views::WidgetDelegateView* widget_delegate = new views::WidgetDelegateView; widget_delegate->GetContentsView()->AddChildView(textfield); @@ -67,10 +75,22 @@ class Browser : public Application, public view_manager::ViewManagerDelegate { view_manager::ViewTreeNode* root) OVERRIDE { } + // views::TextfieldController: + virtual bool HandleKeyEvent(views::Textfield* sender, + const ui::KeyEvent& key_event) OVERRIDE { + if (key_event.key_code() == ui::VKEY_RETURN) { + GURL url(sender->text()); + printf("User entered this URL: %s\n", url.spec().c_str()); + launcher_->Launch(url.spec()); + } + return false; + } + scoped_ptr<ViewsInit> views_init_; view_manager::ViewManager* view_manager_; view_manager::View* view_; + launcher::LauncherPtr launcher_; DISALLOW_COPY_AND_ASSIGN(Browser); }; |