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

Side by Side Diff: src/utils/SkShadowPaintFilterCanvas.cpp

Issue 2287553002: Moved ambient lights out of SkLight's light array (Closed) Base URL: https://skia.googlesource.com/skia@master
Patch Set: made req changes Created 4 years, 3 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
« src/core/SkShadowShader.cpp ('K') | « src/core/SkShadowShader.cpp ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2016 Google Inc. 2 * Copyright 2016 Google Inc.
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 "SkPathEffect.h" 8 #include "SkPathEffect.h"
9 #include "SkShadowPaintFilterCanvas.h" 9 #include "SkShadowPaintFilterCanvas.h"
10 10
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
43 newPaint.setColor(color); 43 newPaint.setColor(color);
44 44
45 *paint->writable() = newPaint; 45 *paint->writable() = newPaint;
46 } 46 }
47 47
48 return true; 48 return true;
49 } 49 }
50 50
51 SkISize SkShadowPaintFilterCanvas::ComputeDepthMapSize(const SkLights::Light& li ght, int maxDepth, 51 SkISize SkShadowPaintFilterCanvas::ComputeDepthMapSize(const SkLights::Light& li ght, int maxDepth,
52 int width, int height) { 52 int width, int height) {
53 SkASSERT(light.type() != SkLights::Light::kAmbient_LightType);
54 if (light.type() != SkLights::Light::kDirectional_LightType) { 53 if (light.type() != SkLights::Light::kDirectional_LightType) {
55 return SkISize::Make(width *2 , height * 2); 54 return SkISize::Make(width *2 , height * 2);
56 } 55 }
57 56
58 int dMapWidth = SkMin32(maxDepth * fabs(light.dir().fX) + width, 57 int dMapWidth = SkMin32(maxDepth * fabs(light.dir().fX) + width,
59 width * 2); 58 width * 2);
60 int dMapHeight = SkMin32(maxDepth * fabs(light.dir().fY) + height, 59 int dMapHeight = SkMin32(maxDepth * fabs(light.dir().fY) + height,
61 height * 2); 60 height * 2);
62 return SkISize::Make(dMapWidth, dMapHeight); 61 return SkISize::Make(dMapWidth, dMapHeight);
63 } 62 }
64 63
65 void SkShadowPaintFilterCanvas::setShadowParams(const SkShadowParams &params) { 64 void SkShadowPaintFilterCanvas::setShadowParams(const SkShadowParams &params) {
66 fShadowParams = params; 65 fShadowParams = params;
67 } 66 }
68 67
69 void SkShadowPaintFilterCanvas::onDrawPicture(const SkPicture *picture, const Sk Matrix *matrix, 68 void SkShadowPaintFilterCanvas::onDrawPicture(const SkPicture *picture, const Sk Matrix *matrix,
70 const SkPaint *paint) { 69 const SkPaint *paint) {
71 SkTCopyOnFirstWrite<SkPaint> filteredPaint(paint); 70 SkTCopyOnFirstWrite<SkPaint> filteredPaint(paint);
72 if (this->onFilter(&filteredPaint, kPicture_Type)) { 71 if (this->onFilter(&filteredPaint, kPicture_Type)) {
73 SkCanvas::onDrawPicture(picture, matrix, filteredPaint); 72 SkCanvas::onDrawPicture(picture, matrix, filteredPaint);
74 } 73 }
75 } 74 }
76 75
77 void SkShadowPaintFilterCanvas::updateMatrix() { 76 void SkShadowPaintFilterCanvas::updateMatrix() {
78 this->save(); 77 this->save();
79 78
80 // It is up to the user to set the 0th light in fLights to 79 // It is up to the user to set the 0th light in fLights to
81 // the light the want to render the depth map with. 80 // the light the want to render the depth map with.
robertphillips 2016/08/26 17:31:29 Don't we still need the if test to eliminate point
vjiaoblack 2016/08/26 18:10:38 Done.
82 if (this->fLights->light(0).type() == SkLights::Light::kDirectional_LightTyp e) { 81 const SkVector3& lightDir = this->fLights->light(0).dir();
83 const SkVector3& lightDir = this->fLights->light(0).dir(); 82 SkScalar x = lightDir.fX * this->getZ();
84 SkScalar x = lightDir.fX * this->getZ(); 83 SkScalar y = lightDir.fY * this->getZ();
85 SkScalar y = lightDir.fY * this->getZ();
86 84
87 this->translate(x, y); 85 this->translate(x, y);
88 }
89 } 86 }
90 87
91 void SkShadowPaintFilterCanvas::onDrawPaint(const SkPaint &paint) { 88 void SkShadowPaintFilterCanvas::onDrawPaint(const SkPaint &paint) {
92 this->updateMatrix(); 89 this->updateMatrix();
93 this->INHERITED::onDrawPaint(paint); 90 this->INHERITED::onDrawPaint(paint);
94 this->restore(); 91 this->restore();
95 } 92 }
96 93
97 void SkShadowPaintFilterCanvas::onDrawPoints(PointMode mode, size_t count, const SkPoint pts[], 94 void SkShadowPaintFilterCanvas::onDrawPoints(PointMode mode, size_t count, const SkPoint pts[],
98 const SkPaint &paint) { 95 const SkPaint &paint) {
(...skipping 144 matching lines...) Expand 10 before | Expand all | Expand 10 after
243 } 240 }
244 241
245 void SkShadowPaintFilterCanvas::onDrawTextBlob(const SkTextBlob *blob, SkScalar x, SkScalar y, 242 void SkShadowPaintFilterCanvas::onDrawTextBlob(const SkTextBlob *blob, SkScalar x, SkScalar y,
246 const SkPaint &paint) { 243 const SkPaint &paint) {
247 this->updateMatrix(); 244 this->updateMatrix();
248 this->INHERITED::onDrawTextBlob(blob, x, y, paint); 245 this->INHERITED::onDrawTextBlob(blob, x, y, paint);
249 this->restore(); 246 this->restore();
250 } 247 }
251 248
252 #endif 249 #endif
OLDNEW
« src/core/SkShadowShader.cpp ('K') | « src/core/SkShadowShader.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698