Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(872)

Unified Diff: mojo/examples/png_viewer/png_viewer.cc

Issue 684543003: Move //mojo/examples to //examples (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « mojo/examples/png_viewer/DEPS ('k') | mojo/examples/sample_app/BUILD.gn » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: mojo/examples/png_viewer/png_viewer.cc
diff --git a/mojo/examples/png_viewer/png_viewer.cc b/mojo/examples/png_viewer/png_viewer.cc
deleted file mode 100644
index 42323a3abd85ec23fc127b241981048f9340248b..0000000000000000000000000000000000000000
--- a/mojo/examples/png_viewer/png_viewer.cc
+++ /dev/null
@@ -1,249 +0,0 @@
-// Copyright 2014 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include <algorithm>
-
-#include "base/macros.h"
-#include "base/memory/scoped_ptr.h"
-#include "base/message_loop/message_loop.h"
-#include "base/strings/string_tokenizer.h"
-#include "mojo/application/application_runner_chromium.h"
-#include "mojo/examples/bitmap_uploader/bitmap_uploader.h"
-#include "mojo/examples/media_viewer/media_viewer.mojom.h"
-#include "mojo/public/c/system/main.h"
-#include "mojo/public/cpp/application/application_connection.h"
-#include "mojo/public/cpp/application/application_delegate.h"
-#include "mojo/public/cpp/application/application_impl.h"
-#include "mojo/public/cpp/application/interface_factory_impl.h"
-#include "mojo/public/cpp/application/service_provider_impl.h"
-#include "mojo/services/public/cpp/view_manager/types.h"
-#include "mojo/services/public/cpp/view_manager/view.h"
-#include "mojo/services/public/cpp/view_manager/view_manager.h"
-#include "mojo/services/public/cpp/view_manager/view_manager_client_factory.h"
-#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/interfaces/content_handler/content_handler.mojom.h"
-#include "skia/ext/platform_canvas.h"
-#include "skia/ext/refptr.h"
-#include "third_party/skia/include/core/SkBitmap.h"
-#include "third_party/skia/include/core/SkCanvas.h"
-#include "third_party/skia/include/core/SkPaint.h"
-#include "third_party/skia/include/core/SkScalar.h"
-#include "ui/gfx/codec/png_codec.h"
-
-namespace mojo {
-namespace examples {
-
-class PNGViewer;
-
-// TODO(aa): Hook up ZoomableMedia interface again.
-class PNGView : public ViewManagerDelegate, public ViewObserver {
- public:
- static void Spawn(URLResponsePtr response,
- ServiceProviderImpl* exported_services,
- scoped_ptr<ServiceProvider> imported_services,
- Shell* shell) {
- // PNGView deletes itself when its View is destroyed.
- new PNGView(
- response.Pass(), exported_services, imported_services.Pass(), shell);
- }
-
- private:
- static const uint16_t kMaxZoomPercentage = 400;
- static const uint16_t kMinZoomPercentage = 20;
- static const uint16_t kDefaultZoomPercentage = 100;
- static const uint16_t kZoomStep = 20;
-
- PNGView(URLResponsePtr response,
- ServiceProviderImpl* exported_services,
- scoped_ptr<ServiceProvider> imported_services,
- Shell* shell)
- : imported_services_(imported_services.Pass()),
- shell_(shell),
- root_(nullptr),
- view_manager_client_factory_(shell, this),
- zoom_percentage_(kDefaultZoomPercentage) {
- exported_services->AddService(&view_manager_client_factory_);
- DecodePNG(response.Pass());
- }
-
- virtual ~PNGView() {
- if (root_)
- root_->RemoveObserver(this);
- }
-
- // Overridden from ViewManagerDelegate:
- virtual void OnEmbed(ViewManager* view_manager,
- View* root,
- ServiceProviderImpl* exported_services,
- scoped_ptr<ServiceProvider> imported_services) override {
- root_ = root;
- root_->AddObserver(this);
- bitmap_uploader_.reset(new BitmapUploader(root_));
- bitmap_uploader_->Init(shell_);
- bitmap_uploader_->SetColor(SK_ColorGRAY);
- if (!bitmap_.isNull())
- DrawBitmap();
- }
-
- virtual void OnViewManagerDisconnected(ViewManager* view_manager) override {
- // TODO(aa): Need to figure out how shutdown works.
- }
-
- // Overridden from ViewObserver:
- virtual void OnViewBoundsChanged(View* view,
- const Rect& old_bounds,
- const Rect& new_bounds) override {
- DCHECK_EQ(view, root_);
- DrawBitmap();
- }
-
- virtual void OnViewDestroyed(View* view) override {
- DCHECK_EQ(view, root_);
- delete this;
- }
-
- void DecodePNG(URLResponsePtr response) {
- int content_length = GetContentLength(response->headers);
- scoped_ptr<unsigned char[]> data(new unsigned char[content_length]);
- unsigned char* buf = data.get();
- uint32_t bytes_remaining = content_length;
- uint32_t num_bytes = bytes_remaining;
- while (bytes_remaining > 0) {
- MojoResult result = ReadDataRaw(
- response->body.get(), buf, &num_bytes, MOJO_READ_DATA_FLAG_NONE);
- if (result == MOJO_RESULT_SHOULD_WAIT) {
- Wait(response->body.get(),
- MOJO_HANDLE_SIGNAL_READABLE,
- MOJO_DEADLINE_INDEFINITE);
- } else if (result == MOJO_RESULT_OK) {
- buf += num_bytes;
- num_bytes = bytes_remaining -= num_bytes;
- } else {
- break;
- }
- }
-
- gfx::PNGCodec::Decode(static_cast<const unsigned char*>(data.get()),
- content_length,
- &bitmap_);
- }
-
- void DrawBitmap() {
- if (!root_)
- return;
-
- skia::RefPtr<SkCanvas> canvas(skia::AdoptRef(skia::CreatePlatformCanvas(
- root_->bounds().width, root_->bounds().height, true)));
- canvas->drawColor(SK_ColorGRAY);
- SkPaint paint;
- SkScalar scale =
- SkFloatToScalar(zoom_percentage_ * 1.0f / kDefaultZoomPercentage);
- canvas->scale(scale, scale);
- canvas->drawBitmap(bitmap_, 0, 0, &paint);
- bitmap_uploader_->SetBitmap(
- skia::GetTopDevice(*canvas)->accessBitmap(true));
- }
-
- void ZoomIn() {
- if (zoom_percentage_ >= kMaxZoomPercentage)
- return;
- zoom_percentage_ += kZoomStep;
- DrawBitmap();
- }
-
- void ZoomOut() {
- if (zoom_percentage_ <= kMinZoomPercentage)
- return;
- zoom_percentage_ -= kZoomStep;
- DrawBitmap();
- }
-
- void ZoomToActualSize() {
- if (zoom_percentage_ == kDefaultZoomPercentage)
- return;
- zoom_percentage_ = kDefaultZoomPercentage;
- DrawBitmap();
- }
-
- int GetContentLength(const Array<String>& headers) {
- for (size_t i = 0; i < headers.size(); ++i) {
- base::StringTokenizer t(headers[i], ": ;=");
- while (t.GetNext()) {
- if (!t.token_is_delim() && t.token() == "Content-Length") {
- while (t.GetNext()) {
- if (!t.token_is_delim())
- return atoi(t.token().c_str());
- }
- }
- }
- }
- return 0;
- }
-
- SkBitmap bitmap_;
- scoped_ptr<ServiceProvider> imported_services_;
- Shell* shell_;
- View* root_;
- ViewManagerClientFactory view_manager_client_factory_;
- uint16_t zoom_percentage_;
- scoped_ptr<BitmapUploader> bitmap_uploader_;
-
- DISALLOW_COPY_AND_ASSIGN(PNGView);
-};
-
-class ContentHandlerImpl : public InterfaceImpl<ContentHandler> {
- public:
- explicit ContentHandlerImpl(Shell* shell) : shell_(shell) {}
- virtual ~ContentHandlerImpl() {}
-
- private:
- // Overridden from ContentHandler:
- virtual void OnConnect(
- const mojo::String& requestor_url,
- URLResponsePtr response,
- InterfaceRequest<ServiceProvider> service_provider) override {
- ServiceProviderImpl* exported_services = new ServiceProviderImpl();
- BindToRequest(exported_services, &service_provider);
- scoped_ptr<ServiceProvider> remote(
- exported_services->CreateRemoteServiceProvider());
- PNGView::Spawn(response.Pass(), exported_services, remote.Pass(), shell_);
- }
-
- Shell* shell_;
-
- DISALLOW_COPY_AND_ASSIGN(ContentHandlerImpl);
-};
-
-class PNGViewer : public ApplicationDelegate {
- public:
- PNGViewer() {}
- private:
- // Overridden from ApplicationDelegate:
- virtual void Initialize(ApplicationImpl* app) override {
- content_handler_factory_.reset(
- new InterfaceFactoryImplWithContext<ContentHandlerImpl, Shell>(
- app->shell()));
- }
-
- // Overridden from ApplicationDelegate:
- virtual bool ConfigureIncomingConnection(
- ApplicationConnection* connection) override {
- connection->AddService(content_handler_factory_.get());
- return true;
- }
-
- scoped_ptr<InterfaceFactoryImplWithContext<ContentHandlerImpl, Shell> >
- content_handler_factory_;
-
- DISALLOW_COPY_AND_ASSIGN(PNGViewer);
-};
-
-} // namespace examples
-} // namespace mojo
-
-MojoResult MojoMain(MojoHandle shell_handle) {
- mojo::ApplicationRunnerChromium runner(new mojo::examples::PNGViewer);
- return runner.Run(shell_handle);
-}
« no previous file with comments | « mojo/examples/png_viewer/DEPS ('k') | mojo/examples/sample_app/BUILD.gn » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698