Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2006 Apple Computer, Inc. All rights reserved. | 2 * Copyright (C) 2006 Apple Computer, Inc. All rights reserved. |
| 3 * Copyright (C) 2008, 2009 Google, Inc. | 3 * Copyright (C) 2008, 2009 Google, Inc. |
| 4 * | 4 * |
| 5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
| 6 * modification, are permitted provided that the following conditions | 6 * modification, are permitted provided that the following conditions |
| 7 * are met: | 7 * are met: |
| 8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. 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 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
| 11 * notice, this list of conditions and the following disclaimer in the | 11 * notice, this list of conditions and the following disclaimer in the |
| 12 * documentation and/or other materials provided with the distribution. | 12 * documentation and/or other materials provided with the distribution. |
| 13 * | 13 * |
| 14 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY | 14 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY |
| 15 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 15 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| 17 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR | 17 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR |
| 18 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | 18 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
| 19 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 19 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| 20 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | 20 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
| 21 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | 21 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
| 22 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 22 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 25 */ | 25 */ |
| 26 | 26 |
| 27 #include "platform/image-decoders/ImageFrame.h" | 27 #include "platform/image-decoders/ImageFrame.h" |
| 28 | 28 |
| 29 #include "platform/RuntimeEnabledFeatures.h" | 29 #include "platform/RuntimeEnabledFeatures.h" |
| 30 #include "platform/graphics/skia/SkiaUtils.h" | |
| 30 #include "platform/image-decoders/ImageDecoder.h" | 31 #include "platform/image-decoders/ImageDecoder.h" |
| 31 | 32 |
| 32 namespace blink { | 33 namespace blink { |
| 33 | 34 |
| 34 ImageFrame::ImageFrame() | 35 ImageFrame::ImageFrame() |
| 35 : m_allocator(0) | 36 : m_allocator(0) |
| 36 , m_hasAlpha(true) | 37 , m_hasAlpha(true) |
| 37 , m_status(FrameEmpty) | 38 , m_status(FrameEmpty) |
| 38 , m_duration(0) | 39 , m_duration(0) |
| 39 , m_disposalMethod(DisposeNotSpecified) | 40 , m_disposalMethod(DisposeNotSpecified) |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 89 bool ImageFrame::copyBitmapData(const ImageFrame& other) | 90 bool ImageFrame::copyBitmapData(const ImageFrame& other) |
| 90 { | 91 { |
| 91 if (this == &other) | 92 if (this == &other) |
| 92 return true; | 93 return true; |
| 93 | 94 |
| 94 m_hasAlpha = other.m_hasAlpha; | 95 m_hasAlpha = other.m_hasAlpha; |
| 95 m_bitmap.reset(); | 96 m_bitmap.reset(); |
| 96 return other.m_bitmap.copyTo(&m_bitmap, other.m_bitmap.colorType()); | 97 return other.m_bitmap.copyTo(&m_bitmap, other.m_bitmap.colorType()); |
| 97 } | 98 } |
| 98 | 99 |
| 100 bool ImageFrame::takeBitmapDataIfWritable(ImageFrame* other) | |
| 101 { | |
| 102 DCHECK(other); | |
| 103 if (other->m_bitmap.isImmutable() || this == other) | |
|
Peter Kasting
2016/08/30 06:59:40
Tiny efficiency nit: Reverse order of checks
aleksandar.stojiljkovic
2016/09/21 20:56:57
It isn't obvious when/if this could happen (this =
Peter Kasting
2016/09/21 21:54:49
I suppose you could make this (and maybe that func
aleksandar.stojiljkovic
2016/09/22 09:41:19
Done.
| |
| 104 return false; | |
| 105 m_hasAlpha = other->m_hasAlpha; | |
| 106 m_bitmap.reset(); | |
| 107 m_bitmap.swap(other->m_bitmap); | |
| 108 other->m_status = FrameEmpty; | |
| 109 return true; | |
| 110 } | |
| 111 | |
| 99 bool ImageFrame::setSizeAndColorProfile(int newWidth, int newHeight, const ICCPr ofile& newIccProfile) | 112 bool ImageFrame::setSizeAndColorProfile(int newWidth, int newHeight, const ICCPr ofile& newIccProfile) |
| 100 { | 113 { |
| 101 // setSizeAndColorProfile() should only be called once, it leaks memory othe rwise. | 114 // setSizeAndColorProfile() should only be called once, it leaks memory othe rwise. |
| 102 ASSERT(!width() && !height()); | 115 ASSERT(!width() && !height()); |
| 103 | 116 |
| 104 sk_sp<SkColorSpace> colorSpace; | 117 sk_sp<SkColorSpace> colorSpace; |
| 105 if (RuntimeEnabledFeatures::colorCorrectRenderingEnabled() && !newIccProfile .isEmpty()) | 118 if (RuntimeEnabledFeatures::colorCorrectRenderingEnabled() && !newIccProfile .isEmpty()) |
| 106 colorSpace = SkColorSpace::NewICC(newIccProfile.data(), newIccProfile.si ze()); | 119 colorSpace = SkColorSpace::NewICC(newIccProfile.data(), newIccProfile.si ze()); |
| 107 | 120 |
| 108 m_bitmap.setInfo(SkImageInfo::MakeN32(newWidth, newHeight, | 121 m_bitmap.setInfo(SkImageInfo::MakeN32(newWidth, newHeight, |
| 109 m_premultiplyAlpha ? kPremul_SkAlphaType : kUnpremul_SkAlphaType, colorS pace)); | 122 m_premultiplyAlpha ? kPremul_SkAlphaType : kUnpremul_SkAlphaType, colorS pace)); |
| 110 if (!m_bitmap.tryAllocPixels(m_allocator, 0)) | 123 if (!m_bitmap.tryAllocPixels(m_allocator, 0)) |
| 111 return false; | 124 return false; |
| 112 | 125 |
| 113 zeroFillPixelData(); | 126 zeroFillPixelData(); |
| 114 return true; | 127 return true; |
| 115 } | 128 } |
| 116 | 129 |
| 117 bool ImageFrame::hasAlpha() const | 130 bool ImageFrame::hasAlpha() const |
| 118 { | 131 { |
| 119 return m_hasAlpha; | 132 return m_hasAlpha; |
| 120 } | 133 } |
| 121 | 134 |
| 135 const SkBitmap& ImageFrame::bitmap() const | |
| 136 { | |
| 137 // We don't want to set the status to immutable here as we do in | |
| 138 // finalizePixelsAndGetImage() because mutable bitmap is reusable as the | |
| 139 // next animation frame by calling takeBitmapDataIfWritable. | |
|
Peter Kasting
2016/08/30 06:59:40
Nit: The header comments should already justify an
aleksandar.stojiljkovic
2016/09/21 20:56:57
Done.
| |
| 140 return m_bitmap; | |
| 141 } | |
| 142 | |
| 143 PassRefPtr<SkImage> ImageFrame::finalizePixelsAndGetImage() | |
| 144 { | |
| 145 DCHECK(m_status != FrameComplete || (!m_bitmap.isNull() && !m_bitmap.empty() )); | |
| 146 | |
| 147 // We don't set the status to immutable until there is a request to get | |
| 148 // SkImage and decoding is done. We set the bitmap to immutable here to | |
| 149 // avoid copying in SkImage::MakeFromBitmap. | |
| 150 if (!m_bitmap.isImmutable() && m_status == FrameComplete) | |
| 151 m_bitmap.setImmutable(); | |
| 152 return fromSkSp(SkImage::MakeFromBitmap(m_bitmap)); | |
| 153 } | |
| 154 | |
| 122 void ImageFrame::setHasAlpha(bool alpha) | 155 void ImageFrame::setHasAlpha(bool alpha) |
| 123 { | 156 { |
| 124 m_hasAlpha = alpha; | 157 m_hasAlpha = alpha; |
| 125 | 158 |
| 126 m_bitmap.setAlphaType(computeAlphaType()); | 159 m_bitmap.setAlphaType(computeAlphaType()); |
| 127 } | 160 } |
| 128 | 161 |
| 129 void ImageFrame::setStatus(Status status) | 162 void ImageFrame::setStatus(Status status) |
| 130 { | 163 { |
| 131 m_status = status; | 164 m_status = status; |
| 132 if (m_status == FrameComplete) { | 165 if (m_status == FrameComplete) { |
| 133 m_bitmap.setAlphaType(computeAlphaType()); | 166 m_bitmap.setAlphaType(computeAlphaType()); |
| 134 // Send pending pixels changed notifications now, because we can't do th is after | 167 // Send pending pixels changed notifications now, because we can't do th is after |
| 135 // the bitmap has been marked immutable. | 168 // the bitmap has been marked immutable. |
| 136 notifyBitmapIfPixelsChanged(); | 169 notifyBitmapIfPixelsChanged(); |
| 137 m_bitmap.setImmutable(); // Tell the bitmap it's done. | |
| 138 } | 170 } |
| 139 } | 171 } |
| 140 | 172 |
| 141 void ImageFrame::zeroFillFrameRect(const IntRect& rect) | 173 void ImageFrame::zeroFillFrameRect(const IntRect& rect) |
| 142 { | 174 { |
| 143 if (rect.isEmpty()) | 175 if (rect.isEmpty()) |
| 144 return; | 176 return; |
| 145 | 177 |
| 146 m_bitmap.eraseArea(rect, SkColorSetARGB(0, 0, 0, 0)); | 178 m_bitmap.eraseArea(rect, SkColorSetARGB(0, 0, 0, 0)); |
| 147 setHasAlpha(true); | 179 setHasAlpha(true); |
| 148 } | 180 } |
| 149 | 181 |
| 150 SkAlphaType ImageFrame::computeAlphaType() const | 182 SkAlphaType ImageFrame::computeAlphaType() const |
| 151 { | 183 { |
| 152 // If the frame is not fully loaded, there will be transparent pixels, | 184 // If the frame is not fully loaded, there will be transparent pixels, |
| 153 // so we can't tell skia we're opaque, even for image types that logically | 185 // so we can't tell skia we're opaque, even for image types that logically |
| 154 // always are (e.g. jpeg). | 186 // always are (e.g. jpeg). |
| 155 if (!m_hasAlpha && m_status == FrameComplete) | 187 if (!m_hasAlpha && m_status == FrameComplete) |
| 156 return kOpaque_SkAlphaType; | 188 return kOpaque_SkAlphaType; |
| 157 | 189 |
| 158 return m_premultiplyAlpha ? kPremul_SkAlphaType : kUnpremul_SkAlphaType; | 190 return m_premultiplyAlpha ? kPremul_SkAlphaType : kUnpremul_SkAlphaType; |
| 159 } | 191 } |
| 160 | 192 |
| 161 } // namespace blink | 193 } // namespace blink |
| OLD | NEW |