| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (c) 2013, Google Inc. All rights reserved. | 2 * Copyright (c) 2013, Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 80 { | 80 { |
| 81 DEFINE_STATIC_LOCAL(SkBitmap, nullBitmap, ()); | 81 DEFINE_STATIC_LOCAL(SkBitmap, nullBitmap, ()); |
| 82 return nullBitmap; | 82 return nullBitmap; |
| 83 } | 83 } |
| 84 | 84 |
| 85 PassRefPtr<SkImage> ImageBufferSurface::newImageSnapshot() const | 85 PassRefPtr<SkImage> ImageBufferSurface::newImageSnapshot() const |
| 86 { | 86 { |
| 87 return nullptr; | 87 return nullptr; |
| 88 } | 88 } |
| 89 | 89 |
| 90 static SkBitmap deepSkBitmapCopy(const SkBitmap& bitmap) | 90 void ImageBufferSurface::draw(GraphicsContext* context, const FloatRect& destRec
t, const FloatRect& srcRect, SkXfermode::Mode op) |
| 91 { | |
| 92 SkBitmap tmp; | |
| 93 if (!bitmap.deepCopyTo(&tmp)) | |
| 94 bitmap.copyTo(&tmp, bitmap.colorType()); | |
| 95 | |
| 96 return tmp; | |
| 97 } | |
| 98 | |
| 99 void ImageBufferSurface::draw(GraphicsContext* context, const FloatRect& destRec
t, const FloatRect& srcRect, SkXfermode::Mode op, bool needsCopy) | |
| 100 { | 91 { |
| 101 SkBitmap bmp = bitmap(); | 92 SkBitmap bmp = bitmap(); |
| 102 // For ImageBufferSurface that enables cachedBitmap, Use the cached bitmap f
or CPU side usage | 93 // For ImageBufferSurface that enables cachedBitmap, Use the cached bitmap f
or CPU side usage |
| 103 // if it is available, otherwise generate and use it. | 94 // if it is available, otherwise generate and use it. |
| 104 if (!context->isAccelerated() && isAccelerated() && cachedBitmapEnabled() &&
isValid()) { | 95 if (isAccelerated() && cachedBitmapEnabled() && isValid()) { |
| 105 updateCachedBitmapIfNeeded(); | 96 updateCachedBitmapIfNeeded(); |
| 106 bmp = cachedBitmap(); | 97 bmp = cachedBitmap(); |
| 107 } | 98 } |
| 108 | 99 |
| 109 RefPtr<Image> image = BitmapImage::create(needsCopy ? deepSkBitmapCopy(bmp)
: bmp); | 100 RefPtr<Image> image = BitmapImage::create(bmp); |
| 110 | 101 |
| 111 context->drawImage(image.get(), destRect, srcRect, op, DoNotRespectImageOrie
ntation); | 102 context->drawImage(image.get(), destRect, srcRect, op, DoNotRespectImageOrie
ntation); |
| 112 } | 103 } |
| 113 | 104 |
| 114 } // namespace blink | 105 } // namespace blink |
| OLD | NEW |