mirror of
https://github.com/drewcassidy/quicktex.git
synced 2024-09-13 06:37:34 +00:00
Document base classes
This commit is contained in:
parent
7c91139775
commit
f7821c3a70
@ -59,8 +59,9 @@ add_module_names = False
|
|||||||
autodoc_docstring_signature = True
|
autodoc_docstring_signature = True
|
||||||
|
|
||||||
autodoc_default_options = {
|
autodoc_default_options = {
|
||||||
'member-order': 'groupwise',
|
'member-order': 'bysource',
|
||||||
'exclude-members': '__weakref__'
|
'exclude-members': '__weakref__',
|
||||||
|
'imported-members': True,
|
||||||
}
|
}
|
||||||
|
|
||||||
# -- Options for Intersphinx ------------------------------------------------
|
# -- Options for Intersphinx ------------------------------------------------
|
||||||
|
@ -7,7 +7,7 @@ bc1 module
|
|||||||
----------
|
----------
|
||||||
.. automodule:: quicktex.s3tc.bc1
|
.. automodule:: quicktex.s3tc.bc1
|
||||||
|
|
||||||
.. autoclass:: BC1Encoder(BlockEncoder)
|
.. autoclass:: BC1Encoder
|
||||||
|
|
||||||
.. automethod:: __init__
|
.. automethod:: __init__
|
||||||
.. automethod:: set_level
|
.. automethod:: set_level
|
||||||
@ -38,7 +38,7 @@ bc1 module
|
|||||||
.. autoclass:: quicktex.s3tc.bc1::BC1Encoder.EndpointMode
|
.. autoclass:: quicktex.s3tc.bc1::BC1Encoder.EndpointMode
|
||||||
.. autoclass:: quicktex.s3tc.bc1::BC1Encoder.ErrorMode
|
.. autoclass:: quicktex.s3tc.bc1::BC1Encoder.ErrorMode
|
||||||
|
|
||||||
.. autoclass:: BC1Decoder(BlockDecoder)
|
.. autoclass:: BC1Decoder
|
||||||
|
|
||||||
.. automethod:: __init__
|
.. automethod:: __init__
|
||||||
.. autoproperty:: interpolator(self) -> quicktex.s3tc.interpolator.Interpolator
|
.. autoproperty:: interpolator(self) -> quicktex.s3tc.interpolator.Interpolator
|
||||||
@ -48,13 +48,13 @@ bc3 module
|
|||||||
----------
|
----------
|
||||||
.. automodule:: quicktex.s3tc.bc3
|
.. automodule:: quicktex.s3tc.bc3
|
||||||
|
|
||||||
.. autoclass:: BC3Encoder(BlockEncoder)
|
.. autoclass:: BC3Encoder
|
||||||
|
|
||||||
.. automethod:: __init__
|
.. automethod:: __init__
|
||||||
.. autoproperty:: bc1_encoder(self) -> quicktex.s3tc.bc1.BC1Encoder
|
.. autoproperty:: bc1_encoder(self) -> quicktex.s3tc.bc1.BC1Encoder
|
||||||
.. autoproperty:: bc4_encoder(self) -> quicktex.s3tc.bc4.BC4Encoder
|
.. autoproperty:: bc4_encoder(self) -> quicktex.s3tc.bc4.BC4Encoder
|
||||||
|
|
||||||
.. autoclass:: BC3Decoder(BlockDecoder)
|
.. autoclass:: BC3Decoder
|
||||||
|
|
||||||
.. automethod:: __init__
|
.. automethod:: __init__
|
||||||
.. autoproperty:: bc1_decoder(self) -> quicktex.s3tc.bc1.BC1Decoder
|
.. autoproperty:: bc1_decoder(self) -> quicktex.s3tc.bc1.BC1Decoder
|
||||||
@ -64,12 +64,12 @@ bc4 module
|
|||||||
----------
|
----------
|
||||||
.. automodule:: quicktex.s3tc.bc4
|
.. automodule:: quicktex.s3tc.bc4
|
||||||
|
|
||||||
.. autoclass:: BC4Encoder(BlockEncoder)
|
.. autoclass:: BC4Encoder
|
||||||
|
|
||||||
.. automethod:: __init__
|
.. automethod:: __init__
|
||||||
.. autoproperty:: channel(self) -> int
|
.. autoproperty:: channel(self) -> int
|
||||||
|
|
||||||
.. autoclass:: BC4Decoder(BlockDecoder)
|
.. autoclass:: BC4Decoder
|
||||||
|
|
||||||
.. automethod:: __init__
|
.. automethod:: __init__
|
||||||
.. autoproperty:: channel(self) -> int
|
.. autoproperty:: channel(self) -> int
|
||||||
@ -78,13 +78,13 @@ bc5 module
|
|||||||
----------
|
----------
|
||||||
.. automodule:: quicktex.s3tc.bc5
|
.. automodule:: quicktex.s3tc.bc5
|
||||||
|
|
||||||
.. autoclass:: BC5Encoder(BlockEncoder)
|
.. autoclass:: BC5Encoder
|
||||||
|
|
||||||
.. automethod:: __init__
|
.. automethod:: __init__
|
||||||
.. autoproperty:: bc4_encoders(self) -> tuple[quicktex.s3tc.bc4.BC4Encoder]
|
.. autoproperty:: bc4_encoders(self) -> tuple[quicktex.s3tc.bc4.BC4Encoder]
|
||||||
.. autoproperty:: channels(self) -> tuple[int, int]
|
.. autoproperty:: channels(self) -> tuple[int, int]
|
||||||
|
|
||||||
.. autoclass:: BC5Decoder(BlockDecoder)
|
.. autoclass:: BC5Decoder
|
||||||
|
|
||||||
.. automethod:: __init__
|
.. automethod:: __init__
|
||||||
.. autoproperty:: bc4_decoders(self) -> tuple[quicktex.s3tc.bc4.BC4Decoder]
|
.. autoproperty:: bc4_decoders(self) -> tuple[quicktex.s3tc.bc4.BC4Decoder]
|
||||||
@ -95,8 +95,3 @@ interpolator module
|
|||||||
|
|
||||||
.. automodule:: quicktex.s3tc.interpolator
|
.. automodule:: quicktex.s3tc.interpolator
|
||||||
:members:
|
:members:
|
||||||
|
|
||||||
.. autoclass:: Interpolator
|
|
||||||
.. autoclass:: InterpolatorRound(Interpolator)
|
|
||||||
.. autoclass:: InterpolatorNvidia(Interpolator)
|
|
||||||
.. autoclass:: InterpolatorAMD(Interpolator)
|
|
||||||
|
@ -48,7 +48,11 @@ void InitBC1(py::module_ &s3tc) {
|
|||||||
options.disable_function_signatures();
|
options.disable_function_signatures();
|
||||||
|
|
||||||
// BC1Encoder
|
// BC1Encoder
|
||||||
py::class_<BC1Encoder> bc1_encoder(bc1, "BC1Encoder", block_encoder, "Encodes RGB textures to BC1");
|
py::class_<BC1Encoder> bc1_encoder(bc1, "BC1Encoder", block_encoder, R"doc(
|
||||||
|
Base: :py:class:`~quicktex.BlockEncoder`
|
||||||
|
|
||||||
|
Encodes RGB textures to BC1.
|
||||||
|
)doc");
|
||||||
|
|
||||||
py::enum_<BC1Encoder::EndpointMode>(bc1_encoder, "EndpointMode", "Enum representing various methods of finding endpoints in a block.")
|
py::enum_<BC1Encoder::EndpointMode>(bc1_encoder, "EndpointMode", "Enum representing various methods of finding endpoints in a block.")
|
||||||
.value("LeastSquares", BC1Encoder::EndpointMode::LeastSquares, "Find endpoints using a 2D least squares approach.")
|
.value("LeastSquares", BC1Encoder::EndpointMode::LeastSquares, "Find endpoints using a 2D least squares approach.")
|
||||||
@ -129,7 +133,11 @@ void InitBC1(py::module_ &s3tc) {
|
|||||||
"Automatically clamped to between :py:const:`BC1Encoder.min_power_iterations` and :py:const:`BC1Encoder.max_power_iterations`");
|
"Automatically clamped to between :py:const:`BC1Encoder.min_power_iterations` and :py:const:`BC1Encoder.max_power_iterations`");
|
||||||
|
|
||||||
// BC1Decoder
|
// BC1Decoder
|
||||||
py::class_<BC1Decoder> bc1_decoder(bc1, "BC1Decoder", block_decoder, "Decodes BC1 textures to RGB");
|
py::class_<BC1Decoder> bc1_decoder(bc1, "BC1Decoder", block_decoder, R"doc(
|
||||||
|
Base: :py:class:`~quicktex.BlockDecoder`
|
||||||
|
|
||||||
|
Decodes BC1 textures to RGB
|
||||||
|
)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"pbdoc(
|
||||||
|
@ -48,7 +48,11 @@ void InitBC3(py::module_ &s3tc) {
|
|||||||
options.disable_function_signatures();
|
options.disable_function_signatures();
|
||||||
|
|
||||||
// BC3Encoder
|
// BC3Encoder
|
||||||
py::class_<BC3Encoder> bc3_encoder(bc3, "BC3Encoder", block_encoder, "Encodes RGBA textures to BC3");
|
py::class_<BC3Encoder> bc3_encoder(bc3, "BC3Encoder", block_encoder,R"doc(
|
||||||
|
Base: :py:class:`~quicktex.BlockEncoder`
|
||||||
|
|
||||||
|
Encodes RGBA textures to BC3
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc3_encoder.def(py::init<unsigned>(), "level"_a = 5);
|
bc3_encoder.def(py::init<unsigned>(), "level"_a = 5);
|
||||||
bc3_encoder.def(py::init<unsigned, InterpolatorPtr>(), "level"_a, "interpolator"_a, R"doc(
|
bc3_encoder.def(py::init<unsigned, InterpolatorPtr>(), "level"_a, "interpolator"_a, R"doc(
|
||||||
@ -67,7 +71,11 @@ void InitBC3(py::module_ &s3tc) {
|
|||||||
"Internal :py:class:`~quicktex.s3tc.bc4.BC4Encoder` used for alpha data. Readonly.");
|
"Internal :py:class:`~quicktex.s3tc.bc4.BC4Encoder` used for alpha data. Readonly.");
|
||||||
|
|
||||||
// BC3Decoder
|
// BC3Decoder
|
||||||
py::class_<BC3Decoder> bc3_decoder(bc3, "BC3Decoder", block_decoder, "Decodes BC3 textures to RGBA");
|
py::class_<BC3Decoder> bc3_decoder(bc3, "BC3Decoder", block_decoder, R"doc(
|
||||||
|
Base: :py:class:`~quicktex.BlockDecoder`
|
||||||
|
|
||||||
|
Decodes BC3 textures to RGBA
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc3_decoder.def(py::init<>());
|
bc3_decoder.def(py::init<>());
|
||||||
bc3_decoder.def(py::init<InterpolatorPtr>(), "interpolator"_a, R"doc(
|
bc3_decoder.def(py::init<InterpolatorPtr>(), "interpolator"_a, R"doc(
|
||||||
|
@ -44,7 +44,11 @@ void InitBC4(py::module_ &s3tc) {
|
|||||||
options.disable_function_signatures();
|
options.disable_function_signatures();
|
||||||
|
|
||||||
// BC4Encoder
|
// BC4Encoder
|
||||||
py::class_<BC4Encoder> bc4_encoder(bc4, "BC4Encoder", block_encoder, "Encodes single-channel textures to BC4.");
|
py::class_<BC4Encoder> bc4_encoder(bc4, "BC4Encoder", block_encoder, R"doc(
|
||||||
|
Base: :py:class:`~quicktex.BlockEncoder`
|
||||||
|
|
||||||
|
Encodes single-channel textures to BC4.
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc4_encoder.def(py::init<uint8_t>(), py::arg("channel") = 3, R"doc(
|
bc4_encoder.def(py::init<uint8_t>(), py::arg("channel") = 3, R"doc(
|
||||||
__init__(channel : int = 3) -> None
|
__init__(channel : int = 3) -> None
|
||||||
@ -56,7 +60,11 @@ void InitBC4(py::module_ &s3tc) {
|
|||||||
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.");
|
||||||
|
|
||||||
// BC4Decoder
|
// BC4Decoder
|
||||||
py::class_<BC4Decoder> bc4_decoder(bc4, "BC4Decoder", block_decoder, "Encodes BC4 textures to a single-channel texture.");
|
py::class_<BC4Decoder> bc4_decoder(bc4, "BC4Decoder", block_decoder, R"doc(
|
||||||
|
Base: :py:class:`~quicktex.BlockDecoder`
|
||||||
|
|
||||||
|
Decodes BC4 textures to a single-channel.
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc4_decoder.def(py::init<uint8_t>(), py::arg("channel") = 3, R"doc(
|
bc4_decoder.def(py::init<uint8_t>(), py::arg("channel") = 3, R"doc(
|
||||||
__init__(channel : int = 3) -> None
|
__init__(channel : int = 3) -> None
|
||||||
|
@ -41,7 +41,11 @@ void InitBC5(py::module_ &s3tc) {
|
|||||||
options.disable_function_signatures();
|
options.disable_function_signatures();
|
||||||
|
|
||||||
// BC5Encoder
|
// BC5Encoder
|
||||||
py::class_<BC5Encoder> bc5_encoder(bc5, "BC5Encoder", block_encoder, "Encodes dual-channel textures to BC5.");
|
py::class_<BC5Encoder> bc5_encoder(bc5, "BC5Encoder", block_encoder, R"doc(
|
||||||
|
Base: :py:class:`~quicktex.BlockEncoder`
|
||||||
|
|
||||||
|
Encodes dual-channel textures to BC5.
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc5_encoder.def(py::init<uint8_t, uint8_t>(), py::arg("chan0") = 0, py::arg("chan1") = 1, R"doc(
|
bc5_encoder.def(py::init<uint8_t, uint8_t>(), py::arg("chan0") = 0, py::arg("chan1") = 1, R"doc(
|
||||||
__init__(chan0 : int = 0, chan1 : int = 1) -> None
|
__init__(chan0 : int = 0, chan1 : int = 1) -> None
|
||||||
@ -57,7 +61,11 @@ void InitBC5(py::module_ &s3tc) {
|
|||||||
"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.");
|
||||||
|
|
||||||
// BC5Decoder
|
// BC5Decoder
|
||||||
py::class_<BC5Decoder> bc5_decoder(bc5, "BC5Decoder", block_decoder, "Decodes BC5 textures to a dual-channel texture.");
|
py::class_<BC5Decoder> bc5_decoder(bc5, "BC5Decoder", block_decoder, R"doc(
|
||||||
|
Base: :py:class:`~quicktex.BlockDecoder`
|
||||||
|
|
||||||
|
Decodes BC4 textures to two channels.
|
||||||
|
)doc");
|
||||||
|
|
||||||
bc5_decoder.def(py::init<uint8_t, uint8_t>(), py::arg("chan0") = 0, py::arg("chan1") = 1, R"doc(
|
bc5_decoder.def(py::init<uint8_t, uint8_t>(), py::arg("chan0") = 0, py::arg("chan1") = 1, R"doc(
|
||||||
__init__(chan0 : int = 0, chan1 : int = 1) -> None
|
__init__(chan0 : int = 0, chan1 : int = 1) -> None
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
/* Python-rgbcx Texture Compression Library
|
/* Python-rgbcx Texture Compression Library
|
||||||
Copyright (C) 2021 Andrew Cassidy <drewcassidy@me.com>
|
Copyright (C) 2021 Andrew Cassidy <drewcassidy@me.com>
|
||||||
Partially derived from rgbcx.h written by Richard Geldreich <richgel99@gmail.com>
|
Partially derived from rgbcx.h written by Richard Geldreich <richgel99@gmail.com> and licenced under the public domain
|
||||||
and licenced under the public domain
|
|
||||||
|
|
||||||
This program is free software: you can redistribute it and/or modify
|
This program is free software: you can redistribute it and/or modify
|
||||||
it under the terms of the GNU Lesser General Public License as published by
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
@ -31,21 +30,39 @@ using namespace quicktex::s3tc;
|
|||||||
using InterpolatorPtr = std::shared_ptr<Interpolator>;
|
using InterpolatorPtr = std::shared_ptr<Interpolator>;
|
||||||
|
|
||||||
void InitInterpolator(py::module_ &s3tc) {
|
void InitInterpolator(py::module_ &s3tc) {
|
||||||
auto interpolator = s3tc.def_submodule("_interpolator", "Internal interpolator module");
|
auto interpolator = s3tc.def_submodule("_interpolator", "internal interpolator module");
|
||||||
|
|
||||||
// Interpolator
|
// Interpolator
|
||||||
py::class_<Interpolator> ideal(
|
py::class_<Interpolator> ideal(
|
||||||
interpolator, "Interpolator",
|
interpolator, "Interpolator", R"doc(
|
||||||
"Interpolator base class representing the default mode, with no rounding for colors 2 and 3. This matches the D3D10 docs on BC1.");
|
Interpolator base class representing the ideal interpolation mode, with no rounding for colors 2 and 3.
|
||||||
|
This matches the `D3D10 docs`_ on BC1.
|
||||||
|
|
||||||
|
.. _D3D10 docs: https://docs.microsoft.com/en-us/windows/win32/direct3d10/d3d10-graphics-programming-guide-resources-block-compression
|
||||||
|
)doc");
|
||||||
|
|
||||||
// InterpolatorRound
|
// InterpolatorRound
|
||||||
py::class_<InterpolatorRound> round(interpolator, "InterpolatorRound", ideal,
|
py::class_<InterpolatorRound> round(interpolator, "InterpolatorRound", ideal, R"doc(
|
||||||
"Round colors 2 and 3. Matches the AMD Compressonator tool and the D3D9 docs on DXT1.");
|
Base: :py:class:`~quicktex.s3tc.interpolator.Interpolator`
|
||||||
|
|
||||||
|
Interpolator class representing the ideal rounding interpolation mode.
|
||||||
|
Round colors 2 and 3. Matches the AMD Compressonator tool and the `D3D9 docs`_ on DXT1.
|
||||||
|
|
||||||
|
.. _D3D9 docs: https://docs.microsoft.com/en-us/windows/win32/direct3d9/opaque-and-1-bit-alpha-textures
|
||||||
|
)doc");
|
||||||
|
|
||||||
// InterpolatorNvidia
|
// InterpolatorNvidia
|
||||||
py::class_<InterpolatorNvidia> nvidia(interpolator, "InterpolatorNvidia", ideal, "Nvidia GPU mode.");
|
py::class_<InterpolatorNvidia> nvidia(interpolator, "InterpolatorNvidia", ideal, R"doc(
|
||||||
|
Base: :py:class:`~quicktex.s3tc.interpolator.Interpolator`
|
||||||
|
|
||||||
|
Interpolator class representing the Nvidia GPU interpolation mode.
|
||||||
|
)doc");
|
||||||
|
|
||||||
// InterpolatorAMD
|
// InterpolatorAMD
|
||||||
py::class_<InterpolatorAMD> amd(interpolator, "InterpolatorAMD", ideal, "AMD GPU mode.");
|
py::class_<InterpolatorAMD> amd(interpolator, "InterpolatorAMD", ideal, R"doc(
|
||||||
|
Base: :py:class:`~quicktex.s3tc.interpolator.Interpolator`
|
||||||
|
|
||||||
|
Interpolator class representing the AMD GPU interpolation mode.
|
||||||
|
)doc");
|
||||||
}
|
}
|
||||||
} // namespace quicktex::bindings
|
} // namespace quicktex::bindings
|
Loading…
Reference in New Issue
Block a user