| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 #ifndef APPS_MOTERM_MOTERM_VIEW_H_ | 5 #ifndef APPS_MOTERM_MOTERM_VIEW_H_ |
| 6 #define APPS_MOTERM_MOTERM_VIEW_H_ | 6 #define APPS_MOTERM_MOTERM_VIEW_H_ |
| 7 | 7 |
| 8 #include "apps/moterm/gl_helper.h" | 8 #include <memory> |
| 9 |
| 9 #include "apps/moterm/moterm_driver.h" | 10 #include "apps/moterm/moterm_driver.h" |
| 10 #include "apps/moterm/moterm_model.h" | 11 #include "apps/moterm/moterm_model.h" |
| 11 #include "base/macros.h" | 12 #include "base/macros.h" |
| 12 #include "base/memory/weak_ptr.h" | 13 #include "base/memory/weak_ptr.h" |
| 13 #include "mojo/common/binding_set.h" | 14 #include "mojo/common/binding_set.h" |
| 14 #include "mojo/public/cpp/application/interface_factory.h" | 15 #include "mojo/public/cpp/application/interface_factory.h" |
| 15 #include "mojo/public/cpp/application/service_provider_impl.h" | 16 #include "mojo/public/cpp/application/service_provider_impl.h" |
| 16 #include "mojo/public/cpp/bindings/callback.h" | 17 #include "mojo/public/cpp/bindings/callback.h" |
| 17 #include "mojo/public/cpp/bindings/interface_request.h" | 18 #include "mojo/public/cpp/bindings/interface_request.h" |
| 18 #include "mojo/services/surfaces/interfaces/surface_id.mojom.h" | 19 #include "mojo/services/input_events/interfaces/input_event_constants.mojom.h" |
| 20 #include "mojo/services/input_events/interfaces/input_events.mojom.h" |
| 19 #include "mojo/services/terminal/interfaces/terminal.mojom.h" | 21 #include "mojo/services/terminal/interfaces/terminal.mojom.h" |
| 20 #include "mojo/services/view_manager/cpp/view_observer.h" | 22 #include "mojo/ui/choreographer.h" |
| 21 #include "skia/ext/refptr.h" | 23 #include "mojo/ui/ganesh_view.h" |
| 24 #include "mojo/ui/input_handler.h" |
| 22 #include "third_party/skia/include/core/SkBitmapDevice.h" | 25 #include "third_party/skia/include/core/SkBitmapDevice.h" |
| 23 #include "third_party/skia/include/core/SkTypeface.h" | 26 #include "third_party/skia/include/core/SkTypeface.h" |
| 24 | 27 |
| 25 namespace mojo { | 28 class MotermView : public mojo::ui::GaneshView, |
| 26 class Shell; | 29 public mojo::ui::ChoreographerDelegate, |
| 27 } | 30 public mojo::ui::InputListener, |
| 28 | |
| 29 class MotermView : public mojo::ViewObserver, | |
| 30 public GlHelper::Client, | |
| 31 public MotermModel::Delegate, | 31 public MotermModel::Delegate, |
| 32 public MotermDriver::Client, | 32 public MotermDriver::Client, |
| 33 public mojo::InterfaceFactory<mojo::terminal::Terminal>, | 33 public mojo::InterfaceFactory<mojo::terminal::Terminal>, |
| 34 public mojo::terminal::Terminal { | 34 public mojo::terminal::Terminal { |
| 35 public: | 35 public: |
| 36 MotermView( | 36 MotermView( |
| 37 mojo::Shell* shell, | 37 mojo::ApplicationImpl* app_impl, |
| 38 mojo::View* view, | 38 mojo::InterfaceRequest<mojo::ServiceProvider> service_provider_request, |
| 39 mojo::InterfaceRequest<mojo::ServiceProvider> service_provider_request); | 39 const mojo::ui::ViewProvider::CreateViewCallback& create_view_callback); |
| 40 ~MotermView() override; | 40 ~MotermView() override; |
| 41 | 41 |
| 42 private: | 42 private: |
| 43 // |mojo::ViewObserver|: | 43 // |mojo::ui::View|: |
| 44 void OnViewDestroyed(mojo::View* view) override; | 44 void OnLayout(mojo::ui::ViewLayoutParamsPtr layout_params, |
| 45 void OnViewBoundsChanged(mojo::View* view, | 45 mojo::Array<uint32_t> children_needing_layout, |
| 46 const mojo::Rect& old_bounds, | 46 const OnLayoutCallback& callback) override; |
| 47 const mojo::Rect& new_bounds) override; | |
| 48 void OnViewInputEvent(mojo::View* view, const mojo::EventPtr& event) override; | |
| 49 | 47 |
| 50 // |GlHelper::Client|: | 48 // |mojo::ui::ChoreographerDelegate|: |
| 51 void OnSurfaceIdChanged(mojo::SurfaceIdPtr surface_id) override; | 49 void OnDraw(const mojo::gfx::composition::FrameInfo& frame_info, |
| 52 void OnContextLost() override; | 50 const base::TimeDelta& time_delta) override; |
| 53 void OnFrameDisplayed(uint32_t frame_id) override; | 51 |
| 52 // |mojo::ui::InputListener|: |
| 53 void OnEvent(mojo::EventPtr event, const OnEventCallback& callback) override; |
| 54 | 54 |
| 55 // |MotermModel::Delegate|: | 55 // |MotermModel::Delegate|: |
| 56 void OnResponse(const void* buf, size_t size) override; | 56 void OnResponse(const void* buf, size_t size) override; |
| 57 void OnSetKeypadMode(bool application_mode) override; | 57 void OnSetKeypadMode(bool application_mode) override; |
| 58 | 58 |
| 59 // |MotermDriver::Client|: | 59 // |MotermDriver::Client|: |
| 60 void OnDataReceived(const void* bytes, size_t num_bytes) override; | 60 void OnDataReceived(const void* bytes, size_t num_bytes) override; |
| 61 void OnClosed() override; | 61 void OnClosed() override; |
| 62 void OnDestroyed() override; | 62 void OnDestroyed() override; |
| 63 | 63 |
| (...skipping 10 matching lines...) Expand all Loading... |
| 74 bool force, | 74 bool force, |
| 75 const ConnectToClientCallback& callback) override; | 75 const ConnectToClientCallback& callback) override; |
| 76 void GetSize(const GetSizeCallback& callback) override; | 76 void GetSize(const GetSizeCallback& callback) override; |
| 77 void SetSize(uint32_t rows, | 77 void SetSize(uint32_t rows, |
| 78 uint32_t columns, | 78 uint32_t columns, |
| 79 bool reset, | 79 bool reset, |
| 80 const SetSizeCallback& callback) override; | 80 const SetSizeCallback& callback) override; |
| 81 | 81 |
| 82 // If |force| is true, it will draw everything. Otherwise it will draw only if | 82 // If |force| is true, it will draw everything. Otherwise it will draw only if |
| 83 // |model_state_changes_| is dirty. | 83 // |model_state_changes_| is dirty. |
| 84 void Draw(bool force); | 84 void ScheduleDraw(bool force); |
| 85 void DrawContent(SkCanvas* canvas); |
| 85 | 86 |
| 86 void OnKeyPressed(const mojo::EventPtr& key_event); | 87 void OnKeyPressed(mojo::EventPtr key_event); |
| 87 | 88 |
| 88 mojo::View* const view_; | 89 mojo::Size view_size_; |
| 89 GlHelper gl_helper_; | 90 mojo::ui::Choreographer choreographer_; |
| 91 mojo::ui::InputHandler input_handler_; |
| 90 | 92 |
| 91 // TODO(vtl): Consider the structure of this app. Do we really want the "view" | 93 // TODO(vtl): Consider the structure of this app. Do we really want the "view" |
| 92 // owning the model? | 94 // owning the model? |
| 93 // The terminal model. | 95 // The terminal model. |
| 94 MotermModel model_; | 96 MotermModel model_; |
| 95 // State changes to the model since last draw. | 97 // State changes to the model since last draw. |
| 96 MotermModel::StateChanges model_state_changes_; | 98 MotermModel::StateChanges model_state_changes_; |
| 97 | 99 |
| 98 base::WeakPtr<MotermDriver> driver_; | 100 base::WeakPtr<MotermDriver> driver_; |
| 99 // If set, called when we get |OnClosed()| or |OnDestroyed()| from the driver. | 101 // If set, called when we get |OnClosed()| or |OnDestroyed()| from the driver. |
| 100 mojo::Closure on_closed_callback_; | 102 mojo::Closure on_closed_callback_; |
| 101 | 103 |
| 102 mojo::ServiceProviderImpl service_provider_impl_; | 104 mojo::ServiceProviderImpl service_provider_impl_; |
| 103 mojo::BindingSet<mojo::terminal::Terminal> terminal_bindings_; | 105 mojo::BindingSet<mojo::terminal::Terminal> terminal_bindings_; |
| 104 | 106 |
| 105 // TODO(vtl): For some reason, drawing while a frame is already pending (i.e., | |
| 106 // we've submitted it but haven't gotten a callback) interacts badly with | |
| 107 // resizing -- sometimes this results in us losing all future | |
| 108 // |OnViewBoundsChanged()| messages. So, for now, don't submit frames in that | |
| 109 // case. | |
| 110 bool frame_pending_; | |
| 111 // If we skip drawing despite being forced to, we should force the next draw. | 107 // If we skip drawing despite being forced to, we should force the next draw. |
| 112 bool force_next_draw_; | 108 bool force_next_draw_; |
| 113 | 109 |
| 114 skia::RefPtr<SkTypeface> regular_typeface_; | 110 skia::RefPtr<SkTypeface> regular_typeface_; |
| 115 | 111 |
| 116 int ascent_; | 112 int ascent_; |
| 117 int line_height_; | 113 int line_height_; |
| 118 int advance_width_; | 114 int advance_width_; |
| 119 | 115 |
| 120 skia::RefPtr<SkBitmapDevice> bitmap_device_; | |
| 121 | |
| 122 // Keyboard state. | 116 // Keyboard state. |
| 123 bool keypad_application_mode_; | 117 bool keypad_application_mode_; |
| 124 | 118 |
| 125 DISALLOW_COPY_AND_ASSIGN(MotermView); | 119 DISALLOW_COPY_AND_ASSIGN(MotermView); |
| 126 }; | 120 }; |
| 127 | 121 |
| 128 #endif // APPS_MOTERM_MOTERM_VIEW_H_ | 122 #endif // APPS_MOTERM_MOTERM_VIEW_H_ |
| OLD | NEW |