| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2008 The Android Open Source Project | 2 * Copyright 2008 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 "SkBitmapDevice.h" | 8 #include "SkBitmapDevice.h" |
| 9 #include "SkCanvas.h" | 9 #include "SkCanvas.h" |
| 10 #include "SkCanvasPriv.h" | 10 #include "SkCanvasPriv.h" |
| (...skipping 734 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 745 SkCanvas::SkCanvas(SkBaseDevice* device) | 745 SkCanvas::SkCanvas(SkBaseDevice* device) |
| 746 : fMCStack(sizeof(MCRec), fMCRecStorage, sizeof(fMCRecStorage)) | 746 : fMCStack(sizeof(MCRec), fMCRecStorage, sizeof(fMCRecStorage)) |
| 747 , fProps(device->surfaceProps()) | 747 , fProps(device->surfaceProps()) |
| 748 , fConservativeRasterClip(false) | 748 , fConservativeRasterClip(false) |
| 749 { | 749 { |
| 750 inc_canvas(); | 750 inc_canvas(); |
| 751 | 751 |
| 752 this->init(device, kDefault_InitFlags); | 752 this->init(device, kDefault_InitFlags); |
| 753 } | 753 } |
| 754 | 754 |
| 755 SkCanvas::SkCanvas(SkBaseDevice* device, SkRasterCanvasLayerAllocator* allocator
) |
| 756 : fMCStack(sizeof(MCRec), fMCRecStorage, sizeof(fMCRecStorage)) |
| 757 , fProps(device->surfaceProps()) |
| 758 , fConservativeRasterClip(false) |
| 759 , fLayerAllocator(allocator) |
| 760 { |
| 761 inc_canvas(); |
| 762 |
| 763 this->init(device, kDefault_InitFlags); |
| 764 } |
| 765 |
| 755 SkCanvas::SkCanvas(SkBaseDevice* device, InitFlags flags) | 766 SkCanvas::SkCanvas(SkBaseDevice* device, InitFlags flags) |
| 756 : fMCStack(sizeof(MCRec), fMCRecStorage, sizeof(fMCRecStorage)) | 767 : fMCStack(sizeof(MCRec), fMCRecStorage, sizeof(fMCRecStorage)) |
| 757 , fProps(device->surfaceProps()) | 768 , fProps(device->surfaceProps()) |
| 758 , fConservativeRasterClip(false) | 769 , fConservativeRasterClip(false) |
| 759 { | 770 { |
| 760 inc_canvas(); | 771 inc_canvas(); |
| 761 | 772 |
| 762 this->init(device, flags); | 773 this->init(device, flags); |
| 763 } | 774 } |
| 764 | 775 |
| (...skipping 494 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1259 SkImageInfo info = make_layer_info(priorDevice->imageInfo(), ir.width(), ir.
height(), isOpaque, | 1270 SkImageInfo info = make_layer_info(priorDevice->imageInfo(), ir.width(), ir.
height(), isOpaque, |
| 1260 paint); | 1271 paint); |
| 1261 | 1272 |
| 1262 SkAutoTUnref<SkBaseDevice> newDevice; | 1273 SkAutoTUnref<SkBaseDevice> newDevice; |
| 1263 { | 1274 { |
| 1264 const bool preserveLCDText = kOpaque_SkAlphaType == info.alphaType() || | 1275 const bool preserveLCDText = kOpaque_SkAlphaType == info.alphaType() || |
| 1265 (saveLayerFlags & kPreserveLCDText_SaveLaye
rFlag); | 1276 (saveLayerFlags & kPreserveLCDText_SaveLaye
rFlag); |
| 1266 const SkBaseDevice::TileUsage usage = SkBaseDevice::kNever_TileUsage; | 1277 const SkBaseDevice::TileUsage usage = SkBaseDevice::kNever_TileUsage; |
| 1267 const SkBaseDevice::CreateInfo createInfo = SkBaseDevice::CreateInfo(inf
o, usage, geo, | 1278 const SkBaseDevice::CreateInfo createInfo = SkBaseDevice::CreateInfo(inf
o, usage, geo, |
| 1268 pre
serveLCDText); | 1279 pre
serveLCDText); |
| 1269 newDevice.reset(priorDevice->onCreateDevice(createInfo, paint)); | 1280 newDevice.reset(priorDevice->onCreateDevice(createInfo, paint, fLayerAll
ocator.get())); |
| 1270 if (!newDevice) { | 1281 if (!newDevice) { |
| 1271 SkErrorInternals::SetError(kInternalError_SkError, | 1282 SkErrorInternals::SetError(kInternalError_SkError, |
| 1272 "Unable to create device for layer."); | 1283 "Unable to create device for layer."); |
| 1273 return; | 1284 return; |
| 1274 } | 1285 } |
| 1275 } | 1286 } |
| 1276 newDevice->setOrigin(ir.fLeft, ir.fTop); | 1287 newDevice->setOrigin(ir.fLeft, ir.fTop); |
| 1277 | 1288 |
| 1278 DeviceCM* layer = new DeviceCM(newDevice, paint, this, fConservativeRasterCl
ip, stashedMatrix); | 1289 DeviceCM* layer = new DeviceCM(newDevice, paint, this, fConservativeRasterCl
ip, stashedMatrix); |
| 1279 | 1290 |
| (...skipping 2224 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3504 | 3515 |
| 3505 SkAutoCanvasMatrixPaint::~SkAutoCanvasMatrixPaint() { | 3516 SkAutoCanvasMatrixPaint::~SkAutoCanvasMatrixPaint() { |
| 3506 fCanvas->restoreToCount(fSaveCount); | 3517 fCanvas->restoreToCount(fSaveCount); |
| 3507 } | 3518 } |
| 3508 | 3519 |
| 3509 #ifdef SK_SUPPORT_LEGACY_NEW_SURFACE_API | 3520 #ifdef SK_SUPPORT_LEGACY_NEW_SURFACE_API |
| 3510 SkSurface* SkCanvas::newSurface(const SkImageInfo& info, const SkSurfaceProps* p
rops) { | 3521 SkSurface* SkCanvas::newSurface(const SkImageInfo& info, const SkSurfaceProps* p
rops) { |
| 3511 return this->makeSurface(info, props).release(); | 3522 return this->makeSurface(info, props).release(); |
| 3512 } | 3523 } |
| 3513 #endif | 3524 #endif |
| OLD | NEW |