aboutsummaryrefslogtreecommitdiffstats
path: root/src/classes/com/sun/opengl/util/texture/spi/DDSImage.java
diff options
context:
space:
mode:
authorKenneth Russel <[email protected]>2006-05-20 14:23:41 +0000
committerKenneth Russel <[email protected]>2006-05-20 14:23:41 +0000
commit437584608fa8e479ba13f209ff42d609bda5c41d (patch)
tree7f10e8ace33a1e7bd1fb33b22fce285d8db6ddcd /src/classes/com/sun/opengl/util/texture/spi/DDSImage.java
parentc87828368dbb9e31f402de14be76af2b9af08588 (diff)
Fixed bugs in handling of mipmapped compressed textures
git-svn-id: file:///usr/local/projects/SUN/JOGL/git-svn/svn-server-sync/jogl/trunk@771 232f8b59-042b-4e1e-8c03-345bb8c30851
Diffstat (limited to 'src/classes/com/sun/opengl/util/texture/spi/DDSImage.java')
-rwxr-xr-xsrc/classes/com/sun/opengl/util/texture/spi/DDSImage.java14
1 files changed, 4 insertions, 10 deletions
diff --git a/src/classes/com/sun/opengl/util/texture/spi/DDSImage.java b/src/classes/com/sun/opengl/util/texture/spi/DDSImage.java
index 068e3baa6..12a855c57 100755
--- a/src/classes/com/sun/opengl/util/texture/spi/DDSImage.java
+++ b/src/classes/com/sun/opengl/util/texture/spi/DDSImage.java
@@ -734,18 +734,12 @@ public class DDSImage {
}
private int mipMapSizeInBytes(int map) {
+ int width = mipMapWidth(map);
+ int height = mipMapHeight(map);
if (isCompressed()) {
- if (!isSurfaceDescFlagSet(DDSD_LINEARSIZE)) {
- throw new RuntimeException("Illegal compressed texture: DDSD_LINEARSIZE not specified in texture header");
- }
- int bytes = header.pitchOrLinearSize;
- for (int i = 0; i < map; i++) {
- bytes >>= 2;
- }
- return bytes;
+ int blockSize = (getCompressionFormat() == D3DFMT_DXT1 ? 8 : 16);
+ return ((width+3)/4)*((height+3)/4)*blockSize;
} else {
- int width = mipMapWidth(map);
- int height = mipMapHeight(map);
return width * height * (getDepth() / 8);
}
}