blob: b9e84ae093dec445731b53568ee898943458f439 [file] [log] [blame]
Brian Salomon2bbdcc42017-09-07 12:36:34 -04001/*
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
8#ifndef GrSamplerState_DEFINED
9#define GrSamplerState_DEFINED
10
Mike Reedfe4611c2020-12-29 12:23:46 -050011#include "include/core/SkSamplingOptions.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050012#include "include/gpu/GrTypes.h"
Brian Salomona7d9f302020-07-15 13:25:30 -040013#include <limits>
Brian Salomon2bbdcc42017-09-07 12:36:34 -040014
15/**
16 * Represents the filtering and tile modes used to access a texture.
17 */
18class GrSamplerState {
19public:
Mike Reedfe4611c2020-12-29 12:23:46 -050020 using Filter = SkFilterMode;
21 using MipmapMode = SkMipmapMode;
Brian Salomone69b9ef2020-07-22 11:18:06 -040022
23 enum class WrapMode : uint8_t {
24 kClamp,
25 kRepeat,
26 kMirrorRepeat,
27 kClampToBorder,
28 kLast = kClampToBorder
29 };
Michael Ludwigadb12e72019-12-04 16:19:18 -050030
Brian Salomonccb61422020-01-09 10:46:36 -050031 static constexpr int kFilterCount = static_cast<int>(Filter::kLast) + 1;
32 static constexpr int kWrapModeCount = static_cast<int>(WrapMode::kLast) + 1;
Brian Salomon2bbdcc42017-09-07 12:36:34 -040033
Brian Salomonccb61422020-01-09 10:46:36 -050034 constexpr GrSamplerState() = default;
Brian Salomon2bbdcc42017-09-07 12:36:34 -040035
Brian Salomone69b9ef2020-07-22 11:18:06 -040036 constexpr GrSamplerState(WrapMode wrapXAndY, Filter filter, MipmapMode mm = MipmapMode::kNone)
37 : fWrapModes{wrapXAndY, wrapXAndY}, fFilter(filter), fMipmapMode(mm) {}
Brian Salomon2bbdcc42017-09-07 12:36:34 -040038
Brian Salomone69b9ef2020-07-22 11:18:06 -040039 constexpr GrSamplerState(WrapMode wrapX,
40 WrapMode wrapY,
41 Filter filter,
42 MipmapMode mm = MipmapMode::kNone)
43 : fWrapModes{wrapX, wrapY}, fFilter(filter), fMipmapMode(mm) {}
Brian Salomonca6b2f42020-01-24 11:31:21 -050044
Brian Salomone69b9ef2020-07-22 11:18:06 -040045 constexpr GrSamplerState(const WrapMode wrapModes[2],
46 Filter filter,
47 MipmapMode mm = MipmapMode::kNone)
48 : fWrapModes{wrapModes[0], wrapModes[1]}, fFilter(filter), fMipmapMode(mm) {}
Brian Salomon2bbdcc42017-09-07 12:36:34 -040049
Brian Salomonccb61422020-01-09 10:46:36 -050050 constexpr /*explicit*/ GrSamplerState(Filter filter) : fFilter(filter) {}
Brian Salomone69b9ef2020-07-22 11:18:06 -040051 constexpr GrSamplerState(Filter filter, MipmapMode mm) : fFilter(filter), fMipmapMode(mm) {}
Brian Salomonccb61422020-01-09 10:46:36 -050052
Brian Salomon2bbdcc42017-09-07 12:36:34 -040053 constexpr GrSamplerState(const GrSamplerState&) = default;
54
Brian Salomonccb61422020-01-09 10:46:36 -050055 constexpr GrSamplerState& operator=(const GrSamplerState&) = default;
Brian Salomon2bbdcc42017-09-07 12:36:34 -040056
Brian Salomonccb61422020-01-09 10:46:36 -050057 constexpr WrapMode wrapModeX() const { return fWrapModes[0]; }
Brian Salomone69b9ef2020-07-22 11:18:06 -040058
Brian Salomonccb61422020-01-09 10:46:36 -050059 constexpr WrapMode wrapModeY() const { return fWrapModes[1]; }
Brian Salomon2bbdcc42017-09-07 12:36:34 -040060
Greg Daniel4fd41ff2020-10-22 11:07:28 -040061 constexpr bool isRepeatedX() const {
62 return fWrapModes[0] == WrapMode::kRepeat || fWrapModes[0] == WrapMode::kMirrorRepeat;
63 }
64
65 constexpr bool isRepeatedY() const {
66 return fWrapModes[1] == WrapMode::kRepeat || fWrapModes[1] == WrapMode::kMirrorRepeat;
67 }
68
Brian Salomonccb61422020-01-09 10:46:36 -050069 constexpr bool isRepeated() const {
Greg Daniel4fd41ff2020-10-22 11:07:28 -040070 return this->isRepeatedX() || this->isRepeatedY();
Brian Salomon2bbdcc42017-09-07 12:36:34 -040071 }
72
Brian Salomone69b9ef2020-07-22 11:18:06 -040073 constexpr Filter filter() const { return fFilter; }
74
75 constexpr MipmapMode mipmapMode() const { return fMipmapMode; }
76
77 constexpr GrMipmapped mipmapped() const {
78 return GrMipmapped(fMipmapMode != MipmapMode::kNone);
79 }
80
81 constexpr void setFilterMode(Filter filterMode) { fFilter = filterMode; }
82
83 constexpr void setMipmapMode(MipmapMode mm) { fMipmapMode = mm; }
84
85 constexpr void setWrapModeX(const WrapMode wrap) { fWrapModes[0] = wrap; }
86
87 constexpr void setWrapModeY(const WrapMode wrap) { fWrapModes[1] = wrap; }
88
Brian Salomonccb61422020-01-09 10:46:36 -050089 constexpr bool operator==(GrSamplerState that) const {
Brian Salomon2bbdcc42017-09-07 12:36:34 -040090 return fWrapModes[0] == that.fWrapModes[0] && fWrapModes[1] == that.fWrapModes[1] &&
Brian Salomone69b9ef2020-07-22 11:18:06 -040091 fFilter == that.fFilter && fMipmapMode == that.fMipmapMode;
Brian Salomon2bbdcc42017-09-07 12:36:34 -040092 }
93
Brian Salomonccb61422020-01-09 10:46:36 -050094 constexpr bool operator!=(const GrSamplerState& that) const { return !(*this == that); }
Brian Salomon2bbdcc42017-09-07 12:36:34 -040095
Brian Salomona7d9f302020-07-15 13:25:30 -040096 /**
97 * Turn the sampler state into an integer from a tightly packed range for use as an index
98 * (or key)
99 */
100 constexpr uint8_t asIndex() const {
101 constexpr int kNumWraps = static_cast<int>(WrapMode::kLast) + 1;
Brian Salomone69b9ef2020-07-22 11:18:06 -0400102 constexpr int kNumFilters = static_cast<int>(Filter::kLast ) + 1;
Brian Salomona7d9f302020-07-15 13:25:30 -0400103 int result = static_cast<int>(fWrapModes[0])*1
104 + static_cast<int>(fWrapModes[1])*kNumWraps
Brian Salomone69b9ef2020-07-22 11:18:06 -0400105 + static_cast<int>(fFilter) *kNumWraps*kNumWraps
106 + static_cast<int>(fMipmapMode) *kNumWraps*kNumWraps*kNumFilters;
Brian Salomona7d9f302020-07-15 13:25:30 -0400107 SkASSERT(result <= kNumUniqueSamplers);
108 return static_cast<uint8_t>(result);
Robert Phillipsf22c57d2019-10-14 14:16:02 -0400109 }
110
Brian Salomone69b9ef2020-07-22 11:18:06 -0400111 static constexpr int kNumUniqueSamplers = (static_cast<int>(WrapMode::kLast ) + 1)
112 * (static_cast<int>(WrapMode::kLast ) + 1)
113 * (static_cast<int>(Filter::kLast ) + 1)
114 * (static_cast<int>(MipmapMode::kLast) + 1);
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400115private:
Brian Salomonccb61422020-01-09 10:46:36 -0500116 WrapMode fWrapModes[2] = {WrapMode::kClamp, WrapMode::kClamp};
117 Filter fFilter = GrSamplerState::Filter::kNearest;
Brian Salomone69b9ef2020-07-22 11:18:06 -0400118 MipmapMode fMipmapMode = GrSamplerState::MipmapMode::kNone;
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400119};
120
Brian Salomona7d9f302020-07-15 13:25:30 -0400121static_assert(GrSamplerState::kNumUniqueSamplers <=
122 std::numeric_limits<decltype(GrSamplerState{}.asIndex())>::max());
123
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400124#endif