Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(174)

Side by Side Diff: third_party/WebKit/Source/platform/graphics/ImagePattern.cpp

Issue 2007553002: Retire setGradientSpaceTransform, setPatternSpaceTransform (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: more expectations Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "platform/graphics/ImagePattern.h" 5 #include "platform/graphics/ImagePattern.h"
6 6
7 #include "platform/graphics/Image.h" 7 #include "platform/graphics/Image.h"
8 #include "platform/graphics/skia/SkiaUtils.h" 8 #include "platform/graphics/skia/SkiaUtils.h"
9 #include "third_party/skia/include/core/SkCanvas.h" 9 #include "third_party/skia/include/core/SkCanvas.h"
10 #include "third_party/skia/include/core/SkImage.h" 10 #include "third_party/skia/include/core/SkImage.h"
(...skipping 12 matching lines...) Expand all
23 , m_tileImage(toSkSp(image->imageForCurrentFrame())) 23 , m_tileImage(toSkSp(image->imageForCurrentFrame()))
24 { 24 {
25 if (m_tileImage) { 25 if (m_tileImage) {
26 // TODO(fmalita): mechanism to extract the actual SkImageInfo from an Sk Image? 26 // TODO(fmalita): mechanism to extract the actual SkImageInfo from an Sk Image?
27 const SkImageInfo info = 27 const SkImageInfo info =
28 SkImageInfo::MakeN32Premul(m_tileImage->width(), m_tileImage->height ()); 28 SkImageInfo::MakeN32Premul(m_tileImage->width(), m_tileImage->height ());
29 adjustExternalMemoryAllocated(info.getSafeSize(info.minRowBytes())); 29 adjustExternalMemoryAllocated(info.getSafeSize(info.minRowBytes()));
30 } 30 }
31 } 31 }
32 32
33 sk_sp<SkShader> ImagePattern::createShader() const 33 sk_sp<SkShader> ImagePattern::createShader(const SkMatrix* localMatrix) const
34 { 34 {
35 if (!m_tileImage) 35 if (!m_tileImage)
36 return SkShader::MakeColorShader(SK_ColorTRANSPARENT); 36 return SkShader::MakeColorShader(SK_ColorTRANSPARENT);
37 37
38 SkMatrix localMatrix = affineTransformToSkMatrix(m_patternSpaceTransformatio n);
39
40 if (isRepeatXY()) { 38 if (isRepeatXY()) {
41 // Fast path: for repeatXY we just return a shader from the original ima ge. 39 // Fast path: for repeatXY we just return a shader from the original ima ge.
42 return m_tileImage->makeShader(SkShader::kRepeat_TileMode, SkShader::kRe peat_TileMode, &localMatrix); 40 return m_tileImage->makeShader(SkShader::kRepeat_TileMode, SkShader::kRe peat_TileMode, localMatrix);
43 } 41 }
44 42
45 // Skia does not have a "draw the tile only once" option. Clamp_TileMode 43 // Skia does not have a "draw the tile only once" option. Clamp_TileMode
46 // repeats the last line of the image after drawing one tile. To avoid 44 // repeats the last line of the image after drawing one tile. To avoid
47 // filling the space with arbitrary pixels, this workaround forces the 45 // filling the space with arbitrary pixels, this workaround forces the
48 // image to have a line of transparent pixels on the "repeated" edge(s), 46 // image to have a line of transparent pixels on the "repeated" edge(s),
49 // thus causing extra space to be transparent filled. 47 // thus causing extra space to be transparent filled.
50 SkShader::TileMode tileModeX = isRepeatX() 48 SkShader::TileMode tileModeX = isRepeatX()
51 ? SkShader::kRepeat_TileMode : SkShader::kClamp_TileMode; 49 ? SkShader::kRepeat_TileMode : SkShader::kClamp_TileMode;
52 SkShader::TileMode tileModeY = isRepeatY() 50 SkShader::TileMode tileModeY = isRepeatY()
53 ? SkShader::kRepeat_TileMode : SkShader::kClamp_TileMode; 51 ? SkShader::kRepeat_TileMode : SkShader::kClamp_TileMode;
54 int expandW = isRepeatX() ? 0 : 1; 52 int expandW = isRepeatX() ? 0 : 1;
55 int expandH = isRepeatY() ? 0 : 1; 53 int expandH = isRepeatY() ? 0 : 1;
56 54
57 // Create a transparent image 1 pixel wider and/or taller than the 55 // Create a transparent image 1 pixel wider and/or taller than the
58 // original, then copy the orignal into it. 56 // original, then copy the orignal into it.
59 // FIXME: Is there a better way to pad (not scale) an image in skia? 57 // FIXME: Is there a better way to pad (not scale) an image in skia?
60 sk_sp<SkSurface> surface = SkSurface::MakeRasterN32Premul( 58 sk_sp<SkSurface> surface = SkSurface::MakeRasterN32Premul(
61 m_tileImage->width() + expandW, m_tileImage->height() + expandH); 59 m_tileImage->width() + expandW, m_tileImage->height() + expandH);
62 if (!surface) 60 if (!surface)
63 return SkShader::MakeColorShader(SK_ColorTRANSPARENT); 61 return SkShader::MakeColorShader(SK_ColorTRANSPARENT);
64 62
65 surface->getCanvas()->clear(SK_ColorTRANSPARENT); 63 surface->getCanvas()->clear(SK_ColorTRANSPARENT);
66 SkPaint paint; 64 SkPaint paint;
67 paint.setXfermodeMode(SkXfermode::kSrc_Mode); 65 paint.setXfermodeMode(SkXfermode::kSrc_Mode);
68 surface->getCanvas()->drawImage(m_tileImage, 0, 0, &paint); 66 surface->getCanvas()->drawImage(m_tileImage, 0, 0, &paint);
69 67
70 return surface->makeImageSnapshot()->makeShader(tileModeX, tileModeY, &local Matrix); 68 return surface->makeImageSnapshot()->makeShader(tileModeX, tileModeY, localM atrix);
71 } 69 }
72 70
73 bool ImagePattern::isTextureBacked() const 71 bool ImagePattern::isTextureBacked() const
74 { 72 {
75 return m_tileImage && m_tileImage->isTextureBacked(); 73 return m_tileImage && m_tileImage->isTextureBacked();
76 } 74 }
77 75
78 } // namespace blink 76 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698