aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core
diff options
context:
space:
mode:
Diffstat (limited to 'src/core')
-rw-r--r--src/core/SkCanvas.cpp69
-rw-r--r--src/core/SkPictureFlat.h4
-rw-r--r--src/core/SkPicturePlayback.cpp14
-rw-r--r--src/core/SkPictureRecord.cpp30
-rw-r--r--src/core/SkPictureRecord.h2
-rw-r--r--src/core/SkRecordDraw.cpp4
-rw-r--r--src/core/SkRecorder.cpp8
-rw-r--r--src/core/SkRecorder.h3
-rw-r--r--src/core/SkRecords.h5
9 files changed, 6 insertions, 133 deletions
diff --git a/src/core/SkCanvas.cpp b/src/core/SkCanvas.cpp
index 294562ad92..a72b58c7cb 100644
--- a/src/core/SkCanvas.cpp
+++ b/src/core/SkCanvas.cpp
@@ -417,7 +417,6 @@ SkBaseDevice* SkCanvas::init(SkBaseDevice* device, InitFlags flags) {
fDeviceCMDirty = true;
fSaveCount = 1;
fSaveLayerCount = 0;
- fCullCount = 0;
fMetaData = NULL;
fMCRec = (MCRec*)fMCStack.push_back();
@@ -696,7 +695,7 @@ bool SkCanvas::readPixels(const SkImageInfo& dstInfo, void* dstP, size_t rowByte
return false;
}
const SkISize size = this->getBaseLayerSize();
-
+
SkReadPixelsRec rec(dstInfo, dstP, rowBytes, x, y);
if (!rec.trim(size.width(), size.height())) {
return false;
@@ -844,7 +843,7 @@ void SkCanvas::restoreToCount(int count) {
if (count < 1) {
count = 1;
}
-
+
int n = this->getSaveCount() - count;
for (int i = 0; i < n; ++i) {
this->restore();
@@ -1119,71 +1118,7 @@ bool SkAutoROCanvasPixels::asROBitmap(SkBitmap* bitmap) const {
}
}
-void SkCanvas::onPushCull(const SkRect& cullRect) {
- // do nothing. Subclasses may do something
-}
-
-void SkCanvas::onPopCull() {
- // do nothing. Subclasses may do something
-}
-
/////////////////////////////////////////////////////////////////////////////
-#ifdef SK_DEBUG
-// Ensure that cull rects are monotonically nested in device space.
-void SkCanvas::validateCull(const SkIRect& devCull) {
- if (fCullStack.isEmpty()
- || devCull.isEmpty()
- || fCullStack.top().contains(devCull)) {
- return;
- }
-
- SkDEBUGF(("Invalid cull: [%d %d %d %d] (previous cull: [%d %d %d %d])\n",
- devCull.x(), devCull.y(), devCull.right(), devCull.bottom(),
- fCullStack.top().x(), fCullStack.top().y(),
- fCullStack.top().right(), fCullStack.top().bottom()));
-
-#ifdef ASSERT_NESTED_CULLING
- SkDEBUGFAIL("Invalid cull.");
-#endif
-}
-#endif
-
-void SkCanvas::pushCull(const SkRect& cullRect) {
- this->checkForDeferredSave();
- ++fCullCount;
- this->onPushCull(cullRect);
-
-#ifdef SK_DEBUG
- // Map the cull rect into device space.
- SkRect mappedCull;
- this->getTotalMatrix().mapRect(&mappedCull, cullRect);
-
- // Take clipping into account.
- SkIRect devClip, devCull;
- mappedCull.roundOut(&devCull);
- this->getClipDeviceBounds(&devClip);
- if (!devCull.intersect(devClip)) {
- devCull.setEmpty();
- }
-
- this->validateCull(devCull);
- fCullStack.push(devCull); // balanced in popCull
-#endif
-}
-
-void SkCanvas::popCull() {
- SkASSERT(fCullStack.count() == fCullCount);
-
- if (fCullCount > 0) {
- --fCullCount;
- this->onPopCull();
-
- SkDEBUGCODE(fCullStack.pop());
- }
-}
-
-/////////////////////////////////////////////////////////////////////////////
-
void SkCanvas::internalDrawBitmap(const SkBitmap& bitmap,
const SkMatrix& matrix, const SkPaint* paint) {
if (bitmap.drawsNothing()) {
diff --git a/src/core/SkPictureFlat.h b/src/core/SkPictureFlat.h
index 73248051eb..103eeceb16 100644
--- a/src/core/SkPictureFlat.h
+++ b/src/core/SkPictureFlat.h
@@ -63,8 +63,8 @@ enum DrawType {
// new ops -- feel free to re-alphabetize on next version bump
DRAW_DRRECT,
- PUSH_CULL,
- POP_CULL,
+ PUSH_CULL, // deprecated, M41 was last Chromium version to write this to an .skp
+ POP_CULL, // deprecated, M41 was last Chromium version to write this to an .skp
DRAW_PATCH, // could not add in aphabetical order
DRAW_PICTURE_MATRIX_PAINT,
diff --git a/src/core/SkPicturePlayback.cpp b/src/core/SkPicturePlayback.cpp
index b4cac52dd4..1c9b13e445 100644
--- a/src/core/SkPicturePlayback.cpp
+++ b/src/core/SkPicturePlayback.cpp
@@ -148,18 +148,8 @@ void SkPicturePlayback::handleOp(SkReader32* reader,
reader->setOffset(offsetToRestore);
}
} break;
- case PUSH_CULL: {
- const SkRect& cullRect = reader->skipT<SkRect>();
- size_t offsetToRestore = reader->readInt();
- if (offsetToRestore && canvas->quickReject(cullRect)) {
- reader->setOffset(offsetToRestore);
- } else {
- canvas->pushCull(cullRect);
- }
- } break;
- case POP_CULL:
- canvas->popCull();
- break;
+ case PUSH_CULL: break; // Deprecated, safe to ignore both push and pop.
+ case POP_CULL: break;
case CONCAT: {
SkMatrix matrix;
reader->readMatrix(&matrix);
diff --git a/src/core/SkPictureRecord.cpp b/src/core/SkPictureRecord.cpp
index 67c4229e3d..eec6bc0bcb 100644
--- a/src/core/SkPictureRecord.cpp
+++ b/src/core/SkPictureRecord.cpp
@@ -847,36 +847,6 @@ void SkPictureRecord::endCommentGroup() {
this->validate(initialOffset, size);
}
-// [op/size] [rect] [skip offset]
-static const uint32_t kPushCullOpSize = 2 * kUInt32Size + sizeof(SkRect);
-void SkPictureRecord::onPushCull(const SkRect& cullRect) {
- size_t size = kPushCullOpSize;
- size_t initialOffset = this->addDraw(PUSH_CULL, &size);
- // PUSH_CULL's size should stay constant (used to rewind).
- SkASSERT(size == kPushCullOpSize);
-
- this->addRect(cullRect);
- fCullOffsetStack.push(SkToU32(fWriter.bytesWritten()));
- this->addInt(0);
- this->validate(initialOffset, size);
-}
-
-void SkPictureRecord::onPopCull() {
- SkASSERT(!fCullOffsetStack.isEmpty());
-
- uint32_t cullSkipOffset = fCullOffsetStack.top();
- fCullOffsetStack.pop();
-
- // op only
- size_t size = kUInt32Size;
- size_t initialOffset = this->addDraw(POP_CULL, &size);
-
- // update the cull skip offset to point past this op.
- fWriter.overwriteTAt<uint32_t>(cullSkipOffset, SkToU32(fWriter.bytesWritten()));
-
- this->validate(initialOffset, size);
-}
-
///////////////////////////////////////////////////////////////////////////////
SkSurface* SkPictureRecord::onNewSurface(const SkImageInfo& info, const SkSurfaceProps&) {
diff --git a/src/core/SkPictureRecord.h b/src/core/SkPictureRecord.h
index e8ce4bde56..facf30d748 100644
--- a/src/core/SkPictureRecord.h
+++ b/src/core/SkPictureRecord.h
@@ -186,8 +186,6 @@ protected:
virtual void didSetMatrix(const SkMatrix&) SK_OVERRIDE;
virtual void onDrawDRRect(const SkRRect&, const SkRRect&, const SkPaint&) SK_OVERRIDE;
- virtual void onPushCull(const SkRect&) SK_OVERRIDE;
- virtual void onPopCull() SK_OVERRIDE;
virtual void onDrawText(const void* text, size_t byteLength, SkScalar x, SkScalar y,
const SkPaint&) SK_OVERRIDE;
diff --git a/src/core/SkRecordDraw.cpp b/src/core/SkRecordDraw.cpp
index b714e75901..86621f2170 100644
--- a/src/core/SkRecordDraw.cpp
+++ b/src/core/SkRecordDraw.cpp
@@ -81,8 +81,6 @@ template <> void Draw::draw(const NoOp&) {}
DRAW(Restore, restore());
DRAW(Save, save());
DRAW(SaveLayer, saveLayer(r.bounds, r.paint, r.flags));
-DRAW(PopCull, popCull());
-DRAW(PushCull, pushCull(r.rect));
DRAW(Clear, clear(r.color));
DRAW(SetMatrix, setMatrix(SkMatrix::Concat(fInitialCTM, r.matrix)));
@@ -286,8 +284,6 @@ private:
void trackBounds(const ClipRRect&) { this->pushControl(); }
void trackBounds(const ClipPath&) { this->pushControl(); }
void trackBounds(const ClipRegion&) { this->pushControl(); }
- void trackBounds(const PushCull&) { this->pushControl(); }
- void trackBounds(const PopCull&) { this->pushControl(); }
void trackBounds(const BeginCommentGroup&) { this->pushControl(); }
void trackBounds(const AddComment&) { this->pushControl(); }
void trackBounds(const EndCommentGroup&) { this->pushControl(); }
diff --git a/src/core/SkRecorder.cpp b/src/core/SkRecorder.cpp
index e29d43d7d8..71a1167543 100644
--- a/src/core/SkRecorder.cpp
+++ b/src/core/SkRecorder.cpp
@@ -295,14 +295,6 @@ void SkRecorder::didRestore() {
APPEND(Restore, this->devBounds(), this->getTotalMatrix());
}
-void SkRecorder::onPushCull(const SkRect& rect) {
- APPEND(PushCull, rect);
-}
-
-void SkRecorder::onPopCull() {
- APPEND(PopCull);
-}
-
void SkRecorder::didConcat(const SkMatrix& matrix) {
this->didSetMatrix(this->getTotalMatrix());
}
diff --git a/src/core/SkRecorder.h b/src/core/SkRecorder.h
index 102aac5a1d..5d80ac107d 100644
--- a/src/core/SkRecorder.h
+++ b/src/core/SkRecorder.h
@@ -130,9 +130,6 @@ public:
void onDrawPicture(const SkPicture*, const SkMatrix*, const SkPaint*) SK_OVERRIDE;
- void onPushCull(const SkRect& cullRect) SK_OVERRIDE;
- void onPopCull() SK_OVERRIDE;
-
void beginCommentGroup(const char*) SK_OVERRIDE;
void addComment(const char*, const char*) SK_OVERRIDE;
void endCommentGroup() SK_OVERRIDE;
diff --git a/src/core/SkRecords.h b/src/core/SkRecords.h
index d8dfb2b937..ed5eaf3491 100644
--- a/src/core/SkRecords.h
+++ b/src/core/SkRecords.h
@@ -30,8 +30,6 @@ namespace SkRecords {
M(Restore) \
M(Save) \
M(SaveLayer) \
- M(PushCull) \
- M(PopCull) \
M(SetMatrix) \
M(ClipPath) \
M(ClipRRect) \
@@ -225,9 +223,6 @@ RECORD2(Restore, SkIRect, devBounds, TypedMatrix, matrix);
RECORD0(Save);
RECORD3(SaveLayer, Optional<SkRect>, bounds, Optional<SkPaint>, paint, SkCanvas::SaveFlags, flags);
-RECORD1(PushCull, SkRect, rect);
-RECORD0(PopCull);
-
RECORD1(SetMatrix, TypedMatrix, matrix);
struct RegionOpAndAA {