1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2015 Google Inc. 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker #ifndef SkSampler_DEFINED 8*c8dee2aaSAndroid Build Coastguard Worker #define SkSampler_DEFINED 9*c8dee2aaSAndroid Build Coastguard Worker 10*c8dee2aaSAndroid Build Coastguard Worker #include "include/codec/SkCodec.h" 11*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkTypes.h" 12*c8dee2aaSAndroid Build Coastguard Worker #include "include/private/base/SkNoncopyable.h" 13*c8dee2aaSAndroid Build Coastguard Worker #include "src/codec/SkCodecPriv.h" 14*c8dee2aaSAndroid Build Coastguard Worker 15*c8dee2aaSAndroid Build Coastguard Worker #include <cstddef> 16*c8dee2aaSAndroid Build Coastguard Worker 17*c8dee2aaSAndroid Build Coastguard Worker struct SkImageInfo; 18*c8dee2aaSAndroid Build Coastguard Worker 19*c8dee2aaSAndroid Build Coastguard Worker class SkSampler : public SkNoncopyable { 20*c8dee2aaSAndroid Build Coastguard Worker public: 21*c8dee2aaSAndroid Build Coastguard Worker /** 22*c8dee2aaSAndroid Build Coastguard Worker * Update the sampler to sample every sampleX'th pixel. Returns the 23*c8dee2aaSAndroid Build Coastguard Worker * width after sampling. 24*c8dee2aaSAndroid Build Coastguard Worker */ setSampleX(int sampleX)25*c8dee2aaSAndroid Build Coastguard Worker int setSampleX(int sampleX) { 26*c8dee2aaSAndroid Build Coastguard Worker return this->onSetSampleX(sampleX); 27*c8dee2aaSAndroid Build Coastguard Worker } 28*c8dee2aaSAndroid Build Coastguard Worker 29*c8dee2aaSAndroid Build Coastguard Worker /** 30*c8dee2aaSAndroid Build Coastguard Worker * Update the sampler to sample every sampleY'th row. 31*c8dee2aaSAndroid Build Coastguard Worker */ setSampleY(int sampleY)32*c8dee2aaSAndroid Build Coastguard Worker void setSampleY(int sampleY) { 33*c8dee2aaSAndroid Build Coastguard Worker fSampleY = sampleY; 34*c8dee2aaSAndroid Build Coastguard Worker } 35*c8dee2aaSAndroid Build Coastguard Worker 36*c8dee2aaSAndroid Build Coastguard Worker /** 37*c8dee2aaSAndroid Build Coastguard Worker * Retrieve the value set for sampleY. 38*c8dee2aaSAndroid Build Coastguard Worker */ sampleY()39*c8dee2aaSAndroid Build Coastguard Worker int sampleY() const { 40*c8dee2aaSAndroid Build Coastguard Worker return fSampleY; 41*c8dee2aaSAndroid Build Coastguard Worker } 42*c8dee2aaSAndroid Build Coastguard Worker 43*c8dee2aaSAndroid Build Coastguard Worker /** 44*c8dee2aaSAndroid Build Coastguard Worker * Based on fSampleY, return whether this row belongs in the output. 45*c8dee2aaSAndroid Build Coastguard Worker * 46*c8dee2aaSAndroid Build Coastguard Worker * @param row Row of the image, starting with the first row in the subset. 47*c8dee2aaSAndroid Build Coastguard Worker */ rowNeeded(int row)48*c8dee2aaSAndroid Build Coastguard Worker bool rowNeeded(int row) const { 49*c8dee2aaSAndroid Build Coastguard Worker return (row - get_start_coord(fSampleY)) % fSampleY == 0; 50*c8dee2aaSAndroid Build Coastguard Worker } 51*c8dee2aaSAndroid Build Coastguard Worker 52*c8dee2aaSAndroid Build Coastguard Worker /** 53*c8dee2aaSAndroid Build Coastguard Worker * Fill the remainder of the destination with 0. 54*c8dee2aaSAndroid Build Coastguard Worker * 55*c8dee2aaSAndroid Build Coastguard Worker * 0 has a different meaning depending on the SkColorType. For color types 56*c8dee2aaSAndroid Build Coastguard Worker * with transparency, this means transparent. For k565 and kGray, 0 is 57*c8dee2aaSAndroid Build Coastguard Worker * black. 58*c8dee2aaSAndroid Build Coastguard Worker * 59*c8dee2aaSAndroid Build Coastguard Worker * @param info 60*c8dee2aaSAndroid Build Coastguard Worker * Contains the color type of the rows to fill. 61*c8dee2aaSAndroid Build Coastguard Worker * Contains the pixel width of the destination rows to fill 62*c8dee2aaSAndroid Build Coastguard Worker * Contains the number of rows that we need to fill. 63*c8dee2aaSAndroid Build Coastguard Worker * 64*c8dee2aaSAndroid Build Coastguard Worker * @param dst 65*c8dee2aaSAndroid Build Coastguard Worker * The destination row to fill. 66*c8dee2aaSAndroid Build Coastguard Worker * 67*c8dee2aaSAndroid Build Coastguard Worker * @param rowBytes 68*c8dee2aaSAndroid Build Coastguard Worker * Stride in bytes of the destination. 69*c8dee2aaSAndroid Build Coastguard Worker * 70*c8dee2aaSAndroid Build Coastguard Worker * @param zeroInit 71*c8dee2aaSAndroid Build Coastguard Worker * Indicates whether memory is already zero initialized. 72*c8dee2aaSAndroid Build Coastguard Worker */ 73*c8dee2aaSAndroid Build Coastguard Worker static void Fill(const SkImageInfo& info, void* dst, size_t rowBytes, 74*c8dee2aaSAndroid Build Coastguard Worker SkCodec::ZeroInitialized zeroInit); 75*c8dee2aaSAndroid Build Coastguard Worker 76*c8dee2aaSAndroid Build Coastguard Worker virtual int fillWidth() const = 0; 77*c8dee2aaSAndroid Build Coastguard Worker SkSampler()78*c8dee2aaSAndroid Build Coastguard Worker SkSampler() 79*c8dee2aaSAndroid Build Coastguard Worker : fSampleY(1) 80*c8dee2aaSAndroid Build Coastguard Worker {} 81*c8dee2aaSAndroid Build Coastguard Worker ~SkSampler()82*c8dee2aaSAndroid Build Coastguard Worker virtual ~SkSampler() {} 83*c8dee2aaSAndroid Build Coastguard Worker private: 84*c8dee2aaSAndroid Build Coastguard Worker int fSampleY; 85*c8dee2aaSAndroid Build Coastguard Worker 86*c8dee2aaSAndroid Build Coastguard Worker virtual int onSetSampleX(int) = 0; 87*c8dee2aaSAndroid Build Coastguard Worker }; 88*c8dee2aaSAndroid Build Coastguard Worker 89*c8dee2aaSAndroid Build Coastguard Worker #endif // SkSampler_DEFINED 90