make BC4 channel readonly

This commit is contained in:
Andrew Cassidy 2021-03-19 01:39:21 -07:00
parent 285e891bef
commit 5a272c954f
5 changed files with 20 additions and 23 deletions

View File

@ -29,6 +29,6 @@ namespace quicktex::s3tc {
void BC3Decoder::DecodeBlock(Color4x4 dest, BC3Block *const block) const noexcept(ndebug) { void BC3Decoder::DecodeBlock(Color4x4 dest, BC3Block *const block) const noexcept(ndebug) {
_bc1_decoder->DecodeBlock(dest, &(block->color_block), false); _bc1_decoder->DecodeBlock(dest, &(block->color_block), false);
_bc4_decoder->DecodeBlock(dest, &(block->alpha_block), 3); _bc4_decoder->DecodeBlock(dest, &(block->alpha_block));
} }
} // namespace quicktex::s3tc } // namespace quicktex::s3tc

View File

@ -25,6 +25,6 @@
namespace quicktex::s3tc { namespace quicktex::s3tc {
void BC3Encoder::EncodeBlock(Color4x4 pixels, BC3Block *dest) const { void BC3Encoder::EncodeBlock(Color4x4 pixels, BC3Block *dest) const {
_bc1_encoder->EncodeBlock(pixels, &(dest->color_block)); _bc1_encoder->EncodeBlock(pixels, &(dest->color_block));
_bc4_encoder->EncodeBlock(pixels, &(dest->alpha_block), 3); _bc4_encoder->EncodeBlock(pixels, &(dest->alpha_block));
} }
} // namespace quicktex::s3tc } // namespace quicktex::s3tc

View File

@ -29,20 +29,19 @@
#include "BC4Block.h" #include "BC4Block.h"
namespace quicktex::s3tc { namespace quicktex::s3tc {
class BC4Decoder : public BlockDecoderTemplate<BC4Block, 4, 4> { class BC4Decoder : public BlockDecoderTemplate<BC4Block, 4, 4> {
public: public:
BC4Decoder(uint8_t channel = 3) { SetChannel(channel); } BC4Decoder(uint8_t channel = 3) {
void DecodeBlock(Color4x4 dest, BC4Block *const block) const noexcept(ndebug) override { DecodeBlock(dest.GetChannel(_channel), block); }
void DecodeBlock(Color4x4 dest, BC4Block *const block, uint8_t channel) const noexcept(ndebug) { DecodeBlock(dest.GetChannel(channel), block); }
void DecodeBlock(Byte4x4 dest, BC4Block *const block) const noexcept(ndebug);
uint8_t GetChannel() const { return _channel; }
void SetChannel(uint8_t channel) {
if (channel >= 4U) throw std::invalid_argument("Channel out of range"); if (channel >= 4U) throw std::invalid_argument("Channel out of range");
_channel = channel; _channel = channel;
} }
void DecodeBlock(Color4x4 dest, BC4Block *const block) const noexcept(ndebug) override { DecodeBlock(dest.GetChannel(_channel), block); }
void DecodeBlock(Byte4x4 dest, BC4Block *const block) const noexcept(ndebug);
uint8_t GetChannel() const { return _channel; }
private: private:
uint8_t _channel; uint8_t _channel;
}; };

View File

@ -32,18 +32,16 @@ namespace quicktex::s3tc {
class BC4Encoder : public BlockEncoderTemplate<BC4Block, 4, 4> { class BC4Encoder : public BlockEncoderTemplate<BC4Block, 4, 4> {
public: public:
BC4Encoder(const uint8_t channel) { SetChannel(channel); } BC4Encoder(const uint8_t channel) {
void EncodeBlock(Color4x4 pixels, BC4Block *const dest) const override { EncodeBlock(pixels.GetChannel(_channel), dest); }
void EncodeBlock(Color4x4 pixels, BC4Block *const dest, uint8_t channel) const noexcept(ndebug) { EncodeBlock(pixels.GetChannel(channel), dest); }
void EncodeBlock(Byte4x4 pixels, BC4Block *const dest) const noexcept(ndebug);
uint8_t GetChannel() const { return _channel; }
void SetChannel(uint8_t channel) {
if (channel >= 4) throw std::invalid_argument("Channel out of range"); if (channel >= 4) throw std::invalid_argument("Channel out of range");
_channel = channel; _channel = channel;
} }
void EncodeBlock(Color4x4 pixels, BC4Block *const dest) const override { EncodeBlock(pixels.GetChannel(_channel), dest); }
void EncodeBlock(Byte4x4 pixels, BC4Block *const dest) const noexcept(ndebug);
uint8_t GetChannel() const { return _channel; }
private: private:
uint8_t _channel; uint8_t _channel;
}; };

View File

@ -45,13 +45,13 @@ void InitBC4(py::module_ &s3tc) {
py::class_<BC4Encoder> bc4_encoder(bc4, "BC4Encoder", block_encoder); py::class_<BC4Encoder> bc4_encoder(bc4, "BC4Encoder", block_encoder);
bc4_encoder.def(py::init<uint8_t>(), py::arg("channel") = 3); bc4_encoder.def(py::init<uint8_t>(), py::arg("channel") = 3);
bc4_encoder.def_property("channel", &BC4Encoder::GetChannel, &BC4Encoder::SetChannel); bc4_encoder.def_property_readonly("channel", &BC4Encoder::GetChannel, "The channel to read from. 0 to 3 inclusive. Readonly.");
// BC4Decoder // BC4Decoder
py::class_<BC4Decoder> bc4_decoder(bc4, "BC4Decoder", block_decoder); py::class_<BC4Decoder> bc4_decoder(bc4, "BC4Decoder", block_decoder);
bc4_decoder.def(py::init<uint8_t>(), py::arg("channel") = 3); bc4_decoder.def(py::init<uint8_t>(), py::arg("channel") = 3);
bc4_decoder.def_property("channel", &BC4Decoder::GetChannel, &BC4Decoder::SetChannel); bc4_decoder.def_property_readonly("channel", &BC4Decoder::GetChannel, "The channel to write to. 0 to 3 inclusive. Readonly.");
} }
} // namespace quicktex::bindings } // namespace quicktex::bindings