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

Unified Diff: services/image_decoder/public/cpp/decode.cc

Issue 2475543003: Introduce the image_decoder service (Closed)
Patch Set: . Created 4 years, 1 month 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 | « services/image_decoder/public/cpp/decode.h ('k') | services/image_decoder/public/interfaces/BUILD.gn » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: services/image_decoder/public/cpp/decode.cc
diff --git a/services/image_decoder/public/cpp/decode.cc b/services/image_decoder/public/cpp/decode.cc
new file mode 100644
index 0000000000000000000000000000000000000000..24dbd5bf83d9bb5457c9dca755738a18766a4292
--- /dev/null
+++ b/services/image_decoder/public/cpp/decode.cc
@@ -0,0 +1,49 @@
+// Copyright 2016 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 "services/image_decoder/public/cpp/decode.h"
+
+#include "services/image_decoder/public/cpp/constants.h"
+#include "services/service_manager/public/cpp/connector.h"
+#include "third_party/skia/include/core/SkBitmap.h"
+
+namespace image_decoder {
+
+namespace {
+
+// Helper callback which owns an ImageDecoderPtr until invoked. This keeps the
+// ImageDecoder pipe open just long enough to dispatch a reply, at which point
+// the reply is forwarded to the wrapped |callback|.
+void OnDecodeImage(mojom::ImageDecoderPtr decoder,
+ const mojom::ImageDecoder::DecodeImageCallback& callback,
+ const SkBitmap& bitmap) {
+ callback.Run(bitmap);
+}
+
+// Called in the case of a connection error on an ImageDecoder proxy.
+void OnConnectionError(
+ const mojom::ImageDecoder::DecodeImageCallback& callback) {
+ SkBitmap null_bitmap;
+ callback.Run(null_bitmap);
+}
+
+} // namespace
+
+void Decode(service_manager::Connector* connector,
+ const std::vector<uint8_t>& encoded_bytes,
+ mojom::ImageCodec codec,
+ bool shrink_to_fit,
+ uint64_t max_size_in_bytes,
+ const mojom::ImageDecoder::DecodeImageCallback& callback) {
+ mojom::ImageDecoderPtr decoder;
+ connector->ConnectToInterface(kServiceName, &decoder);
+ decoder.set_connection_error_handler(
+ base::Bind(&OnConnectionError, callback));
+ mojom::ImageDecoder* raw_decoder = decoder.get();
+ raw_decoder->DecodeImage(
+ encoded_bytes, codec, shrink_to_fit, max_size_in_bytes,
+ base::Bind(&OnDecodeImage, base::Passed(&decoder), callback));
+}
+
+} // namespace image_decoder
« no previous file with comments | « services/image_decoder/public/cpp/decode.h ('k') | services/image_decoder/public/interfaces/BUILD.gn » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698