Add ktx
This commit is contained in:
@@ -0,0 +1,9 @@
|
||||
# Copyright (c) 2023, Shukant Pal and Contributors
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
from pathlib import Path
|
||||
import os
|
||||
|
||||
__test_images__ = os.environ['KTX_IMAGES_DIR'] \
|
||||
if 'KTX_IMAGES_DIR' in os.environ \
|
||||
else str((Path(__file__) / Path('../../../../tests/testimages')).resolve())
|
||||
@@ -0,0 +1,26 @@
|
||||
# Copyright (c) 2023, Shukant Pal and Contributors
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
from pyktx import *
|
||||
from test_config import __test_images__
|
||||
import unittest
|
||||
|
||||
|
||||
class TestKtxTexture(unittest.TestCase):
|
||||
def test_kv_data(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'astc_ldr_4x4_FlightHelmet_baseColor.ktx2')
|
||||
texture = KtxTexture2.create_from_named_file(test_ktx_file)
|
||||
|
||||
self.assertEqual(texture.kv_data.find_value('KTXorientation'), b'rd\x00')
|
||||
self.assertEqual(texture.kv_data.copy(), {
|
||||
'KTXorientation': b'rd\x00',
|
||||
'KTXwriter': b'toktx v4.0.__default__ / libktx v4.0.__default__\x00',
|
||||
'KTXwriterScParams': b'--encode astc --astc_blk_d 4x4\x00',
|
||||
})
|
||||
|
||||
for key in ['KTXorientation', 'KTXwriter', 'KTXwriterScParams']:
|
||||
texture.kv_data.delete_kv_pair(key)
|
||||
texture.kv_data.add_kv_pair('KTXwriter', b'pyktx v4.0.__default__ / libktx v4.0.__default__\x00')
|
||||
|
||||
self.assertEqual(texture.kv_data.find_value('KTXwriter'),
|
||||
b'pyktx v4.0.__default__ / libktx v4.0.__default__\x00')
|
||||
@@ -0,0 +1,60 @@
|
||||
# Copyright (c) 2023, Shukant Pal and Contributors
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
from pyktx import *
|
||||
from tempfile import NamedTemporaryFile
|
||||
from test_config import __test_images__
|
||||
import os
|
||||
import unittest
|
||||
|
||||
|
||||
class TestKtxTexture1(unittest.TestCase):
|
||||
def test_create_from_named_file(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'etc1.ktx')
|
||||
texture = KtxTexture1.create_from_named_file(test_ktx_file)
|
||||
|
||||
self.assertEqual(texture.gl_internalformat, GlInternalformat.ETC1_RGB8_OES)
|
||||
self.assertFalse(texture.is_array)
|
||||
self.assertFalse(texture.generate_mipmaps)
|
||||
self.assertEqual(texture.num_levels, 1)
|
||||
|
||||
def test_write_to_named_file(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'etc2-rgb.ktx')
|
||||
copy_file = NamedTemporaryFile(delete=False)
|
||||
copy_file.close()
|
||||
|
||||
texture = KtxTexture1.create_from_named_file(test_ktx_file, KtxTextureCreateFlagBits.LOAD_IMAGE_DATA_BIT)
|
||||
texture.write_to_named_file(copy_file.name)
|
||||
|
||||
with open(test_ktx_file, 'rb') as original, open(copy_file.name, 'rb') as copy:
|
||||
self.assertEqual(original.read(), copy.read())
|
||||
|
||||
os.unlink(copy_file.name)
|
||||
|
||||
def test_write_to_memory(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'etc2-rgba1.ktx')
|
||||
texture = KtxTexture1.create_from_named_file(test_ktx_file, KtxTextureCreateFlagBits.LOAD_IMAGE_DATA_BIT)
|
||||
texture_bytes = texture.write_to_memory()
|
||||
|
||||
with open(test_ktx_file, 'rb') as original:
|
||||
self.assertEqual(original.read(), texture_bytes)
|
||||
|
||||
def test_get_data(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'etc2-rgba1.ktx')
|
||||
texture = KtxTexture1.create_from_named_file(test_ktx_file, KtxTextureCreateFlagBits.LOAD_IMAGE_DATA_BIT)
|
||||
|
||||
data = texture.data()
|
||||
|
||||
with open(test_ktx_file, 'rb') as file:
|
||||
level_0_size = texture.image_size(0)
|
||||
self.assertEqual(file.read()[-level_0_size:], data[:])
|
||||
|
||||
def test_create(self):
|
||||
info = KtxTextureCreateInfo(
|
||||
gl_internal_format=GlInternalformat.COMPRESSED_RGBA_ASTC_4x4_KHR,
|
||||
base_width=10,
|
||||
base_height=10,
|
||||
base_depth=1)
|
||||
|
||||
texture = KtxTexture1.create(info, KtxTextureCreateStorage.ALLOC)
|
||||
texture.set_image_from_memory(0, 0, 0, bytes(texture.data_size))
|
||||
@@ -0,0 +1,104 @@
|
||||
# Copyright (c) 2023, Shukant Pal and Contributors
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
from pyktx import *
|
||||
from test_config import __test_images__
|
||||
import unittest
|
||||
|
||||
|
||||
class TestKtxTexture2(unittest.TestCase):
|
||||
def test_create_from_named_file(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'astc_ldr_4x4_FlightHelmet_baseColor.ktx2')
|
||||
texture = KtxTexture2.create_from_named_file(test_ktx_file)
|
||||
|
||||
self.assertEqual(texture.num_levels, 1)
|
||||
self.assertEqual(texture.num_faces, 1)
|
||||
self.assertEqual(texture.vk_format, VkFormat.VK_FORMAT_ASTC_4x4_SRGB_BLOCK)
|
||||
self.assertEqual(texture.base_width, 2048)
|
||||
self.assertEqual(texture.base_height, 2048)
|
||||
self.assertEqual(texture.supercompression_scheme, KtxSupercmpScheme.NONE)
|
||||
|
||||
def test_create_from_named_file_mipmapped(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'astc_mipmap_ldr_4x4_posx.ktx2')
|
||||
texture = KtxTexture2.create_from_named_file(test_ktx_file, KtxTextureCreateFlagBits.NO_FLAGS)
|
||||
|
||||
self.assertEqual(texture.num_levels, 12)
|
||||
self.assertEqual(texture.base_width, 2048)
|
||||
self.assertEqual(texture.base_height, 2048)
|
||||
|
||||
def test_get_image_size(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'astc_mipmap_ldr_4x4_posx.ktx2')
|
||||
texture = KtxTexture2.create_from_named_file(test_ktx_file)
|
||||
|
||||
self.assertEqual(texture.image_size(0), 4194304)
|
||||
|
||||
def test_get_image_offset(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'astc_mipmap_ldr_4x4_posx.ktx2')
|
||||
texture = KtxTexture2.create_from_named_file(test_ktx_file)
|
||||
|
||||
level11_offset = texture.image_offset(11, 0, 0)
|
||||
level0_offset = texture.image_offset(0, 0, 0)
|
||||
|
||||
self.assertEqual(level11_offset, 0)
|
||||
self.assertEqual(level0_offset - level11_offset, 0x155790 - 0x220)
|
||||
|
||||
def test_get_size(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'astc_mipmap_ldr_4x4_posx.ktx2')
|
||||
texture = KtxTexture2.create_from_named_file(test_ktx_file)
|
||||
|
||||
self.assertEqual(texture.num_levels, 12)
|
||||
|
||||
data_size = texture.data_size
|
||||
total_size = 0
|
||||
|
||||
for i in range(0, 12):
|
||||
total_size += texture.image_size(i)
|
||||
|
||||
self.assertEqual(total_size, data_size)
|
||||
|
||||
data = texture.data()
|
||||
self.assertEqual(len(data), data_size)
|
||||
|
||||
def test_get_data(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'astc_mipmap_ldr_4x4_posx.ktx2')
|
||||
texture = KtxTexture2.create_from_named_file(test_ktx_file)
|
||||
|
||||
self.assertEqual(texture.num_levels, 12)
|
||||
|
||||
level0_length = texture.image_size(0)
|
||||
|
||||
with open(test_ktx_file, 'rb') as file:
|
||||
data = texture.data()
|
||||
self.assertEqual(file.read()[-level0_length - 1:], data[-level0_length - 1:])
|
||||
|
||||
def test_compress_basis(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'arraytex_7_mipmap_reference_u.ktx2')
|
||||
texture = KtxTexture2.create_from_named_file(test_ktx_file, KtxTextureCreateFlagBits.LOAD_IMAGE_DATA_BIT)
|
||||
|
||||
self.assertEqual(texture.is_compressed, False)
|
||||
self.assertEqual(texture.supercompression_scheme, KtxSupercmpScheme.NONE)
|
||||
|
||||
texture.compress_basis(KtxBasisParams(quality_level=1))
|
||||
|
||||
self.assertEqual(texture.is_compressed, True)
|
||||
self.assertEqual(texture.supercompression_scheme, KtxSupercmpScheme.BASIS_LZ)
|
||||
|
||||
def test_transcode_basis(self):
|
||||
test_ktx_file = os.path.join(__test_images__, 'color_grid_basis.ktx2')
|
||||
texture = KtxTexture2.create_from_named_file(test_ktx_file, KtxTextureCreateFlagBits.LOAD_IMAGE_DATA_BIT)
|
||||
|
||||
texture.transcode_basis(KtxTranscodeFmt.ASTC_4x4_RGBA, 0)
|
||||
|
||||
self.assertEqual(texture.vk_format, VkFormat.VK_FORMAT_ASTC_4x4_SRGB_BLOCK)
|
||||
|
||||
def test_create(self):
|
||||
info = KtxTextureCreateInfo(
|
||||
gl_internal_format=None, # ignored
|
||||
base_width=10,
|
||||
base_height=10,
|
||||
base_depth=1,
|
||||
vk_format=VkFormat.VK_FORMAT_ASTC_4x4_SRGB_BLOCK)
|
||||
|
||||
texture = KtxTexture2.create(info, KtxTextureCreateStorage.ALLOC)
|
||||
self.assertEqual(texture.vk_format, VkFormat.VK_FORMAT_ASTC_4x4_SRGB_BLOCK)
|
||||
texture.set_image_from_memory(0, 0, 0, bytes(texture.data_size))
|
||||
Reference in New Issue
Block a user