| Index: examples/surfaces_app/surfaces_app.cc
|
| diff --git a/examples/surfaces_app/surfaces_app.cc b/examples/surfaces_app/surfaces_app.cc
|
| index e0f972daf3d93f430ecb833c76dc98afb380104c..ae5622d69df3deb05fade168e0edaff37b812d3a 100644
|
| --- a/examples/surfaces_app/surfaces_app.cc
|
| +++ b/examples/surfaces_app/surfaces_app.cc
|
| @@ -20,7 +20,6 @@
|
| #include "mojo/services/gpu/public/interfaces/gpu.mojom.h"
|
| #include "mojo/services/native_viewport/public/interfaces/native_viewport.mojom.h"
|
| #include "mojo/services/surfaces/public/interfaces/surfaces.mojom.h"
|
| -#include "mojo/services/surfaces/public/interfaces/surfaces_service.mojom.h"
|
| #include "ui/gfx/rect.h"
|
|
|
| namespace mojo {
|
| @@ -30,18 +29,17 @@ class SurfacesApp : public ApplicationDelegate,
|
| public SurfaceClient,
|
| public NativeViewportClient {
|
| public:
|
| - SurfacesApp() : weak_factory_(this) {}
|
| - virtual ~SurfacesApp() {}
|
| + SurfacesApp() : onscreen_id_(SurfaceId::New()), weak_factory_(this) {}
|
| + ~SurfacesApp() override {}
|
|
|
| // ApplicationDelegate implementation
|
| - virtual bool ConfigureIncomingConnection(
|
| - ApplicationConnection* connection) override {
|
| + bool ConfigureIncomingConnection(ApplicationConnection* connection) override {
|
| connection->ConnectToService("mojo:native_viewport_service", &viewport_);
|
| viewport_.set_client(this);
|
|
|
| - connection->ConnectToService("mojo:surfaces_service", &surfaces_service_);
|
| - surfaces_service_->CreateSurfaceConnection(base::Bind(
|
| - &SurfacesApp::SurfaceConnectionCreated, base::Unretained(this)));
|
| + connection->ConnectToService("mojo:surfaces_service", &surface_);
|
| + surface_.set_client(this);
|
| + embedder_.set_surface(surface_.get());
|
|
|
| size_ = gfx::Size(800, 600);
|
|
|
| @@ -76,8 +74,8 @@ class SurfacesApp : public ApplicationDelegate,
|
| int bounced_offset = offset;
|
| if (offset > 200)
|
| bounced_offset = 400 - offset;
|
| - embedder_->ProduceFrame(
|
| - child_one_id_, child_two_id_, child_size_, size_, bounced_offset);
|
| + embedder_.ProduceFrame(child_one_id_, child_two_id_, child_size_, size_,
|
| + bounced_offset);
|
| base::MessageLoop::current()->PostDelayedTask(
|
| FROM_HERE,
|
| base::Bind(
|
| @@ -85,35 +83,27 @@ class SurfacesApp : public ApplicationDelegate,
|
| base::TimeDelta::FromMilliseconds(50));
|
| }
|
|
|
| - void SurfaceConnectionCreated(SurfacePtr surface, uint32_t id_namespace) {
|
| - surface_ = surface.Pass();
|
| - surface_.set_client(this);
|
| - embedder_.reset(new Embedder(surface_.get()));
|
| - allocator_.reset(new cc::SurfaceIdAllocator(id_namespace));
|
| -
|
| - onscreen_id_ = allocator_->GenerateId();
|
| - embedder_->SetSurfaceId(onscreen_id_);
|
| - surface_->CreateSurface(SurfaceId::From(onscreen_id_), Size::From(size_));
|
| - viewport_->SubmittedFrame(SurfaceId::From(onscreen_id_));
|
| + // SurfaceClient implementation.
|
| + void SetIdNamespace(uint32_t id_namespace) override {
|
| + onscreen_id_->id_namespace = id_namespace;
|
| + embedder_.set_surface_id(onscreen_id_.Clone());
|
| + surface_->CreateSurface(onscreen_id_.Clone());
|
| + viewport_->SubmittedFrame(onscreen_id_.Clone());
|
| Draw(10);
|
| }
|
| -
|
| - // SurfaceClient implementation.
|
| - virtual void ReturnResources(Array<ReturnedResourcePtr> resources) override {
|
| + void ReturnResources(Array<ReturnedResourcePtr> resources) override {
|
| DCHECK(!resources.size());
|
| }
|
| // NativeViewportClient implementation.
|
| - virtual void OnSizeChanged(mojo::SizePtr size) override {}
|
| - virtual void OnDestroyed() override {}
|
| + void OnSizeChanged(mojo::SizePtr size) override {}
|
| + void OnDestroyed() override {}
|
|
|
| private:
|
| void OnCreatedNativeViewport(uint64_t native_viewport_id) {}
|
|
|
| - SurfacesServicePtr surfaces_service_;
|
| SurfacePtr surface_;
|
| - cc::SurfaceId onscreen_id_;
|
| - scoped_ptr<cc::SurfaceIdAllocator> allocator_;
|
| - scoped_ptr<Embedder> embedder_;
|
| + SurfaceIdPtr onscreen_id_;
|
| + Embedder embedder_;
|
| ChildPtr child_one_;
|
| cc::SurfaceId child_one_id_;
|
| ChildPtr child_two_;
|
|
|