| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528 |
-
- #include "../testTools.h"
- #include "../../DFPSR/base/simd.h"
- START_TEST(Texture)
- {
- // 1x1, 2x2, 4x4, 8x8, 16x16
- TextureRgbaU8 texture = TextureRgbaU8(4, 4);
- {
- stateName = U"Getting eight pixel offsets to layer.\n";
- U32x8 layerOffsets = texture_getPixelOffsetToLayer(texture, U32x8(0u));
- stateName = U"Comparing eight pixel offsets to layer.\n";
- ASSERT(allLanesEqual(layerOffsets, U32x8(85u)));
- stateName = U"Getting eight pixel offsets.\n";
- U32x8 pixelOffsets = texture_getPixelOffset(texture, U32x8(0u, 1u, 2u, 3u, 0u, 1u, 2u, 3u), U32x8(0u, 0u, 0u, 0u, 1u, 1u, 1u, 1u), U32x8(0u));
- stateName = U"Comparing eight pixel offsets.\n";
- ASSERT(allLanesEqual((pixelOffsets), U32x8(85u, 86u, 87u, 88u, 101u, 102u, 103u, 104u)));
- }
- ASSERT(texture_hasPyramid(texture));
- ASSERT_EQUAL(texture_getMaxWidth(texture), 16);
- ASSERT_EQUAL(texture_getMaxHeight(texture), 16);
- ASSERT_EQUAL(texture_getSmallestMipLevel(texture), 4);
- ASSERT_EQUAL(texture.impl_startOffset , 0b00000000000000000000000001010101);
- ASSERT_EQUAL(texture.impl_maxLevelMask, 0b00000000000000000000000011111111);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 15u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 14u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 13u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 12u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 11u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 10u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 9u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 8u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 7u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 6u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 5u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 4u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 3u), 0b00000000000000000000000000000001);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 2u), 0b00000000000000000000000000000101);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 1u), 0b00000000000000000000000000010101);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 0u), 0b00000000000000000000000001010101);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 7534u, 424u, 15u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 75624u, 6217u, 14u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 8562u, 91287u, 13u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 66u, 3578u, 12u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 13593u, 14375u, 11u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2586u, 1547u, 10u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 34589u, 2358u, 9u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 835206u, 23817u, 8u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 265u, 1365u, 7u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 8520u, 4895u, 6u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 574u, 86316u, 5u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 4u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 0u, 4u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 1u, 4u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 25u, 85u, 4u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 246753u, 837624u, 4u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 3u), 1u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 0u, 3u), 2u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 1u, 3u), 3u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 1u, 3u), 4u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 246753u, 837624u, 3u), 2u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 6u, 9u, 3u), 3u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 13u, 79u, 3u), 4u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 2u), 5u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 0u, 2u), 6u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 0u, 2u), 7u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 0u, 2u), 8u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 1u, 2u), 9u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 1u, 2u), 10u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 1u, 2u), 11u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 1u, 2u), 12u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 2u, 2u), 13u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 2u, 2u), 14u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 2u, 2u), 15u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 2u, 2u), 16u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 3u, 2u), 17u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 3u, 2u), 18u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 3u, 2u), 19u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 3u, 2u), 20u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 65536u, 2050u, 2u), 13u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 991366u, 5u, 2u), 11u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 1u), 21u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 0u, 1u), 22u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 0u, 1u), 23u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 0u, 1u), 24u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 4u, 0u, 1u), 25u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 5u, 0u, 1u), 26u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 6u, 0u, 1u), 27u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 7u, 0u, 1u), 28u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 1u, 1u), 29u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 1u, 1u), 30u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 1u, 1u), 31u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 1u, 1u), 32u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 4u, 1u, 1u), 33u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 5u, 1u, 1u), 34u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 6u, 1u, 1u), 35u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 7u, 1u, 1u), 36u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 2u, 1u), 37u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 2u, 1u), 38u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 2u, 1u), 39u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 2u, 1u), 40u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 4u, 2u, 1u), 41u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 5u, 2u, 1u), 42u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 6u, 2u, 1u), 43u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 7u, 2u, 1u), 44u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 3u, 1u), 45u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 3u, 1u), 46u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 3u, 1u), 47u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 3u, 1u), 48u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 4u, 3u, 1u), 49u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 5u, 3u, 1u), 50u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 6u, 3u, 1u), 51u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 7u, 3u, 1u), 52u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 4u, 1u), 53u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 4u, 1u), 54u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 4u, 1u), 55u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 4u, 1u), 56u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 4u, 4u, 1u), 57u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 5u, 4u, 1u), 58u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 6u, 4u, 1u), 59u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 7u, 4u, 1u), 60u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 5u, 1u), 61u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 5u, 1u), 62u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 5u, 1u), 63u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 5u, 1u), 64u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 4u, 5u, 1u), 65u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 5u, 5u, 1u), 66u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 6u, 5u, 1u), 67u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 7u, 5u, 1u), 68u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 6u, 1u), 69u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 6u, 1u), 70u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 6u, 1u), 71u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 6u, 1u), 72u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 4u, 6u, 1u), 73u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 5u, 6u, 1u), 74u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 6u, 6u, 1u), 75u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 7u, 6u, 1u), 76u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 7u, 1u), 77u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 7u, 1u), 78u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 7u, 1u), 79u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 7u, 1u), 80u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 4u, 7u, 1u), 81u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 5u, 7u, 1u), 82u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 6u, 7u, 1u), 83u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 7u, 7u, 1u), 84u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 37u, 132u, 1u), 58u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 518u, 260u, 1u), 59u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 15u, 15u, 1u), 84u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 0u), 85u);
- // The four first template arguments to texture_getPixelOffset are SQUARE, SINGLE_LAYER, XY_INSIDE and MIP_INSIDE, which can be used to simplify the calculations with any information known in compile time.
- // Optimized by saying that the image is a square, with multiple levels, and mip level within used bounds.
- uint32_t result = texture_getPixelOffset<true, false, true, true>(texture, 0u, 0u, 0u); ASSERT_EQUAL(result, 85u);
- #ifndef NDEBUG
- // Should crash with an error when making a false claim that the texture only has a single layer.
- BEGIN_CRASH(U"texture_getPixelOffset was told that the texture would only have a single layer");
- result = texture_getPixelOffset<false, true, false, false>(texture, 0u, 0u, 0u);
- END_CRASH
- #endif
- ASSERT(allLanesEqual(texture_getPixelOffset(texture, U32x4(0u, 0u, 0u, 0u), U32x4(0u, 0u, 0u, 0u), U32x4(0u, 1u, 2u, 3u)), U32x4(85u, 21u, 5u, 1u)));
- ASSERT(allLanesEqual(texture_getPixelOffset(texture, U32x4(0u, 1u, 0u, 1u), U32x4(0u, 0u, 1u, 1u), U32x4(3u, 3u, 3u, 3u)), U32x4(1u, 2u, 3u, 4u)));
- ASSERT(allLanesEqual(texture_getPixelOffset(texture, U32x4(2u, 3u, 0u, 1u), U32x4(0u, 0u, 1u, 1u), U32x4(0u)), U32x4(87u, 88u, 101u, 102u)));
- ASSERT(allLanesEqual(texture_getPixelOffset(texture, U32x4(2u, 3u, 0u, 1u), U32x4(0u, 0u, 1u, 1u), U32x4(1u)), U32x4(23u, 24u, 29u, 30u)));
- ASSERT(allLanesEqual(texture_getPixelOffset(texture, U32x4(2u, 3u, 0u, 1u), U32x4(0u, 0u, 1u, 1u), U32x4(2u)), U32x4(7u, 8u, 9u, 10u)));
- ASSERT(allLanesEqual(texture_getPixelOffset(texture, U32x8(0u, 1u, 2u, 3u, 0u, 1u, 2u, 3u), U32x8(0u, 0u, 0u, 0u, 1u, 1u, 1u, 1u), U32x8(0u)), U32x8(85u, 86u, 87u, 88u, 101u, 102u, 103u, 104u)));
- ASSERT(allLanesEqual(texture_getPixelOffset(texture, U32x8(0u, 1u, 2u, 3u, 0u, 1u, 2u, 3u), U32x8(0u, 0u, 0u, 0u, 1u, 1u, 1u, 1u), U32x8(1u)), U32x8(21u, 22u, 23u, 24u, 29u, 30u, 31u, 32u)));
- ASSERT(allLanesEqual(texture_getPixelOffset(texture, U32x8(0u, 1u, 2u, 3u, 0u, 1u, 2u, 3u), U32x8(0u, 0u, 0u, 0u, 1u, 1u, 1u, 1u), U32x8(2u)), U32x8(5u, 6u, 7u, 8u, 9u, 10u, 11u, 12u)));
- }
- {
- // 1x2, 2x4, 4x8
- TextureRgbaU8 texture = TextureRgbaU8(2, 3);
- ASSERT(texture_hasPyramid(texture));
- ASSERT_EQUAL(texture_getMaxWidth(texture), 4);
- ASSERT_EQUAL(texture_getMaxHeight(texture), 8);
- ASSERT_EQUAL(texture_getSmallestMipLevel(texture), 2);
- ASSERT_EQUAL(texture.impl_startOffset , 0b00000000000000000000000000001010);
- ASSERT_EQUAL(texture.impl_maxLevelMask, 0b00000000000000000000000000011111);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 15u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 14u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 13u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 12u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 11u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 10u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 9u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 8u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 7u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 6u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 5u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 4u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 3u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 2u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 1u), 0b00000000000000000000000000000010);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 0u), 0b00000000000000000000000000001010);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 15u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 14u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 13u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 12u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 11u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 10u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 9u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 8u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 7u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 6u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 5u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 4u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 3u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 2u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 63u, 0u, 2u), 0u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 1u, 2u), 1u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 94u, 7u, 2u), 1u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 1u), 2u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 0u, 1u), 3u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 1u, 1u), 4u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 1u, 1u), 5u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 2u, 1u), 6u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 2u, 1u), 7u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 3u, 1u), 8u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 3u, 1u), 9u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 0u), 10u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 0u, 0u), 11u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 0u, 0u), 12u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 0u, 0u), 13u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 1u, 0u), 14u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 1u, 0u), 15u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 1u, 0u), 16u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 1u, 0u), 17u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 2u, 0u), 18u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 2u, 0u), 19u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 2u, 0u), 20u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 2u, 0u), 21u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 3u, 0u), 22u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 3u, 0u), 23u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 3u, 0u), 24u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 3u, 0u), 25u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 4u, 0u), 26u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 4u, 0u), 27u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 4u, 0u), 28u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 4u, 0u), 29u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 5u, 0u), 30u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 32u, 29u, 0u), 30u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 5u, 0u), 31u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 5u, 0u), 32u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 5u, 0u), 33u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 6u, 0u), 34u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 6u, 0u), 35u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 6u, 0u), 36u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 6u, 0u), 37u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 7u, 0u), 38u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 1u, 7u, 0u), 39u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 2u, 7u, 0u), 40u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 3u, 7u, 0u), 41u);
- }
- {
- // 2x1, 4x2, 8x4, 16x8
- TextureRgbaU8 texture = TextureRgbaU8(4, 3);
- ASSERT(texture_hasPyramid(texture));
- ASSERT_EQUAL(texture_getMaxWidth(texture), 16);
- ASSERT_EQUAL(texture_getMaxHeight(texture), 8);
- ASSERT_EQUAL(texture_getSmallestMipLevel(texture), 3);
- ASSERT_EQUAL(texture.impl_startOffset , 0b00000000000000000000000000101010);
- ASSERT_EQUAL(texture.impl_maxLevelMask, 0b00000000000000000000000001111111);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 15u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 14u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 13u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 12u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 11u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 10u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 9u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 8u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 7u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 6u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 5u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 4u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 3u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 2u), 0b00000000000000000000000000000010);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 1u), 0b00000000000000000000000000001010);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 0u), 0b00000000000000000000000000101010);
- }
- {
- // 4x4, 8x8, 16x16, 32x32
- TextureRgbaU8 texture = TextureRgbaU8(5, 5, 3);
- ASSERT(texture_hasPyramid(texture));
- ASSERT_EQUAL(texture_getMaxWidth(texture), 32);
- ASSERT_EQUAL(texture_getMaxHeight(texture), 32);
- ASSERT_EQUAL(texture_getSmallestMipLevel(texture), 3);
- ASSERT_EQUAL(texture.impl_startOffset , 0b00000000000000000000000101010000);
- ASSERT_EQUAL(texture.impl_maxLevelMask, 0b00000000000000000000001111111111);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 15u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 14u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 13u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 12u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 11u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 10u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 9u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 8u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 7u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 6u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 5u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 4u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 3u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 2u), 0b00000000000000000000000000010000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 1u), 0b00000000000000000000000001010000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 0u), 0b00000000000000000000000101010000);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 0u, 0u), 336u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 32u, 32u, 0u), 336u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 64u, 64u, 0u), 336u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 128u, 128u, 0u), 336u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 8192u, 8192u, 0u), 336u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 31u, 0u, 0u), 367u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 1u, 0u), 368u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 0u, 31u, 0u), 1328u);
- ASSERT_EQUAL(texture_getPixelOffset(texture, 31u, 31u, 0u), 1359u);
- }
- {
- // 16x8, 32x16
- TextureRgbaU8 texture = TextureRgbaU8(5, 4, 1);
- ASSERT(texture_hasPyramid(texture));
- ASSERT_EQUAL(texture_getMaxWidth(texture), 32);
- ASSERT_EQUAL(texture_getMaxHeight(texture), 16);
- ASSERT_EQUAL(texture_getSmallestMipLevel(texture), 1);
- ASSERT_EQUAL(texture.impl_startOffset , 0b00000000000000000000000010000000);
- ASSERT_EQUAL(texture.impl_maxLevelMask, 0b00000000000000000000000111111111);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 15u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 14u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 13u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 12u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 11u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 10u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 9u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 8u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 7u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 6u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 5u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 4u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 3u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 2u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 1u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 0u), 0b00000000000000000000000010000000);
- }
- {
- // 16x32
- TextureRgbaU8 texture = TextureRgbaU8(4, 5, 0);
- ASSERT(!texture_hasPyramid(texture));
- ASSERT_EQUAL(texture_getMaxWidth(texture), 16);
- ASSERT_EQUAL(texture_getMaxHeight(texture), 32);
- ASSERT_EQUAL(texture_getSmallestMipLevel(texture), 0);
- ASSERT_EQUAL(texture.impl_startOffset , 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture.impl_maxLevelMask, 0b00000000000000000000000111111111);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 15u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 14u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 13u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 12u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 11u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 10u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 9u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 8u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 7u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 6u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 5u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 4u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 3u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 2u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 1u), 0b00000000000000000000000000000000);
- ASSERT_EQUAL(texture_getPixelOffsetToLayer(texture, 0u), 0b00000000000000000000000000000000);
- }
- {
- // 1x1, 2x2, 4x4
- TextureRgbaU8 texture = TextureRgbaU8(2, 2);
- texture_writePixel(texture, 0u, 0u, 2u, 1000u);
- texture_writePixel(texture, 0u, 0u, 1u, 1001u);
- texture_writePixel(texture, 1u, 0u, 1u, 1101u);
- texture_writePixel(texture, 0u, 1u, 1u, 1011u);
- texture_writePixel(texture, 1u, 1u, 1u, 1111u);
- texture_writePixel(texture, 0u, 0u, 0u, 1002u);
- texture_writePixel(texture, 1u, 0u, 0u, 1102u);
- texture_writePixel(texture, 2u, 0u, 0u, 1202u);
- texture_writePixel(texture, 3u, 0u, 0u, 1302u);
- texture_writePixel(texture, 0u, 1u, 0u, 1012u);
- texture_writePixel(texture, 1u, 1u, 0u, 1112u);
- texture_writePixel(texture, 2u, 1u, 0u, 1212u);
- texture_writePixel(texture, 3u, 1u, 0u, 1312u);
- texture_writePixel(texture, 0u, 2u, 0u, 1022u);
- texture_writePixel(texture, 1u, 2u, 0u, 1122u);
- texture_writePixel(texture, 2u, 2u, 0u, 1222u);
- texture_writePixel(texture, 3u, 2u, 0u, 1322u);
- texture_writePixel(texture, 0u, 3u, 0u, 1032u);
- texture_writePixel(texture, 1u, 3u, 0u, 1132u);
- texture_writePixel(texture, 2u, 3u, 0u, 1232u);
- texture_writePixel(texture, 3u, 3u, 0u, 1332u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 2u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 1u), 1001u);
- ASSERT_EQUAL(texture_readPixel(texture, 1u, 0u, 1u), 1101u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 1u, 1u), 1011u);
- ASSERT_EQUAL(texture_readPixel(texture, 1u, 1u, 1u), 1111u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 0u), 1002u);
- ASSERT_EQUAL(texture_readPixel(texture, 1u, 0u, 0u), 1102u);
- ASSERT_EQUAL(texture_readPixel(texture, 2u, 0u, 0u), 1202u);
- ASSERT_EQUAL(texture_readPixel(texture, 3u, 0u, 0u), 1302u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 1u, 0u), 1012u);
- ASSERT_EQUAL(texture_readPixel(texture, 1u, 1u, 0u), 1112u);
- ASSERT_EQUAL(texture_readPixel(texture, 2u, 1u, 0u), 1212u);
- ASSERT_EQUAL(texture_readPixel(texture, 3u, 1u, 0u), 1312u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 2u, 0u), 1022u);
- ASSERT_EQUAL(texture_readPixel(texture, 1u, 2u, 0u), 1122u);
- ASSERT_EQUAL(texture_readPixel(texture, 2u, 2u, 0u), 1222u);
- ASSERT_EQUAL(texture_readPixel(texture, 3u, 2u, 0u), 1322u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 3u, 0u), 1032u);
- ASSERT_EQUAL(texture_readPixel(texture, 1u, 3u, 0u), 1132u);
- ASSERT_EQUAL(texture_readPixel(texture, 2u, 3u, 0u), 1232u);
- ASSERT_EQUAL(texture_readPixel(texture, 3u, 3u, 0u), 1332u);
- ASSERT_EQUAL(texture_readPixel(texture, 7u, 3u, 0u), 1332u);
- ASSERT_EQUAL(texture_readPixel(texture, 3u, 11u, 0u), 1332u);
- ASSERT_EQUAL(texture_readPixel(texture, 1u, 0u, 2u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 1u, 2u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 1u, 1u, 2u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 426462u, 1257535u, 2u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 3u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 3u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 4u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 4u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 5u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 5u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 6u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 6u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 7u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 7u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 8u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 8u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 9u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 9u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 10u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 10u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 11u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 11u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 12u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 12u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 13u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 13u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 14u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 14u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 0u, 0u, 15u), 1000u);
- ASSERT_EQUAL(texture_readPixel(texture, 34698u, 7456u, 15u), 1000u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.0f, 0.0f, 2u), 1000u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.7f, 0.1f, 2u), 1000u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.5f, 0.2f, 2u), 1000u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 4.2f, 7.2f, 2u), 1000u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.25f, 0.25f, 1u), 1001u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.75f, 0.25f, 1u), 1101u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.25f, 0.75f, 1u), 1011u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.75f, 0.75f, 1u), 1111u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.5f / 4.0f, 0.5f / 4.0f, 0u), 1002u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 1.5f / 4.0f, 0.5f / 4.0f, 0u), 1102u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 2.5f / 4.0f, 0.5f / 4.0f, 0u), 1202u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 3.5f / 4.0f, 0.5f / 4.0f, 0u), 1302u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.5f / 4.0f, 1.5f / 4.0f, 0u), 1012u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 1.5f / 4.0f, 1.5f / 4.0f, 0u), 1112u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 2.5f / 4.0f, 1.5f / 4.0f, 0u), 1212u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 3.5f / 4.0f, 1.5f / 4.0f, 0u), 1312u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.5f / 4.0f, 2.5f / 4.0f, 0u), 1022u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 1.5f / 4.0f, 2.5f / 4.0f, 0u), 1122u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 2.5f / 4.0f, 2.5f / 4.0f, 0u), 1222u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 3.5f / 4.0f, 2.5f / 4.0f, 0u), 1322u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 0.5f / 4.0f, 3.5f / 4.0f, 0u), 1032u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 1.5f / 4.0f, 3.5f / 4.0f, 0u), 1132u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 2.5f / 4.0f, 3.5f / 4.0f, 0u), 1232u);
- ASSERT_EQUAL(texture_sample_nearest(texture, 3.5f / 4.0f, 3.5f / 4.0f, 0u), 1332u);
- ASSERT_EQUAL(texture_sample_nearest(texture, -53.0f, -17.0f, 2u), 1000u);
- ASSERT_EQUAL(texture_sample_nearest(texture, -53.0f, -17.0f, 3u), 1000u);
- ASSERT_EQUAL(texture_sample_nearest(texture, -53.0f, -17.0f, 15u), 1000u);
- // TODO: Test the optimization template flags.
- }
- // TODO: Test reading pixels from SafePointer with and without a specified row index.
- {
- /*
- OrderedImageRgbaU8 originalImage = filter_generateRgbaU8(64, 64, [](int x, int y) -> ColorRgbaI32 {
- return ColorRgbaI32(x * 4, y * 4, 0, 255);
- });
- TextureRgbaU8 texture = texture_create_RgbaU8(originalImage);
- */
- // TODO: Do some kind of test with the texture.
- // TODO: Allow creating an unaligned image pointing directly to a specific mip level's pixel data, so that it can easily be drawn for debugging.
- }
- // TODO: Create equivalent functionality that can easily replace the old interface.
- { // RGBA Texture
- /*
- ImageRgbaU8 image;
- image = image_create_RgbaU8(256, 256);
- ASSERT_EQUAL(image_hasPyramid(image), false);
- image_generatePyramid(image);
- ASSERT_EQUAL(image_hasPyramid(image), true);
- image_removePyramid(image);
- ASSERT_EQUAL(image_hasPyramid(image), false);
- image_generatePyramid(image);
- ASSERT_EQUAL(image_hasPyramid(image), true);
- */
- }
- { // Texture criterias
- /*
- ImageRgbaU8 image, subImage;
- image = image_create_RgbaU8(16, 16);
- ASSERT_EQUAL(image_isTexture(image), false); // Too small
- image = image_create_RgbaU8(47, 64);
- ASSERT_EQUAL(image_isTexture(image), false); // Not power-of-two width
- image = image_create_RgbaU8(32, 35);
- ASSERT_EQUAL(image_isTexture(image), false); // Not power-of-two height
- image = image_create_RgbaU8(32, 32);
- ASSERT_EQUAL(image_isTexture(image), true); // Okay
- image = image_create_RgbaU8(32, 16384);
- subImage = image_getSubImage(image, IRect(0, 0, 32, 128));
- ASSERT_EQUAL(image_isTexture(image), true); // Okay
- ASSERT_EQUAL(image_isTexture(subImage), true); // Okay to use full-width vertical sub-images
- image = image_create_RgbaU8(16384, 32);
- subImage = image_getSubImage(image, IRect(0, 0, 128, 32));
- ASSERT_EQUAL(image_isTexture(image), true); // Okay
- ASSERT_EQUAL(image_isTexture(subImage), false); // Not okay to use partial width leading to partial stride
- image = image_create_RgbaU8(16384 + 1, 32);
- ASSERT_EQUAL(image_isTexture(image), false); // Too wide and not power-of-two width
- image = image_create_RgbaU8(32768, 32);
- ASSERT_EQUAL(image_isTexture(image), false); // Too wide
- image = image_create_RgbaU8(32, 16384 + 1);
- ASSERT_EQUAL(image_isTexture(image), false); // Too high and not power-of-two height
- image = image_create_RgbaU8(32, 32768);
- ASSERT_EQUAL(image_isTexture(image), false); // Too high
- */
- }
- END_TEST
|