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

Side by Side Diff: src/effects/SkOffsetImageFilter.cpp

Issue 395603002: Simplify flattening to just write enough to call the factory (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 6 years, 4 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 unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright 2012 The Android Open Source Project 2 * Copyright 2012 The Android Open Source Project
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 7
8 #include "SkOffsetImageFilter.h" 8 #include "SkOffsetImageFilter.h"
9 #include "SkBitmap.h" 9 #include "SkBitmap.h"
10 #include "SkCanvas.h" 10 #include "SkCanvas.h"
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after
84 SkIRect bounds = src; 84 SkIRect bounds = src;
85 bounds.offset(-SkScalarCeilToInt(vec.fX), -SkScalarCeilToInt(vec.fY)); 85 bounds.offset(-SkScalarCeilToInt(vec.fX), -SkScalarCeilToInt(vec.fY));
86 bounds.join(src); 86 bounds.join(src);
87 if (getInput(0)) { 87 if (getInput(0)) {
88 return getInput(0)->filterBounds(bounds, ctm, dst); 88 return getInput(0)->filterBounds(bounds, ctm, dst);
89 } 89 }
90 *dst = bounds; 90 *dst = bounds;
91 return true; 91 return true;
92 } 92 }
93 93
94 SkFlattenable* SkOffsetImageFilter::CreateProc(SkReadBuffer& buffer) {
95 SK_IMAGEFILTER_UNFLATTEN_COMMON(1);
96 SkPoint offset;
97 buffer.readPoint(&offset);
98 return Create(offset.x(), offset.y(), common.inputAt(0), &common.cropRect()) ;
99 }
100
94 void SkOffsetImageFilter::flatten(SkWriteBuffer& buffer) const { 101 void SkOffsetImageFilter::flatten(SkWriteBuffer& buffer) const {
95 this->INHERITED::flatten(buffer); 102 this->INHERITED::flatten(buffer);
96 buffer.writePoint(fOffset); 103 buffer.writePoint(fOffset);
97 } 104 }
98 105
99 SkOffsetImageFilter::SkOffsetImageFilter(SkScalar dx, SkScalar dy, SkImageFilter * input, 106 SkOffsetImageFilter::SkOffsetImageFilter(SkScalar dx, SkScalar dy, SkImageFilter * input,
100 const CropRect* cropRect) 107 const CropRect* cropRect)
101 : INHERITED(1, &input, cropRect) { 108 : INHERITED(1, &input, cropRect) {
102 fOffset.set(dx, dy); 109 fOffset.set(dx, dy);
103 } 110 }
104 111
112 #ifdef SK_SUPPORT_LEGACY_DEEPFLATTENING
105 SkOffsetImageFilter::SkOffsetImageFilter(SkReadBuffer& buffer) 113 SkOffsetImageFilter::SkOffsetImageFilter(SkReadBuffer& buffer)
106 : INHERITED(1, buffer) { 114 : INHERITED(1, buffer) {
107 buffer.readPoint(&fOffset); 115 buffer.readPoint(&fOffset);
108 buffer.validate(SkScalarIsFinite(fOffset.fX) && 116 buffer.validate(SkScalarIsFinite(fOffset.fX) &&
109 SkScalarIsFinite(fOffset.fY)); 117 SkScalarIsFinite(fOffset.fY));
110 } 118 }
119 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698