Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 | 1 |
| 2 /* | 2 /* |
| 3 * Copyright 2008 The Android Open Source Project | 3 * Copyright 2008 The Android Open Source Project |
| 4 * | 4 * |
| 5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
| 6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
| 7 */ | 7 */ |
| 8 | 8 |
| 9 | 9 |
| 10 #include "SkCanvas.h" | 10 #include "SkCanvas.h" |
| (...skipping 1144 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1155 | 1155 |
| 1156 void SkCanvas::onPushCull(const SkRect& cullRect) { | 1156 void SkCanvas::onPushCull(const SkRect& cullRect) { |
| 1157 // do nothing. Subclasses may do something | 1157 // do nothing. Subclasses may do something |
| 1158 } | 1158 } |
| 1159 | 1159 |
| 1160 void SkCanvas::onPopCull() { | 1160 void SkCanvas::onPopCull() { |
| 1161 // do nothing. Subclasses may do something | 1161 // do nothing. Subclasses may do something |
| 1162 } | 1162 } |
| 1163 | 1163 |
| 1164 ///////////////////////////////////////////////////////////////////////////// | 1164 ///////////////////////////////////////////////////////////////////////////// |
| 1165 #ifdef SK_DEBUG | |
| 1166 // Ensure that cull rects are properly nested in device space. | |
|
robertphillips
2014/03/20 12:23:56
I think this is a bad name since it conflates vali
f(malita)
2014/03/20 13:30:58
Renamed to validateAndTrack().
| |
| 1167 void SkCanvas::validateCull(const SkRect& cull) { | |
| 1168 SkRect mappedCull; | |
| 1169 this->getTotalMatrix().mapRect(&mappedCull, cull); | |
| 1170 | |
| 1171 // Take clipping into account. | |
| 1172 SkIRect devClip, devCull; | |
| 1173 this->getClipDeviceBounds(&devClip); | |
| 1174 mappedCull.roundOut(&devCull); | |
| 1175 if (!devCull.intersect(devClip)) | |
|
robertphillips
2014/03/20 12:23:56
{} needed
f(malita)
2014/03/20 13:30:58
Done.
| |
| 1176 devCull.setEmpty(); | |
| 1177 | |
| 1178 if (!fCullStack.isEmpty() | |
| 1179 && !devCull.isEmpty() | |
| 1180 && !fCullStack.top().contains(devCull)) { | |
| 1181 SkDEBUGF(("Invalid cull: [%d %d %d %d] (previous cull: [%d %d %d %d])\n" , | |
| 1182 devCull.x(), devCull.y(), devCull.right(), devCull.bottom(), | |
| 1183 fCullStack.top().x(), fCullStack.top().y(), | |
| 1184 fCullStack.top().right(), fCullStack.top().bottom())); | |
| 1185 | |
| 1186 #ifdef ASSERT_NESTED_CULLING | |
|
robertphillips
2014/03/20 12:23:56
This assert seems odd inside this code block.
f(malita)
2014/03/20 13:30:58
Hmm, the intention is to provide an easy way to se
| |
| 1187 SkASSERT(fCullStack.top().contains(devCull)); | |
| 1188 #endif | |
| 1189 } | |
| 1190 | |
| 1191 fCullStack.push(devCull); // balanced in popCull | |
| 1192 } | |
| 1193 #endif | |
| 1194 | |
| 1195 void SkCanvas::pushCull(const SkRect& cullRect) { | |
|
robertphillips
2014/03/20 12:23:56
this->
| |
| 1196 SkDEBUGCODE(validateCull(cullRect)); | |
| 1197 | |
| 1198 ++fCullCount; | |
| 1199 this->onPushCull(cullRect); | |
| 1200 } | |
| 1201 | |
| 1202 void SkCanvas::popCull() { | |
| 1203 SkASSERT(fCullStack.count() == fCullCount); | |
| 1204 | |
| 1205 if (fCullCount > 0) { | |
| 1206 SkDEBUGCODE(fCullStack.pop()); | |
| 1207 --fCullCount; | |
| 1208 this->onPopCull(); | |
| 1209 } | |
| 1210 } | |
| 1211 | |
| 1212 ///////////////////////////////////////////////////////////////////////////// | |
| 1165 | 1213 |
| 1166 void SkCanvas::internalDrawBitmap(const SkBitmap& bitmap, | 1214 void SkCanvas::internalDrawBitmap(const SkBitmap& bitmap, |
| 1167 const SkMatrix& matrix, const SkPaint* paint) { | 1215 const SkMatrix& matrix, const SkPaint* paint) { |
| 1168 if (bitmap.drawsNothing()) { | 1216 if (bitmap.drawsNothing()) { |
| 1169 return; | 1217 return; |
| 1170 } | 1218 } |
| 1171 | 1219 |
| 1172 SkLazyPaint lazy; | 1220 SkLazyPaint lazy; |
| 1173 if (NULL == paint) { | 1221 if (NULL == paint) { |
| 1174 paint = lazy.init(); | 1222 paint = lazy.init(); |
| (...skipping 1445 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2620 if (!bitmap.installPixels(info, pixels, rowBytes)) { | 2668 if (!bitmap.installPixels(info, pixels, rowBytes)) { |
| 2621 return NULL; | 2669 return NULL; |
| 2622 } | 2670 } |
| 2623 | 2671 |
| 2624 // should this functionality be moved into allocPixels()? | 2672 // should this functionality be moved into allocPixels()? |
| 2625 if (!bitmap.info().isOpaque()) { | 2673 if (!bitmap.info().isOpaque()) { |
| 2626 bitmap.eraseColor(0); | 2674 bitmap.eraseColor(0); |
| 2627 } | 2675 } |
| 2628 return SkNEW_ARGS(SkCanvas, (bitmap)); | 2676 return SkNEW_ARGS(SkCanvas, (bitmap)); |
| 2629 } | 2677 } |
| OLD | NEW |