Index: examples/sample_app/sample_app.cc |
diff --git a/examples/sample_app/sample_app.cc b/examples/sample_app/sample_app.cc |
index c0ff70ef78bfcec2d7066b6f4694b396c403ccb2..17fee2e377afd67551beca68ef35cee39eca93f1 100644 |
--- a/examples/sample_app/sample_app.cc |
+++ b/examples/sample_app/sample_app.cc |
@@ -21,12 +21,11 @@ |
namespace examples { |
-class SampleApp |
- : public mojo::ApplicationDelegate, |
- public mojo::NativeViewportClient, |
- public mojo::InterfaceImpl<mojo::NativeViewportEventDispatcher> { |
+class SampleApp : public mojo::ApplicationDelegate, |
+ public mojo::NativeViewportEventDispatcher, |
+ public mojo::ErrorHandler { |
public: |
- SampleApp() : weak_factory_(this) {} |
+ SampleApp() : dispatcher_binding_(this), weak_factory_(this) {} |
~SampleApp() override { |
// TODO(darin): Fix shutdown so we don't need to leak this. |
@@ -35,7 +34,7 @@ class SampleApp |
void Initialize(mojo::ApplicationImpl* app) override { |
app->ConnectToService("mojo:native_viewport_service", &viewport_); |
- viewport_.set_client(this); |
+ viewport_.set_error_handler(this); |
SetEventDispatcher(); |
@@ -51,12 +50,12 @@ class SampleApp |
viewport_->Show(); |
} |
- void OnDestroyed() override { mojo::RunLoop::current()->Quit(); } |
- |
- void OnMetricsChanged(mojo::ViewportMetricsPtr metrics) override { |
+ void OnMetricsChanged(mojo::ViewportMetricsPtr metrics) { |
assert(metrics); |
if (gles2_client_) |
gles2_client_->SetSize(*metrics->size); |
+ viewport_->RequestMetrics( |
+ base::Bind(&SampleApp::OnMetricsChanged, weak_factory_.GetWeakPtr())); |
sky
2015/01/28 19:26:41
As this class owns the viewport_ it seems like it
|
} |
void OnEvent(mojo::EventPtr event, |
@@ -69,27 +68,31 @@ class SampleApp |
private: |
void SetEventDispatcher() { |
- mojo::NativeViewportEventDispatcherPtr proxy; |
- mojo::WeakBindToProxy(this, &proxy); |
- viewport_->SetEventDispatcher(proxy.Pass()); |
+ mojo::NativeViewportEventDispatcherPtr ptr; |
+ dispatcher_binding_.Bind(GetProxy(&ptr)); |
+ viewport_->SetEventDispatcher(ptr.Pass()); |
} |
- void OnCreatedNativeViewport(uint64_t native_viewport_id) { |
- mojo::SizePtr size = mojo::Size::New(); |
- size->width = 800; |
- size->height = 600; |
+ void OnCreatedNativeViewport(uint64_t native_viewport_id, |
+ mojo::ViewportMetricsPtr metrics) { |
mojo::ViewportParameterListenerPtr listener; |
mojo::CommandBufferPtr command_buffer; |
// TODO(jamesr): Output to a surface instead. |
- gpu_service_->CreateOnscreenGLES2Context(native_viewport_id, size.Pass(), |
- GetProxy(&command_buffer), |
- listener.Pass()); |
+ gpu_service_->CreateOnscreenGLES2Context( |
+ native_viewport_id, metrics->size.Clone(), GetProxy(&command_buffer), |
+ listener.Pass()); |
gles2_client_.reset(new GLES2ClientImpl(command_buffer.Pass())); |
+ viewport_->RequestMetrics( |
+ base::Bind(&SampleApp::OnMetricsChanged, weak_factory_.GetWeakPtr())); |
} |
+ // ErrorHandler implementation. |
+ void OnConnectionError() override { mojo::RunLoop::current()->Quit(); } |
+ |
scoped_ptr<GLES2ClientImpl> gles2_client_; |
mojo::NativeViewportPtr viewport_; |
mojo::GpuPtr gpu_service_; |
+ mojo::Binding<NativeViewportEventDispatcher> dispatcher_binding_; |
base::WeakPtrFactory<SampleApp> weak_factory_; |
DISALLOW_COPY_AND_ASSIGN(SampleApp); |