blob: b0621b468fda729ae98588ac4a78c2e540418a83 [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 Kleinc0bd9f92019-04-23 12:05:21 -050011#include "include/gpu/GrTypes.h"
Brian Salomona7d9f302020-07-15 13:25:30 -040012#include <limits>
Brian Salomon2bbdcc42017-09-07 12:36:34 -040013
14/**
15 * Represents the filtering and tile modes used to access a texture.
16 */
17class GrSamplerState {
18public:
Brian Salomone69b9ef2020-07-22 11:18:06 -040019 enum class Filter : uint8_t { kNearest, kLinear, kLast = kLinear };
Brian Salomonf7353512020-07-22 19:26:48 -040020 enum class MipmapMode : uint8_t { kNone, kNearest, kLinear, kLast = kLinear };
Brian Salomone69b9ef2020-07-22 11:18:06 -040021
22 enum class WrapMode : uint8_t {
23 kClamp,
24 kRepeat,
25 kMirrorRepeat,
26 kClampToBorder,
27 kLast = kClampToBorder
28 };
Michael Ludwigadb12e72019-12-04 16:19:18 -050029
Brian Salomonccb61422020-01-09 10:46:36 -050030 static constexpr int kFilterCount = static_cast<int>(Filter::kLast) + 1;
31 static constexpr int kWrapModeCount = static_cast<int>(WrapMode::kLast) + 1;
Brian Salomon2bbdcc42017-09-07 12:36:34 -040032
Brian Salomonccb61422020-01-09 10:46:36 -050033 constexpr GrSamplerState() = default;
Brian Salomon2bbdcc42017-09-07 12:36:34 -040034
Brian Salomone69b9ef2020-07-22 11:18:06 -040035 constexpr GrSamplerState(WrapMode wrapXAndY, Filter filter, MipmapMode mm = MipmapMode::kNone)
36 : fWrapModes{wrapXAndY, wrapXAndY}, fFilter(filter), fMipmapMode(mm) {}
Brian Salomon2bbdcc42017-09-07 12:36:34 -040037
Brian Salomone69b9ef2020-07-22 11:18:06 -040038 constexpr GrSamplerState(WrapMode wrapX,
39 WrapMode wrapY,
40 Filter filter,
41 MipmapMode mm = MipmapMode::kNone)
42 : fWrapModes{wrapX, wrapY}, fFilter(filter), fMipmapMode(mm) {}
Brian Salomonca6b2f42020-01-24 11:31:21 -050043
Brian Salomone69b9ef2020-07-22 11:18:06 -040044 constexpr GrSamplerState(const WrapMode wrapModes[2],
45 Filter filter,
46 MipmapMode mm = MipmapMode::kNone)
47 : fWrapModes{wrapModes[0], wrapModes[1]}, fFilter(filter), fMipmapMode(mm) {}
Brian Salomon2bbdcc42017-09-07 12:36:34 -040048
Brian Salomonccb61422020-01-09 10:46:36 -050049 constexpr /*explicit*/ GrSamplerState(Filter filter) : fFilter(filter) {}
Brian Salomone69b9ef2020-07-22 11:18:06 -040050 constexpr GrSamplerState(Filter filter, MipmapMode mm) : fFilter(filter), fMipmapMode(mm) {}
Brian Salomonccb61422020-01-09 10:46:36 -050051
Brian Salomon2bbdcc42017-09-07 12:36:34 -040052 constexpr GrSamplerState(const GrSamplerState&) = default;
53
Brian Salomonccb61422020-01-09 10:46:36 -050054 constexpr GrSamplerState& operator=(const GrSamplerState&) = default;
Brian Salomon2bbdcc42017-09-07 12:36:34 -040055
Brian Salomonccb61422020-01-09 10:46:36 -050056 constexpr WrapMode wrapModeX() const { return fWrapModes[0]; }
Brian Salomone69b9ef2020-07-22 11:18:06 -040057
Brian Salomonccb61422020-01-09 10:46:36 -050058 constexpr WrapMode wrapModeY() const { return fWrapModes[1]; }
Brian Salomon2bbdcc42017-09-07 12:36:34 -040059
Brian Salomonccb61422020-01-09 10:46:36 -050060 constexpr bool isRepeated() const {
Brian Salomone69b9ef2020-07-22 11:18:06 -040061 return fWrapModes[0] == WrapMode::kRepeat || fWrapModes[0] == WrapMode::kMirrorRepeat ||
62 fWrapModes[1] == WrapMode::kRepeat || fWrapModes[1] == WrapMode::kMirrorRepeat;
Brian Salomon2bbdcc42017-09-07 12:36:34 -040063 }
64
Brian Salomone69b9ef2020-07-22 11:18:06 -040065 constexpr Filter filter() const { return fFilter; }
66
67 constexpr MipmapMode mipmapMode() const { return fMipmapMode; }
68
69 constexpr GrMipmapped mipmapped() const {
70 return GrMipmapped(fMipmapMode != MipmapMode::kNone);
71 }
72
73 constexpr void setFilterMode(Filter filterMode) { fFilter = filterMode; }
74
75 constexpr void setMipmapMode(MipmapMode mm) { fMipmapMode = mm; }
76
77 constexpr void setWrapModeX(const WrapMode wrap) { fWrapModes[0] = wrap; }
78
79 constexpr void setWrapModeY(const WrapMode wrap) { fWrapModes[1] = wrap; }
80
Brian Salomonccb61422020-01-09 10:46:36 -050081 constexpr bool operator==(GrSamplerState that) const {
Brian Salomon2bbdcc42017-09-07 12:36:34 -040082 return fWrapModes[0] == that.fWrapModes[0] && fWrapModes[1] == that.fWrapModes[1] &&
Brian Salomone69b9ef2020-07-22 11:18:06 -040083 fFilter == that.fFilter && fMipmapMode == that.fMipmapMode;
Brian Salomon2bbdcc42017-09-07 12:36:34 -040084 }
85
Brian Salomonccb61422020-01-09 10:46:36 -050086 constexpr bool operator!=(const GrSamplerState& that) const { return !(*this == that); }
Brian Salomon2bbdcc42017-09-07 12:36:34 -040087
Brian Salomona7d9f302020-07-15 13:25:30 -040088 /**
89 * Turn the sampler state into an integer from a tightly packed range for use as an index
90 * (or key)
91 */
92 constexpr uint8_t asIndex() const {
93 constexpr int kNumWraps = static_cast<int>(WrapMode::kLast) + 1;
Brian Salomone69b9ef2020-07-22 11:18:06 -040094 constexpr int kNumFilters = static_cast<int>(Filter::kLast ) + 1;
Brian Salomona7d9f302020-07-15 13:25:30 -040095 int result = static_cast<int>(fWrapModes[0])*1
96 + static_cast<int>(fWrapModes[1])*kNumWraps
Brian Salomone69b9ef2020-07-22 11:18:06 -040097 + static_cast<int>(fFilter) *kNumWraps*kNumWraps
98 + static_cast<int>(fMipmapMode) *kNumWraps*kNumWraps*kNumFilters;
Brian Salomona7d9f302020-07-15 13:25:30 -040099 SkASSERT(result <= kNumUniqueSamplers);
100 return static_cast<uint8_t>(result);
Robert Phillipsf22c57d2019-10-14 14:16:02 -0400101 }
102
Brian Salomone69b9ef2020-07-22 11:18:06 -0400103 static constexpr int kNumUniqueSamplers = (static_cast<int>(WrapMode::kLast ) + 1)
104 * (static_cast<int>(WrapMode::kLast ) + 1)
105 * (static_cast<int>(Filter::kLast ) + 1)
106 * (static_cast<int>(MipmapMode::kLast) + 1);
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400107private:
Brian Salomonccb61422020-01-09 10:46:36 -0500108 WrapMode fWrapModes[2] = {WrapMode::kClamp, WrapMode::kClamp};
109 Filter fFilter = GrSamplerState::Filter::kNearest;
Brian Salomone69b9ef2020-07-22 11:18:06 -0400110 MipmapMode fMipmapMode = GrSamplerState::MipmapMode::kNone;
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400111};
112
Brian Salomona7d9f302020-07-15 13:25:30 -0400113static_assert(GrSamplerState::kNumUniqueSamplers <=
114 std::numeric_limits<decltype(GrSamplerState{}.asIndex())>::max());
115
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400116#endif