blob: 8dce671f44dbe3c246e65c8e2d23e6dbdd72f8a5 [file] [log] [blame]
scroggoe7fc14b2015-10-02 13:14:46 -07001/*
2 * Copyright 2015 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7#ifndef SkSampler_DEFINED
8#define SkSampler_DEFINED
9
msaretta4970dc2016-01-11 07:23:23 -080010#include "SkCodec.h"
scroggo4f2a88c2016-10-17 14:32:41 -070011#include "SkCodecPriv.h"
scroggoe7fc14b2015-10-02 13:14:46 -070012#include "SkTypes.h"
13
14class SkSampler : public SkNoncopyable {
15public:
16 /**
17 * Update the sampler to sample every sampleX'th pixel. Returns the
18 * width after sampling.
19 */
20 int setSampleX(int sampleX) {
21 return this->onSetSampleX(sampleX);
22 }
23
msarette6dd0042015-10-09 11:07:34 -070024 /**
scroggo8e6c7ad2016-09-16 08:20:38 -070025 * Update the sampler to sample every sampleY'th row.
26 */
27 void setSampleY(int sampleY) {
28 fSampleY = sampleY;
29 }
30
31 /**
32 * Retrieve the value set for sampleY.
33 */
34 int sampleY() const {
35 return fSampleY;
36 }
37
38 /**
39 * Based on fSampleY, return whether this row belongs in the output.
40 *
scroggo4f2a88c2016-10-17 14:32:41 -070041 * @param row Row of the image, starting with the first row in the subset.
scroggo8e6c7ad2016-09-16 08:20:38 -070042 */
43 bool rowNeeded(int row) const {
scroggoaef247a2016-10-19 12:56:46 -070044 return (row - get_start_coord(fSampleY)) % fSampleY == 0;
scroggo8e6c7ad2016-09-16 08:20:38 -070045 }
46
47 /**
msarette6dd0042015-10-09 11:07:34 -070048 * Fill the remainder of the destination with a single color
49 *
50 * @param info
51 * Contains the color type of the rows to fill.
52 * Contains the width of the destination rows to fill
53 * Contains the number of rows that we need to fill.
54 *
55 * @param dst
56 * The destination row to fill from.
57 *
58 * @param rowBytes
59 * Stride in bytes of the destination.
60 *
61 * @param colorOrIndex
msarettf7eb6fc2016-09-13 09:04:11 -070062 * If colorType is kF16, colorOrIndex is treated as a 64-bit color.
msarette6dd0042015-10-09 11:07:34 -070063 * If colorType is kN32, colorOrIndex is treated as a 32-bit color.
64 * If colorType is k565, colorOrIndex is treated as a 16-bit color.
65 * If colorType is kGray, colorOrIndex is treated as an 8-bit color.
66 * If colorType is kIndex, colorOrIndex is treated as an 8-bit index.
67 * Other SkColorTypes are not supported.
68 *
69 * @param zeroInit
70 * Indicates whether memory is already zero initialized.
71 *
72 */
73 static void Fill(const SkImageInfo& info, void* dst, size_t rowBytes,
msarettf7eb6fc2016-09-13 09:04:11 -070074 uint64_t colorOrIndex, SkCodec::ZeroInitialized zeroInit);
msarette6dd0042015-10-09 11:07:34 -070075
76 /**
77 * Allow subclasses to implement unique versions of fill().
78 */
79 virtual void fill(const SkImageInfo& info, void* dst, size_t rowBytes,
msarettf7eb6fc2016-09-13 09:04:11 -070080 uint64_t colorOrIndex, SkCodec::ZeroInitialized zeroInit) {}
msarette6dd0042015-10-09 11:07:34 -070081
scroggo8e6c7ad2016-09-16 08:20:38 -070082 SkSampler()
83 : fSampleY(1)
84 {}
85
scroggoe7fc14b2015-10-02 13:14:46 -070086 virtual ~SkSampler() {}
87private:
scroggo8e6c7ad2016-09-16 08:20:38 -070088 int fSampleY;
msarette6dd0042015-10-09 11:07:34 -070089
scroggoe7fc14b2015-10-02 13:14:46 -070090 virtual int onSetSampleX(int) = 0;
91};
92
93#endif // SkSampler_DEFINED