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

Unified Diff: skia/ext/cdl_picture.cc

Issue 2523673004: [NOT FOR COMMIT] Fully replace SkCanvas uses.
Patch Set: Support Android build. Created 4 years 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 | « skia/ext/cdl_picture.h ('k') | skia/ext/cdl_picture_buffer.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: skia/ext/cdl_picture.cc
diff --git a/skia/ext/cdl_picture.cc b/skia/ext/cdl_picture.cc
new file mode 100644
index 0000000000000000000000000000000000000000..242fa9ceff95ac3254727d4c73bd7d9d5f6697dd
--- /dev/null
+++ b/skia/ext/cdl_picture.cc
@@ -0,0 +1,61 @@
+// Copyright (c) 2013 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 "skia/ext/cdl_picture.h"
+
+#if CDL_ENABLED
+
+#include <stddef.h>
+#include <stdint.h>
+
+#include "base/atomicops.h"
+#include "base/logging.h"
+#include "third_party/skia/include/core/SkPicture.h"
+#include "third_party/skia/include/core/SkPictureRecorder.h"
+
+#include "skia/ext/cdl_picture_buffer.h"
+
+CdlPicture::CdlPicture(sk_sp<CdlPictureBuffer> picture,
+ SkRect cull_bounds,
+ int start_offset,
+ int end_offset)
+ : picture_(picture),
+ cull_bounds_(cull_bounds),
+ start_offset_(start_offset),
+ end_offset_(end_offset) {}
+
+CdlPicture::~CdlPicture() {}
+
+void CdlPicture::draw(CdlCanvas* canvas,
+ const SkMatrix* matrix,
+ const CdlPaint* paint) const {
+ canvas->drawPicture(this, matrix, paint);
+}
+
+sk_sp<SkPicture> CdlPicture::toSkPicture() const {
+ SkPictureRecorder recorder;
+ SkCanvas* canvas = recorder.beginRecording(cullRect());
+ picture_->playback(CdlCanvas::Make(canvas).get(), start_offset_, end_offset_);
+
+ return recorder.finishRecordingAsPicture();
+}
+
+void CdlPicture::playback(CdlCanvas* canvas,
+ SkPicture::AbortCallback* callback) const {
+ // TODO(cdl): CdlPicture doesn't support AbortCallback.
+ int save_count = canvas->getSaveCount();
+ canvas->save();
+ picture_->playback(canvas, start_offset_, end_offset_);
+ canvas->restoreToCount(save_count);
+}
+
+uint32_t CdlPicture::uniqueID() const {
+ if (!unique_id_) {
+ static base::subtle::Atomic32 g_next_id = 1;
+ unique_id_ = base::subtle::Barrier_AtomicIncrement(&g_next_id, 1);
+ }
+ return unique_id_;
+}
+
+#endif // CDL_ENABLED
« no previous file with comments | « skia/ext/cdl_picture.h ('k') | skia/ext/cdl_picture_buffer.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698