OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "services/native_viewport/platform_viewport_android.h" | 5 #include "services/native_viewport/platform_viewport_android.h" |
6 | 6 |
7 #include <android/input.h> | 7 #include <android/input.h> |
8 #include <android/native_window_jni.h> | 8 #include <android/native_window_jni.h> |
9 | 9 |
10 #include "base/android/jni_android.h" | 10 #include "base/android/jni_android.h" |
11 #include "base/bind.h" | 11 #include "base/bind.h" |
12 #include "jni/PlatformViewportAndroid_jni.h" | 12 #include "jni/PlatformViewportAndroid_jni.h" |
13 #include "mojo/converters/geometry/geometry_type_converters.h" | 13 #include "mojo/converters/geometry/geometry_type_converters.h" |
14 #include "mojo/converters/input_events/input_events_type_converters.h" | 14 #include "mojo/converters/input_events/input_events_type_converters.h" |
15 #include "mojo/public/cpp/application/application_impl.h" | |
16 #include "mojo/public/cpp/application/connect.h" | 15 #include "mojo/public/cpp/application/connect.h" |
17 #include "services/native_viewport/native_viewport_support.mojom.h" | 16 #include "services/native_viewport/native_viewport_support.mojom.h" |
18 #include "ui/events/event.h" | 17 #include "ui/events/event.h" |
19 #include "ui/events/keycodes/keyboard_code_conversion_android.h" | 18 #include "ui/events/keycodes/keyboard_code_conversion_android.h" |
20 #include "ui/gfx/point.h" | 19 #include "ui/gfx/point.h" |
21 | 20 |
22 namespace native_viewport { | 21 namespace native_viewport { |
23 namespace { | 22 namespace { |
24 | 23 |
25 mojo::EventType MotionEventActionToEventType(jint action) { | 24 mojo::EventType MotionEventActionToEventType(jint action) { |
(...skipping 22 matching lines...) Expand all Loading... |
48 } // namespace | 47 } // namespace |
49 | 48 |
50 //////////////////////////////////////////////////////////////////////////////// | 49 //////////////////////////////////////////////////////////////////////////////// |
51 // PlatformViewportAndroid, public: | 50 // PlatformViewportAndroid, public: |
52 | 51 |
53 // static | 52 // static |
54 bool PlatformViewportAndroid::Register(JNIEnv* env) { | 53 bool PlatformViewportAndroid::Register(JNIEnv* env) { |
55 return RegisterNativesImpl(env); | 54 return RegisterNativesImpl(env); |
56 } | 55 } |
57 | 56 |
58 PlatformViewportAndroid::PlatformViewportAndroid( | 57 PlatformViewportAndroid::PlatformViewportAndroid(mojo::Shell* shell, |
59 mojo::ApplicationImpl* application, | 58 Delegate* delegate) |
60 Delegate* delegate) | 59 : shell_(shell), |
61 : application_(application), | |
62 delegate_(delegate), | 60 delegate_(delegate), |
63 window_(NULL), | 61 window_(NULL), |
64 id_generator_(0), | 62 id_generator_(0), |
65 weak_factory_(this) {} | 63 weak_factory_(this) {} |
66 | 64 |
67 PlatformViewportAndroid::~PlatformViewportAndroid() { | 65 PlatformViewportAndroid::~PlatformViewportAndroid() { |
68 if (window_) | 66 if (window_) |
69 ReleaseWindow(); | 67 ReleaseWindow(); |
70 JNIEnv* env = base::android::AttachCurrentThread(); | 68 JNIEnv* env = base::android::AttachCurrentThread(); |
71 if (!java_platform_viewport_android_.is_empty()) { | 69 if (!java_platform_viewport_android_.is_empty()) { |
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
160 } | 158 } |
161 | 159 |
162 //////////////////////////////////////////////////////////////////////////////// | 160 //////////////////////////////////////////////////////////////////////////////// |
163 // PlatformViewportAndroid, PlatformViewport implementation: | 161 // PlatformViewportAndroid, PlatformViewport implementation: |
164 | 162 |
165 void PlatformViewportAndroid::Init(const gfx::Rect& bounds) { | 163 void PlatformViewportAndroid::Init(const gfx::Rect& bounds) { |
166 JNIEnv* env = base::android::AttachCurrentThread(); | 164 JNIEnv* env = base::android::AttachCurrentThread(); |
167 Java_PlatformViewportAndroid_createRequest(env, | 165 Java_PlatformViewportAndroid_createRequest(env, |
168 reinterpret_cast<intptr_t>(this)); | 166 reinterpret_cast<intptr_t>(this)); |
169 | 167 |
170 mojo::ConnectToService(application_->shell(), "mojo:native_viewport_support", | 168 mojo::ConnectToService(shell_, "mojo:native_viewport_support", |
171 GetProxy(&support_service_)); | 169 GetProxy(&support_service_)); |
172 support_service_->CreateNewNativeWindow( | 170 support_service_->CreateNewNativeWindow( |
173 base::Bind(&PlatformViewportAndroid::Close, weak_factory_.GetWeakPtr())); | 171 base::Bind(&PlatformViewportAndroid::Close, weak_factory_.GetWeakPtr())); |
174 } | 172 } |
175 | 173 |
176 void PlatformViewportAndroid::Show() { | 174 void PlatformViewportAndroid::Show() { |
177 // Nothing to do. View is created visible. | 175 // Nothing to do. View is created visible. |
178 } | 176 } |
179 | 177 |
180 void PlatformViewportAndroid::Hide() { | 178 void PlatformViewportAndroid::Hide() { |
(...skipping 20 matching lines...) Expand all Loading... |
201 | 199 |
202 void PlatformViewportAndroid::ReleaseWindow() { | 200 void PlatformViewportAndroid::ReleaseWindow() { |
203 ANativeWindow_release(window_); | 201 ANativeWindow_release(window_); |
204 window_ = NULL; | 202 window_ = NULL; |
205 } | 203 } |
206 | 204 |
207 //////////////////////////////////////////////////////////////////////////////// | 205 //////////////////////////////////////////////////////////////////////////////// |
208 // PlatformViewport, public: | 206 // PlatformViewport, public: |
209 | 207 |
210 // static | 208 // static |
211 scoped_ptr<PlatformViewport> PlatformViewport::Create( | 209 scoped_ptr<PlatformViewport> PlatformViewport::Create(mojo::Shell* shell, |
212 mojo::ApplicationImpl* application_, | 210 Delegate* delegate) { |
213 Delegate* delegate) { | |
214 return scoped_ptr<PlatformViewport>( | 211 return scoped_ptr<PlatformViewport>( |
215 new PlatformViewportAndroid(application_, delegate)) | 212 new PlatformViewportAndroid(shell, delegate)) |
216 .Pass(); | 213 .Pass(); |
217 } | 214 } |
218 | 215 |
219 } // namespace native_viewport | 216 } // namespace native_viewport |
OLD | NEW |