mirror of
https://github.com/drewcassidy/quicktex.git
synced 2024-09-13 06:37:34 +00:00
bind encode/decode methods
This commit is contained in:
parent
424d635292
commit
4fdf1085e0
@ -46,8 +46,8 @@ class BC1Encoder final : public BlockEncoder<BlockTexture<BC1Block>> {
|
|||||||
using OrderingPair = std::tuple<unsigned, unsigned>;
|
using OrderingPair = std::tuple<unsigned, unsigned>;
|
||||||
using CBlock = ColorBlock<4, 4>;
|
using CBlock = ColorBlock<4, 4>;
|
||||||
|
|
||||||
inline static constexpr unsigned min_power_iterations = 4;
|
static constexpr unsigned min_power_iterations = 4;
|
||||||
inline static constexpr unsigned max_power_iterations = 10;
|
static constexpr unsigned max_power_iterations = 10;
|
||||||
|
|
||||||
enum class ColorMode {
|
enum class ColorMode {
|
||||||
// An incomplete block with invalid selectors or endpoints
|
// An incomplete block with invalid selectors or endpoints
|
||||||
|
@ -108,7 +108,7 @@ void InitBC1(py::module_ &s3tc) {
|
|||||||
"when using a BC1 texture.");
|
"when using a BC1 texture.");
|
||||||
|
|
||||||
bc1_encoder.def(py::init<unsigned, BC1Encoder::ColorMode>(), "level"_a = 5, "color_mode"_a = BC1Encoder::ColorMode::FourColor);
|
bc1_encoder.def(py::init<unsigned, BC1Encoder::ColorMode>(), "level"_a = 5, "color_mode"_a = BC1Encoder::ColorMode::FourColor);
|
||||||
bc1_encoder.def(py::init<unsigned, BC1Encoder::ColorMode, InterpolatorPtr>(), "level"_a, "color_mode"_a, "interpolator"_a, R"pbdoc(
|
bc1_encoder.def(py::init<unsigned, BC1Encoder::ColorMode, InterpolatorPtr>(), "level"_a, "color_mode"_a, "interpolator"_a, R"doc(
|
||||||
__init__(self, level: int = 5, color_mode=ColorMode.FourColor, interpolator=Interpolator()) -> None
|
__init__(self, level: int = 5, color_mode=ColorMode.FourColor, interpolator=Interpolator()) -> None
|
||||||
|
|
||||||
Create a new BC1 encoder with the specified preset level, color mode, and interpolator.
|
Create a new BC1 encoder with the specified preset level, color mode, and interpolator.
|
||||||
@ -116,16 +116,25 @@ void InitBC1(py::module_ &s3tc) {
|
|||||||
:param int level: The preset level of the resulting encoder, between 0 and 18 inclusive. See :py:meth:`set_level` for more information. Default: 5.
|
:param int level: The preset level of the resulting encoder, between 0 and 18 inclusive. See :py:meth:`set_level` for more information. Default: 5.
|
||||||
:param ColorMode color_mode: The color mode of the resulting BC1Encoder. Default: :py:class:`~quicktex.s3tc.bc1.BC1Encoder.ColorMode.FourColor`.
|
:param ColorMode color_mode: The color mode of the resulting BC1Encoder. Default: :py:class:`~quicktex.s3tc.bc1.BC1Encoder.ColorMode.FourColor`.
|
||||||
:param Interpolator interpolator: The interpolation mode to use for encoding. Default: :py:class:`~quicktex.s3tc.interpolator.Interpolator`.
|
:param Interpolator interpolator: The interpolation mode to use for encoding. Default: :py:class:`~quicktex.s3tc.interpolator.Interpolator`.
|
||||||
)pbdoc");
|
)doc");
|
||||||
|
|
||||||
bc1_encoder.def("set_level", &BC1Encoder::SetLevel, "level"_a, R"pbdoc(
|
bc1_encoder.def("encode", &BC1Encoder::Encode, "texture"_a, R"doc(
|
||||||
|
encode(self, texture: RawTexture) -> BC1Texture
|
||||||
|
|
||||||
|
Encode a raw texture into a new BC1Texture using the encoder's current settings.
|
||||||
|
|
||||||
|
:param RawTexture texture: Input texture to encode.
|
||||||
|
:returns: A new BC1Texture with the same dimension as the input.
|
||||||
|
)doc");
|
||||||
|
|
||||||
|
bc1_encoder.def("set_level", &BC1Encoder::SetLevel, "level"_a, R"doc(
|
||||||
set_level(self, level : int = 5) -> None
|
set_level(self, level : int = 5) -> None
|
||||||
|
|
||||||
Select a preset quality level, between 0 and 18 inclusive. Higher quality levels are slower, but produce blocks that are a closer match to input.
|
Select a preset quality level, between 0 and 18 inclusive. Higher quality levels are slower, but produce blocks that are a closer match to input.
|
||||||
This has no effect on the size of the resulting texture, since BC1 is a fixed-ratio compression method. For better control, see the advanced API below
|
This has no effect on the size of the resulting texture, since BC1 is a fixed-ratio compression method. For better control, see the advanced API below
|
||||||
|
|
||||||
:param int level: The preset level of the resulting encoder, between 0 and 18 inclusive. Default: 5.
|
:param int level: The preset level of the resulting encoder, between 0 and 18 inclusive. Default: 5.
|
||||||
)pbdoc");
|
)doc");
|
||||||
|
|
||||||
bc1_encoder.def_property_readonly("interpolator", &BC1Encoder::GetInterpolator,
|
bc1_encoder.def_property_readonly("interpolator", &BC1Encoder::GetInterpolator,
|
||||||
"The :py:class:`~quicktex.s3tc.interpolator.Interpolator` used by this encoder. This is a readonly property.");
|
"The :py:class:`~quicktex.s3tc.interpolator.Interpolator` used by this encoder. This is a readonly property.");
|
||||||
@ -173,14 +182,23 @@ void InitBC1(py::module_ &s3tc) {
|
|||||||
)doc");
|
)doc");
|
||||||
|
|
||||||
bc1_decoder.def(py::init<bool>(), "write_alpha"_a = false);
|
bc1_decoder.def(py::init<bool>(), "write_alpha"_a = false);
|
||||||
bc1_decoder.def(py::init<bool, InterpolatorPtr>(), "write_alpha"_a, "interpolator"_a, R"pbdoc(
|
bc1_decoder.def(py::init<bool, InterpolatorPtr>(), "write_alpha"_a, "interpolator"_a, R"doc(
|
||||||
__init__(self, interpolator = Interpolator()) -> None
|
__init__(self, interpolator = Interpolator()) -> None
|
||||||
|
|
||||||
Create a new BC1 decoder with the specificied interpolator.
|
Create a new BC1 decoder with the specificied interpolator.
|
||||||
|
|
||||||
:param bool write_alpha: Determines if the alpha channel of the output is written to. Default: False;
|
:param bool write_alpha: Determines if the alpha channel of the output is written to. Default: False;
|
||||||
:param Interpolator interpolator: The interpolation mode to use for decoding. Default: :py:class:`~quicktex.s3tc.interpolator.Interpolator`.
|
:param Interpolator interpolator: The interpolation mode to use for decoding. Default: :py:class:`~quicktex.s3tc.interpolator.Interpolator`.
|
||||||
)pbdoc");
|
)doc");
|
||||||
|
|
||||||
|
bc1_decoder.def("decode", &BC1Decoder::Decode, "texture"_a, R"doc(
|
||||||
|
decode(self, texture: BC1Texture) -> RawTexture
|
||||||
|
|
||||||
|
Decode a BC1 texture into a new RawTexture using the decoder's current settings.
|
||||||
|
|
||||||
|
:param RawTexture texture: Input texture to encode.
|
||||||
|
:returns: A new RawTexture with the same dimensions as the input
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc1_decoder.def_property_readonly("interpolator", &BC1Decoder::GetInterpolator, "The interpolator used by this decoder. This is a readonly property.");
|
bc1_decoder.def_property_readonly("interpolator", &BC1Decoder::GetInterpolator, "The interpolator used by this decoder. This is a readonly property.");
|
||||||
bc1_decoder.def_readwrite("write_alpha", &BC1Decoder::write_alpha, "Determines if the alpha channel of the output is written to.");
|
bc1_decoder.def_readwrite("write_alpha", &BC1Decoder::write_alpha, "Determines if the alpha channel of the output is written to.");
|
||||||
|
@ -89,6 +89,15 @@ void InitBC3(py::module_ &s3tc) {
|
|||||||
:param Interpolator interpolator: The interpolation mode to use for encoding. Default: :py:class:`~quicktex.s3tc.interpolator.Interpolator`.
|
:param Interpolator interpolator: The interpolation mode to use for encoding. Default: :py:class:`~quicktex.s3tc.interpolator.Interpolator`.
|
||||||
)doc");
|
)doc");
|
||||||
|
|
||||||
|
bc3_encoder.def("encode", &BC3Encoder::Encode, "texture"_a, R"doc(
|
||||||
|
encode(self, texture: RawTexture) -> BC3Texture
|
||||||
|
|
||||||
|
Encode a raw texture into a new BC3Texture using the encoder's current settings.
|
||||||
|
|
||||||
|
:param RawTexture texture: Input texture to encode.
|
||||||
|
:returns: A new BC3Texture with the same dimension as the input.
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc3_encoder.def_property_readonly("bc1_encoder", &BC3Encoder::GetBC1Encoder,
|
bc3_encoder.def_property_readonly("bc1_encoder", &BC3Encoder::GetBC1Encoder,
|
||||||
"Internal :py:class:`~quicktex.s3tc.bc1.BC1Encoder` used for RGB data. Readonly.");
|
"Internal :py:class:`~quicktex.s3tc.bc1.BC1Encoder` used for RGB data. Readonly.");
|
||||||
bc3_encoder.def_property_readonly("bc4_encoder", &BC3Encoder::GetBC4Encoder,
|
bc3_encoder.def_property_readonly("bc4_encoder", &BC3Encoder::GetBC4Encoder,
|
||||||
@ -111,6 +120,15 @@ void InitBC3(py::module_ &s3tc) {
|
|||||||
:param Interpolator interpolator: The interpolation mode to use for decoding. Default: :py:class:`~quicktex.s3tc.interpolator.Interpolator`.
|
:param Interpolator interpolator: The interpolation mode to use for decoding. Default: :py:class:`~quicktex.s3tc.interpolator.Interpolator`.
|
||||||
)doc");
|
)doc");
|
||||||
|
|
||||||
|
bc3_decoder.def("decode", &BC3Decoder::Decode, "texture"_a, R"doc(
|
||||||
|
decode(self, texture: BC3Texture) -> RawTexture
|
||||||
|
|
||||||
|
Decode a BC3 texture into a new RawTexture using the decoder's current settings.
|
||||||
|
|
||||||
|
:param RawTexture texture: Input texture to encode.
|
||||||
|
:returns: A new RawTexture with the same dimensions as the input
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc3_decoder.def_property_readonly("bc1_decoder", &BC3Decoder::GetBC1Decoder,
|
bc3_decoder.def_property_readonly("bc1_decoder", &BC3Decoder::GetBC1Decoder,
|
||||||
"Internal :py:class:`~quicktex.s3tc.bc1.BC1Decoder` used for RGB data. Readonly.");
|
"Internal :py:class:`~quicktex.s3tc.bc1.BC1Decoder` used for RGB data. Readonly.");
|
||||||
bc3_decoder.def_property_readonly("bc4_decoder", &BC3Decoder::GetBC4Decoder,
|
bc3_decoder.def_property_readonly("bc4_decoder", &BC3Decoder::GetBC4Decoder,
|
||||||
|
@ -94,6 +94,16 @@ void InitBC4(py::module_ &s3tc) {
|
|||||||
|
|
||||||
:param int channel: the channel that will be read from. 0 to 3 inclusive. Default: 3 (alpha).
|
:param int channel: the channel that will be read from. 0 to 3 inclusive. Default: 3 (alpha).
|
||||||
)doc");
|
)doc");
|
||||||
|
|
||||||
|
bc4_encoder.def("encode", &BC4Encoder::Encode, "texture"_a, R"doc(
|
||||||
|
encode(self, texture: RawTexture) -> BC4Texture
|
||||||
|
|
||||||
|
Encode a raw texture into a new BC4Texture using the encoder's current settings.
|
||||||
|
|
||||||
|
:param RawTexture texture: Input texture to encode.
|
||||||
|
:returns: A new BC4Texture with the same dimension as the input.
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc4_encoder.def_property_readonly("channel", &BC4Encoder::GetChannel, "The channel that will be read from. 0 to 3 inclusive. Readonly.");
|
bc4_encoder.def_property_readonly("channel", &BC4Encoder::GetChannel, "The channel that will be read from. 0 to 3 inclusive. Readonly.");
|
||||||
// endregion
|
// endregion
|
||||||
|
|
||||||
@ -109,6 +119,16 @@ void InitBC4(py::module_ &s3tc) {
|
|||||||
|
|
||||||
:param int channel: The channel that will be written to. 0 to 3 inclusive. Default: 3 (alpha).
|
:param int channel: The channel that will be written to. 0 to 3 inclusive. Default: 3 (alpha).
|
||||||
)doc");
|
)doc");
|
||||||
|
|
||||||
|
bc4_decoder.def("decode", &BC4Decoder::Decode, "texture"_a, R"doc(
|
||||||
|
decode(self, texture: BC4Texture) -> RawTexture
|
||||||
|
|
||||||
|
Decode a BC4 texture into a new RawTexture using the decoder's current settings.
|
||||||
|
|
||||||
|
:param RawTexture texture: Input texture to encode.
|
||||||
|
:returns: A new RawTexture with the same dimensions as the input
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc4_decoder.def_property_readonly("channel", &BC4Decoder::GetChannel, "The channel that will be written to. 0 to 3 inclusive. Readonly.");
|
bc4_decoder.def_property_readonly("channel", &BC4Decoder::GetChannel, "The channel that will be written to. 0 to 3 inclusive. Readonly.");
|
||||||
// endregion
|
// endregion
|
||||||
}
|
}
|
||||||
|
@ -80,6 +80,15 @@ void InitBC5(py::module_ &s3tc) {
|
|||||||
:param int chan1: the second channel that will be read from. 0 to 3 inclusive. Default: 1 (green).
|
:param int chan1: the second channel that will be read from. 0 to 3 inclusive. Default: 1 (green).
|
||||||
)doc");
|
)doc");
|
||||||
|
|
||||||
|
bc5_encoder.def("encode", &BC5Encoder::Encode, "texture"_a, R"doc(
|
||||||
|
encode(self, texture: RawTexture) -> BC5Texture
|
||||||
|
|
||||||
|
Encode a raw texture into a new BC5Texture using the encoder's current settings.
|
||||||
|
|
||||||
|
:param RawTexture texture: Input texture to encode.
|
||||||
|
:returns: A new BC5Texture with the same dimension as the input.
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc5_encoder.def_property_readonly("channels", &BC5Encoder::GetChannels, "A 2-tuple of channels that will be read from. 0 to 3 inclusive. Readonly.");
|
bc5_encoder.def_property_readonly("channels", &BC5Encoder::GetChannels, "A 2-tuple of channels that will be read from. 0 to 3 inclusive. Readonly.");
|
||||||
bc5_encoder.def_property_readonly("bc4_encoders", &BC5Encoder::GetBC4Encoders,
|
bc5_encoder.def_property_readonly("bc4_encoders", &BC5Encoder::GetBC4Encoders,
|
||||||
"2-tuple of internal :py:class:`~quicktex.s3tc.bc4.BC4Encoder` s used for each channel. Readonly.");
|
"2-tuple of internal :py:class:`~quicktex.s3tc.bc4.BC4Encoder` s used for each channel. Readonly.");
|
||||||
@ -101,6 +110,15 @@ void InitBC5(py::module_ &s3tc) {
|
|||||||
:param int chan1: the second channel that will be written to. 0 to 3 inclusive. Default: 1 (green).
|
:param int chan1: the second channel that will be written to. 0 to 3 inclusive. Default: 1 (green).
|
||||||
)doc");
|
)doc");
|
||||||
|
|
||||||
|
bc5_decoder.def("decode", &BC5Decoder::Decode, "texture"_a, R"doc(
|
||||||
|
decode(self, texture: BC5Texture) -> RawTexture
|
||||||
|
|
||||||
|
Decode a BC5 texture into a new RawTexture using the decoder's current settings.
|
||||||
|
|
||||||
|
:param RawTexture texture: Input texture to encode.
|
||||||
|
:returns: A new RawTexture with the same dimensions as the input
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc5_decoder.def_property_readonly("channels", &BC5Decoder::GetChannels, "A 2-tuple of channels that will be written to. 0 to 3 inclusive. Readonly.");
|
bc5_decoder.def_property_readonly("channels", &BC5Decoder::GetChannels, "A 2-tuple of channels that will be written to. 0 to 3 inclusive. Readonly.");
|
||||||
bc5_decoder.def_property_readonly("bc4_decoders", &BC5Decoder::GetBC4Decoders,
|
bc5_decoder.def_property_readonly("bc4_decoders", &BC5Decoder::GetBC4Decoders,
|
||||||
"2-tuple of internal :py:class:`~quicktex.s3tc.bc4.BC4Decoder` s used for each channel. Readonly.");
|
"2-tuple of internal :py:class:`~quicktex.s3tc.bc4.BC4Decoder` s used for each channel. Readonly.");
|
||||||
|
Loading…
Reference in New Issue
Block a user