| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2012 Google Inc. | 2 * Copyright 2012 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 "PictureRenderer.h" | 8 #include "PictureRenderer.h" |
| 9 #include "picture_utils.h" | 9 #include "picture_utils.h" |
| 10 #include "SamplePipeControllers.h" | 10 #include "SamplePipeControllers.h" |
| (...skipping 113 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 124 return this->setupCanvas(width, height); | 124 return this->setupCanvas(width, height); |
| 125 } | 125 } |
| 126 | 126 |
| 127 SkCanvas* PictureRenderer::setupCanvas(int width, int height) { | 127 SkCanvas* PictureRenderer::setupCanvas(int width, int height) { |
| 128 SkAutoTUnref<SkCanvas> canvas; | 128 SkAutoTUnref<SkCanvas> canvas; |
| 129 | 129 |
| 130 switch(fDeviceType) { | 130 switch(fDeviceType) { |
| 131 case kBitmap_DeviceType: { | 131 case kBitmap_DeviceType: { |
| 132 SkBitmap bitmap; | 132 SkBitmap bitmap; |
| 133 sk_tools::setup_bitmap(&bitmap, width, height); | 133 sk_tools::setup_bitmap(&bitmap, width, height); |
| 134 canvas.reset(SkNEW_ARGS(SkCanvas, (bitmap))); | 134 canvas.reset(new SkCanvas(bitmap)); |
| 135 } | 135 } |
| 136 break; | 136 break; |
| 137 #if SK_SUPPORT_GPU | 137 #if SK_SUPPORT_GPU |
| 138 #if SK_ANGLE | 138 #if SK_ANGLE |
| 139 case kAngle_DeviceType: | 139 case kAngle_DeviceType: |
| 140 // fall through | 140 // fall through |
| 141 #endif | 141 #endif |
| 142 #if SK_MESA | 142 #if SK_MESA |
| 143 case kMesa_DeviceType: | 143 case kMesa_DeviceType: |
| 144 // fall through | 144 // fall through |
| (...skipping 13 matching lines...) Expand all Loading... |
| 158 } | 158 } |
| 159 | 159 |
| 160 uint32_t flags = fUseDFText ? SkSurfaceProps::kUseDistanceFieldFonts
_Flag : 0; | 160 uint32_t flags = fUseDFText ? SkSurfaceProps::kUseDistanceFieldFonts
_Flag : 0; |
| 161 SkSurfaceProps props(flags, SkSurfaceProps::kLegacyFontHost_InitType
); | 161 SkSurfaceProps props(flags, SkSurfaceProps::kLegacyFontHost_InitType
); |
| 162 SkAutoTUnref<SkGpuDevice> device( | 162 SkAutoTUnref<SkGpuDevice> device( |
| 163 SkGpuDevice::Create(target->asRenderTarget(), &props, | 163 SkGpuDevice::Create(target->asRenderTarget(), &props, |
| 164 SkGpuDevice::kUninit_InitContents)); | 164 SkGpuDevice::kUninit_InitContents)); |
| 165 if (!device) { | 165 if (!device) { |
| 166 return NULL; | 166 return NULL; |
| 167 } | 167 } |
| 168 canvas.reset(SkNEW_ARGS(SkCanvas, (device))); | 168 canvas.reset(new SkCanvas(device)); |
| 169 break; | 169 break; |
| 170 } | 170 } |
| 171 #endif | 171 #endif |
| 172 default: | 172 default: |
| 173 SkASSERT(0); | 173 SkASSERT(0); |
| 174 return NULL; | 174 return NULL; |
| 175 } | 175 } |
| 176 | 176 |
| 177 if (fHasDrawFilters) { | 177 if (fHasDrawFilters) { |
| 178 if (fDrawFilters[0] & PictureRenderer::kAAClip_DrawFilterFlag) { | 178 if (fDrawFilters[0] & PictureRenderer::kAAClip_DrawFilterFlag) { |
| 179 canvas->setAllowSoftClip(false); | 179 canvas->setAllowSoftClip(false); |
| 180 } | 180 } |
| 181 | 181 |
| 182 canvas.reset(SkNEW_ARGS(FlagsFilterCanvas, (canvas.get(), fDrawFilters))
); | 182 canvas.reset(new FlagsFilterCanvas(canvas.get(), fDrawFilters)); |
| 183 } | 183 } |
| 184 | 184 |
| 185 this->scaleToScaleFactor(canvas); | 185 this->scaleToScaleFactor(canvas); |
| 186 | 186 |
| 187 // Pictures often lie about their extent (i.e., claim to be 100x100 but | 187 // Pictures often lie about their extent (i.e., claim to be 100x100 but |
| 188 // only ever draw to 90x100). Clear here so the undrawn portion will have | 188 // only ever draw to 90x100). Clear here so the undrawn portion will have |
| 189 // a consistent color | 189 // a consistent color |
| 190 canvas->clear(SK_ColorTRANSPARENT); | 190 canvas->clear(SK_ColorTRANSPARENT); |
| 191 return canvas.detach(); | 191 return canvas.detach(); |
| 192 } | 192 } |
| (...skipping 208 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 401 return false; | 401 return false; |
| 402 } | 402 } |
| 403 | 403 |
| 404 PipeController pipeController(fCanvas.get()); | 404 PipeController pipeController(fCanvas.get()); |
| 405 SkGPipeWriter writer; | 405 SkGPipeWriter writer; |
| 406 SkCanvas* pipeCanvas = writer.startRecording(&pipeController); | 406 SkCanvas* pipeCanvas = writer.startRecording(&pipeController); |
| 407 pipeCanvas->drawPicture(fPicture); | 407 pipeCanvas->drawPicture(fPicture); |
| 408 writer.endRecording(); | 408 writer.endRecording(); |
| 409 fCanvas->flush(); | 409 fCanvas->flush(); |
| 410 if (out) { | 410 if (out) { |
| 411 *out = SkNEW(SkBitmap); | 411 *out = new SkBitmap; |
| 412 setup_bitmap(*out, SkScalarCeilToInt(fPicture->cullRect().width()), | 412 setup_bitmap(*out, SkScalarCeilToInt(fPicture->cullRect().width()), |
| 413 SkScalarCeilToInt(fPicture->cullRect().height())); | 413 SkScalarCeilToInt(fPicture->cullRect().height())); |
| 414 fCanvas->readPixels(*out, 0, 0); | 414 fCanvas->readPixels(*out, 0, 0); |
| 415 } | 415 } |
| 416 if (fEnableWrites) { | 416 if (fEnableWrites) { |
| 417 return write(fCanvas, fWritePath, fMismatchPath, fInputFilename, fJsonSu
mmaryPtr, | 417 return write(fCanvas, fWritePath, fMismatchPath, fInputFilename, fJsonSu
mmaryPtr, |
| 418 fUseChecksumBasedFilenames); | 418 fUseChecksumBasedFilenames); |
| 419 } else { | 419 } else { |
| 420 return true; | 420 return true; |
| 421 } | 421 } |
| (...skipping 24 matching lines...) Expand all Loading... |
| 446 SkMultiPictureDraw mpd; | 446 SkMultiPictureDraw mpd; |
| 447 | 447 |
| 448 mpd.add(fCanvas, fPicture); | 448 mpd.add(fCanvas, fPicture); |
| 449 | 449 |
| 450 mpd.draw(); | 450 mpd.draw(); |
| 451 } else { | 451 } else { |
| 452 fCanvas->drawPicture(fPicture); | 452 fCanvas->drawPicture(fPicture); |
| 453 } | 453 } |
| 454 fCanvas->flush(); | 454 fCanvas->flush(); |
| 455 if (out) { | 455 if (out) { |
| 456 *out = SkNEW(SkBitmap); | 456 *out = new SkBitmap; |
| 457 setup_bitmap(*out, SkScalarCeilToInt(fPicture->cullRect().width()), | 457 setup_bitmap(*out, SkScalarCeilToInt(fPicture->cullRect().width()), |
| 458 SkScalarCeilToInt(fPicture->cullRect().height())); | 458 SkScalarCeilToInt(fPicture->cullRect().height())); |
| 459 fCanvas->readPixels(*out, 0, 0); | 459 fCanvas->readPixels(*out, 0, 0); |
| 460 } | 460 } |
| 461 if (fEnableWrites) { | 461 if (fEnableWrites) { |
| 462 return write(fCanvas, fWritePath, fMismatchPath, fInputFilename, fJsonSu
mmaryPtr, | 462 return write(fCanvas, fWritePath, fMismatchPath, fInputFilename, fJsonSu
mmaryPtr, |
| 463 fUseChecksumBasedFilenames); | 463 fUseChecksumBasedFilenames); |
| 464 } else { | 464 } else { |
| 465 return true; | 465 return true; |
| 466 } | 466 } |
| (...skipping 220 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 687 } | 687 } |
| 688 | 688 |
| 689 bool TiledPictureRenderer::render(SkBitmap** out) { | 689 bool TiledPictureRenderer::render(SkBitmap** out) { |
| 690 SkASSERT(fPicture != NULL); | 690 SkASSERT(fPicture != NULL); |
| 691 if (NULL == fPicture) { | 691 if (NULL == fPicture) { |
| 692 return false; | 692 return false; |
| 693 } | 693 } |
| 694 | 694 |
| 695 SkBitmap bitmap; | 695 SkBitmap bitmap; |
| 696 if (out) { | 696 if (out) { |
| 697 *out = SkNEW(SkBitmap); | 697 *out = new SkBitmap; |
| 698 setup_bitmap(*out, SkScalarCeilToInt(fPicture->cullRect().width()), | 698 setup_bitmap(*out, SkScalarCeilToInt(fPicture->cullRect().width()), |
| 699 SkScalarCeilToInt(fPicture->cullRect().height())); | 699 SkScalarCeilToInt(fPicture->cullRect().height())); |
| 700 setup_bitmap(&bitmap, fTileWidth, fTileHeight); | 700 setup_bitmap(&bitmap, fTileWidth, fTileHeight); |
| 701 } | 701 } |
| 702 bool success = true; | 702 bool success = true; |
| 703 | 703 |
| 704 if (fUseMultiPictureDraw) { | 704 if (fUseMultiPictureDraw) { |
| 705 SkMultiPictureDraw mpd; | 705 SkMultiPictureDraw mpd; |
| 706 SkTDArray<SkSurface*> surfaces; | 706 SkTDArray<SkSurface*> surfaces; |
| 707 surfaces.setReserve(fTileRects.count()); | 707 surfaces.setReserve(fTileRects.count()); |
| (...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 787 } else { | 787 } else { |
| 788 name.appendf("%i", fTileHeight); | 788 name.appendf("%i", fTileHeight); |
| 789 } | 789 } |
| 790 return name; | 790 return name; |
| 791 } | 791 } |
| 792 | 792 |
| 793 ////////////////////////////////////////////////////////////////////////////////
/////////////// | 793 ////////////////////////////////////////////////////////////////////////////////
/////////////// |
| 794 | 794 |
| 795 void PlaybackCreationRenderer::setup() { | 795 void PlaybackCreationRenderer::setup() { |
| 796 SkAutoTDelete<SkBBHFactory> factory(this->getFactory()); | 796 SkAutoTDelete<SkBBHFactory> factory(this->getFactory()); |
| 797 fRecorder.reset(SkNEW(SkPictureRecorder)); | 797 fRecorder.reset(new SkPictureRecorder); |
| 798 SkCanvas* canvas = fRecorder->beginRecording(SkIntToScalar(this->getViewWidt
h()), | 798 SkCanvas* canvas = fRecorder->beginRecording(SkIntToScalar(this->getViewWidt
h()), |
| 799 SkIntToScalar(this->getViewHeig
ht()), | 799 SkIntToScalar(this->getViewHeig
ht()), |
| 800 factory.get(), | 800 factory.get(), |
| 801 this->recordFlags()); | 801 this->recordFlags()); |
| 802 this->scaleToScaleFactor(canvas); | 802 this->scaleToScaleFactor(canvas); |
| 803 canvas->drawPicture(fPicture); | 803 canvas->drawPicture(fPicture); |
| 804 } | 804 } |
| 805 | 805 |
| 806 bool PlaybackCreationRenderer::render(SkBitmap** out) { | 806 bool PlaybackCreationRenderer::render(SkBitmap** out) { |
| 807 fPicture.reset(fRecorder->endRecording()); | 807 fPicture.reset(fRecorder->endRecording()); |
| 808 // Since this class does not actually render, return false. | 808 // Since this class does not actually render, return false. |
| 809 return false; | 809 return false; |
| 810 } | 810 } |
| 811 | 811 |
| 812 SkString PlaybackCreationRenderer::getConfigNameInternal() { | 812 SkString PlaybackCreationRenderer::getConfigNameInternal() { |
| 813 return SkString("playback_creation"); | 813 return SkString("playback_creation"); |
| 814 } | 814 } |
| 815 | 815 |
| 816 ////////////////////////////////////////////////////////////////////////////////
/////////////// | 816 ////////////////////////////////////////////////////////////////////////////////
/////////////// |
| 817 // SkPicture variants for each BBoxHierarchy type | 817 // SkPicture variants for each BBoxHierarchy type |
| 818 | 818 |
| 819 SkBBHFactory* PictureRenderer::getFactory() { | 819 SkBBHFactory* PictureRenderer::getFactory() { |
| 820 switch (fBBoxHierarchyType) { | 820 switch (fBBoxHierarchyType) { |
| 821 case kNone_BBoxHierarchyType: | 821 case kNone_BBoxHierarchyType: |
| 822 return NULL; | 822 return NULL; |
| 823 case kRTree_BBoxHierarchyType: | 823 case kRTree_BBoxHierarchyType: |
| 824 return SkNEW(SkRTreeFactory); | 824 return new SkRTreeFactory; |
| 825 } | 825 } |
| 826 SkASSERT(0); // invalid bbhType | 826 SkASSERT(0); // invalid bbhType |
| 827 return NULL; | 827 return NULL; |
| 828 } | 828 } |
| 829 | 829 |
| 830 } // namespace sk_tools | 830 } // namespace sk_tools |
| OLD | NEW |