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

Unified Diff: sky/engine/core/loader/NewImageLoader.cpp

Issue 1151753009: Add Sky framework support for drawing images (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: More style fixes, ran git cl format Created 5 years, 7 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
Index: sky/engine/core/loader/NewImageLoader.cpp
diff --git a/sky/engine/core/loader/NewImageLoader.cpp b/sky/engine/core/loader/NewImageLoader.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..a85dd3609dbf81b541e2c731d4f3ba26322bae50
--- /dev/null
+++ b/sky/engine/core/loader/NewImageLoader.cpp
@@ -0,0 +1,45 @@
+// Copyright 2015 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 "sky/engine/config.h"
+#include "sky/engine/core/loader/NewImageLoader.h"
+#include "sky/engine/platform/image-decoders/ImageDecoder.h"
+#include "sky/engine/platform/SharedBuffer.h"
+
+namespace blink {
+
+void NewImageLoader::Load(const KURL& src) {
+ fetcher_ = adoptPtr(new MojoFetcher(this, src));
abarth-chromium 2015/05/29 23:04:10 What happens if someone calls |Load| a second time
jackson 2015/05/29 23:35:43 OK, I changed it to not null the client
+}
+
+void NewImageLoader::OnReceivedResponse(mojo::URLResponsePtr response) {
+ if (response->status_code != 200) {
+ client_->notifyLoadFinished(SkBitmap());
+ client_ = nullptr;
+ return;
+ }
+ buffer_ = SharedBuffer::create();
+ drainer_ =
+ adoptPtr(new mojo::common::DataPipeDrainer(this, response->body.Pass()));
+}
+
+void NewImageLoader::OnDataAvailable(const void* data, size_t num_bytes) {
+ buffer_->append(static_cast<const char*>(data), num_bytes);
+}
+
+void NewImageLoader::OnDataComplete() {
+ OwnPtr<ImageDecoder> decoder =
+ ImageDecoder::create(*buffer_.get(), ImageSource::AlphaPremultiplied,
+ ImageSource::GammaAndColorProfileIgnored);
+ decoder->setData(buffer_.get(), true);
+ if (decoder->failed()) {
+ client_->notifyLoadFinished(SkBitmap());
+ } else {
+ ImageFrame* frame = decoder->frameBufferAtIndex(0);
abarth-chromium 2015/05/29 23:04:10 Is it possible for an image to have zero frames?
jackson 2015/05/29 23:35:43 Looks like maybe. I'll add a guard
+ SkBitmap bitmap = frame->getSkBitmap();
+ client_->notifyLoadFinished(bitmap);
+ }
+ client_ = nullptr;
+}
+}
abarth-chromium 2015/05/29 23:04:10 } // namespace blink
jackson 2015/05/29 23:35:43 Acknowledged.

Powered by Google App Engine
This is Rietveld 408576698