OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 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 "GrLayerCache.h" | 8 #include "GrLayerCache.h" |
9 #include "GrLayerHoister.h" | 9 #include "GrLayerHoister.h" |
10 #include "SkCanvas.h" | 10 #include "SkCanvas.h" |
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
84 SkIntToScalar(layer->rect().height()
)); | 84 SkIntToScalar(layer->rect().height()
)); |
85 atlasCanvas->clipRect(bound); | 85 atlasCanvas->clipRect(bound); |
86 | 86 |
87 // Since 'clear' doesn't respect the clip we need to draw a rect | 87 // Since 'clear' doesn't respect the clip we need to draw a rect |
88 // TODO: ensure none of the atlased layers contain a clear call! | 88 // TODO: ensure none of the atlased layers contain a clear call! |
89 atlasCanvas->drawRect(bound, paint); | 89 atlasCanvas->drawRect(bound, paint); |
90 | 90 |
91 // info.fCTM maps the layer's top/left to the origin. | 91 // info.fCTM maps the layer's top/left to the origin. |
92 // Since this layer is atlased, the top/left corner needs | 92 // Since this layer is atlased, the top/left corner needs |
93 // to be offset to the correct location in the backing texture. | 93 // to be offset to the correct location in the backing texture. |
| 94 SkMatrix initialCTM; |
| 95 initialCTM.setTranslate(SkIntToScalar(-layer->offset().fX), |
| 96 SkIntToScalar(-layer->offset().fY)); |
| 97 initialCTM.postTranslate(bound.fLeft, bound.fTop); |
| 98 |
| 99 atlasCanvas->translate(SkIntToScalar(-layer->offset().fX), |
| 100 SkIntToScalar(-layer->offset().fY)); |
94 atlasCanvas->translate(bound.fLeft, bound.fTop); | 101 atlasCanvas->translate(bound.fLeft, bound.fTop); |
95 atlasCanvas->concat(layer->ctm()); | 102 atlasCanvas->concat(layer->ctm()); |
96 | 103 |
97 SkRecordPartialDraw(*picture->fRecord.get(), atlasCanvas, bound, | 104 SkRecordPartialDraw(*picture->fRecord.get(), atlasCanvas, bound, |
98 layer->start()+1, layer->stop()); | 105 layer->start()+1, layer->stop(), initialCTM); |
99 | 106 |
100 atlasCanvas->restore(); | 107 atlasCanvas->restore(); |
101 } | 108 } |
102 | 109 |
103 atlasCanvas->flush(); | 110 atlasCanvas->flush(); |
104 } | 111 } |
105 | 112 |
106 // Render the non-atlased layers that require it | 113 // Render the non-atlased layers that require it |
107 for (int i = 0; i < nonAtlased.count(); ++i) { | 114 for (int i = 0; i < nonAtlased.count(); ++i) { |
108 GrCachedLayer* layer = nonAtlased[i]; | 115 GrCachedLayer* layer = nonAtlased[i]; |
(...skipping 10 matching lines...) Expand all Loading... |
119 // extend beyond the boundaries of the atlased sub-rect | 126 // extend beyond the boundaries of the atlased sub-rect |
120 SkRect bound = SkRect::MakeXYWH(SkIntToScalar(layer->rect().fLeft), | 127 SkRect bound = SkRect::MakeXYWH(SkIntToScalar(layer->rect().fLeft), |
121 SkIntToScalar(layer->rect().fTop), | 128 SkIntToScalar(layer->rect().fTop), |
122 SkIntToScalar(layer->rect().width()), | 129 SkIntToScalar(layer->rect().width()), |
123 SkIntToScalar(layer->rect().height())); | 130 SkIntToScalar(layer->rect().height())); |
124 | 131 |
125 layerCanvas->clipRect(bound); // TODO: still useful? | 132 layerCanvas->clipRect(bound); // TODO: still useful? |
126 | 133 |
127 layerCanvas->clear(SK_ColorTRANSPARENT); | 134 layerCanvas->clear(SK_ColorTRANSPARENT); |
128 | 135 |
| 136 SkMatrix initialCTM; |
| 137 initialCTM.setTranslate(SkIntToScalar(-layer->offset().fX), |
| 138 SkIntToScalar(-layer->offset().fY)); |
| 139 |
| 140 layerCanvas->translate(SkIntToScalar(-layer->offset().fX), |
| 141 SkIntToScalar(-layer->offset().fY)); |
129 layerCanvas->concat(layer->ctm()); | 142 layerCanvas->concat(layer->ctm()); |
130 | 143 |
131 SkRecordPartialDraw(*picture->fRecord.get(), layerCanvas, bound, | 144 SkRecordPartialDraw(*picture->fRecord.get(), layerCanvas, bound, |
132 layer->start()+1, layer->stop()); | 145 layer->start()+1, layer->stop(), initialCTM); |
133 | 146 |
134 layerCanvas->flush(); | 147 layerCanvas->flush(); |
135 } | 148 } |
136 } | 149 } |
137 | 150 |
138 void GrLayerHoister::UnlockLayers(GrLayerCache* layerCache, const SkPicture* pic
ture) { | 151 void GrLayerHoister::UnlockLayers(GrLayerCache* layerCache, const SkPicture* pic
ture) { |
139 SkPicture::AccelData::Key key = GrAccelData::ComputeAccelDataKey(); | 152 SkPicture::AccelData::Key key = GrAccelData::ComputeAccelDataKey(); |
140 | 153 |
141 const SkPicture::AccelData* data = picture->EXPERIMENTAL_getAccelData(key); | 154 const SkPicture::AccelData* data = picture->EXPERIMENTAL_getAccelData(key); |
142 SkASSERT(data); | 155 SkASSERT(data); |
143 | 156 |
144 const GrAccelData *gpuData = static_cast<const GrAccelData*>(data); | 157 const GrAccelData *gpuData = static_cast<const GrAccelData*>(data); |
145 SkASSERT(0 != gpuData->numSaveLayers()); | 158 SkASSERT(0 != gpuData->numSaveLayers()); |
146 | 159 |
147 // unlock the layers | 160 // unlock the layers |
148 for (int i = 0; i < gpuData->numSaveLayers(); ++i) { | 161 for (int i = 0; i < gpuData->numSaveLayers(); ++i) { |
149 const GrAccelData::SaveLayerInfo& info = gpuData->saveLayerInfo(i); | 162 const GrAccelData::SaveLayerInfo& info = gpuData->saveLayerInfo(i); |
150 | 163 |
151 GrCachedLayer* layer = layerCache->findLayer(picture->uniqueID(), | 164 GrCachedLayer* layer = layerCache->findLayer(picture->uniqueID(), |
152 info.fSaveLayerOpID, | 165 info.fSaveLayerOpID, |
153 info.fRestoreOpID, | 166 info.fRestoreOpID, |
| 167 info.fOffset, |
154 info.fOriginXform); | 168 info.fOriginXform); |
155 layerCache->unlock(layer); | 169 layerCache->unlock(layer); |
156 } | 170 } |
157 | 171 |
158 #if DISABLE_CACHING | 172 #if DISABLE_CACHING |
159 // This code completely clears out the atlas. It is required when | 173 // This code completely clears out the atlas. It is required when |
160 // caching is disabled so the atlas doesn't fill up and force more | 174 // caching is disabled so the atlas doesn't fill up and force more |
161 // free floating layers | 175 // free floating layers |
162 layerCache->purge(picture->uniqueID()); | 176 layerCache->purge(picture->uniqueID()); |
163 | 177 |
164 layerCache->purgeAll(); | 178 layerCache->purgeAll(); |
165 #endif | 179 #endif |
166 } | 180 } |
167 | 181 |
OLD | NEW |