Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Texture compression #4758

Merged
merged 34 commits into from
Feb 2, 2017
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
4cc7559
Add support for s3tc, pvrtc, and etc1 compressed textures and loading…
bagnell Dec 1, 2016
cd3b02a
Move exported function to the top
pjcozzi Dec 20, 2016
797e43b
Style
pjcozzi Dec 20, 2016
a9fc4f9
Update CHANGES.md
pjcozzi Dec 20, 2016
0235cec
Merge branch 'master' into texture-compression
bagnell Dec 20, 2016
ca72704
Fix failing tests.
bagnell Dec 20, 2016
64dd9b4
Add ktx loading support to materials. Update Sandcastle and tests.
bagnell Dec 21, 2016
da6d1c6
Document type returned from loadKTX and doc unsupported features of t…
bagnell Dec 21, 2016
172cc21
Fix typo.
bagnell Dec 21, 2016
b1876d9
Add missing sampler when loading glTF with comressed texture.
bagnell Dec 21, 2016
1eef793
Merge branch 'master' into texture-compression
bagnell Jan 4, 2017
cb01073
Initial support for transcoding textures from crunch to DXT.
bagnell Jan 5, 2017
c67a2ca
Fix issue with binary glTF compressed textures.
bagnell Jan 5, 2017
bf97394
Merge branch 'texture-compression' into crunch
bagnell Jan 5, 2017
68082c2
Move transcoding CRN to DXT to a web worker.
bagnell Jan 5, 2017
5875390
Add support for embedded crunch textures in binary glTF. Update the doc.
bagnell Jan 5, 2017
ee6856c
Add crunch support to imagery provider and material. Add loadCRN test…
bagnell Jan 5, 2017
252bb8b
Add model tests with crunch compressed textures.
bagnell Jan 5, 2017
f6cf955
Updates from review.
bagnell Jan 9, 2017
73fc589
Update crunch.js and update licenses.
bagnell Jan 9, 2017
304d32a
Merge pull request #4814 from AnalyticalGraphicsInc/crunch
pjcozzi Jan 9, 2017
40f8bcd
Merge branch 'master' into texture-compression
bagnell Jan 26, 2017
ee85f5c
Update parsing glTF compressed textures.
bagnell Jan 26, 2017
d7d82d0
Add getCompressedTextureFormatSupported to Scene.
bagnell Jan 26, 2017
d1270e1
Merge branch 'master' into texture-compression
bagnell Jan 30, 2017
7b9c700
Update test models with compressed textures. Fix binary glTF.
bagnell Jan 30, 2017
3bd7004
Update texture specs after merge.
bagnell Jan 30, 2017
324200c
Fix loading multiple textures.
bagnell Jan 30, 2017
f6ee997
Update ETC1 test.
bagnell Jan 30, 2017
9574914
Fix failing CI tests.
bagnell Jan 30, 2017
4b713b9
Merge branch 'master' into texture-compression
bagnell Feb 1, 2017
697877c
Update CHANGES.md.
bagnell Feb 1, 2017
3938f7b
Merge branch 'master' into texture-compression
bagnell Feb 1, 2017
ffa2554
Tweak CHANGES.md
pjcozzi Feb 2, 2017
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ Change Log
* Added `divideComponents` function to `Cartesian2`, `Cartesian3`, and `Cartesian4`. [#4750](https://github.com/AnalyticalGraphicsInc/cesium/pull/4750)
* Added `WebGLConstants` enum. Previously, this was part of the private Renderer API. [#4731](https://github.com/AnalyticalGraphicsInc/cesium/pull/4731)
* Fixed tooltips for gallery thumbnails in Sandcastle [#4702](https://github.com/AnalyticalGraphicsInc/cesium/pull/4702)
* Added compressed texture support. The supported extensions are `WEBGL_compressed_s3tc`, `WEBGL_compressed_texture_pvrtc`, and `WEBGL_compressed_texture_etc1`. [#4758](https://github.com/AnalyticalGraphicsInc/cesium/pull/4758)

### 1.28 - 2016-12-01

Expand Down
152 changes: 151 additions & 1 deletion Source/Core/PixelFormat.js
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,78 @@ define([
*/
LUMINANCE_ALPHA : WebGLConstants.LUMINANCE_ALPHA,

/**
* A pixel format containing red, green, and blue channels that is DXT1 compressed.
*
* @type {Number}
* @constant
*/
RGB_DXT1 : WebGLConstants.COMPRESSED_RGB_S3TC_DXT1_EXT,

/**
* A pixel format containing red, green, blue, and alpha channels that is DXT1 compressed.
*
* @type {Number}
* @constant
*/
RGBA_DXT1 : WebGLConstants.COMPRESSED_RGBA_S3TC_DXT1_EXT,

/**
* A pixel format containing red, green, blue, and alpha channels that is DXT3 compressed.
*
* @type {Number}
* @constant
*/
RGBA_DXT3 : WebGLConstants.COMPRESSED_RGBA_S3TC_DXT3_EXT,

/**
* A pixel format containing red, green, blue, and alpha channels that is DXT5 compressed.
*
* @type {Number}
* @constant
*/
RGBA_DXT5 : WebGLConstants.COMPRESSED_RGBA_S3TC_DXT5_EXT,

/**
* A pixel format containing red, green, and blue channels that is PVR 4bpp compressed.
*
* @type {Number}
* @constant
*/
RGB_PVRTC_4BPPV1 : WebGLConstants.COMPRESSED_RGB_PVRTC_4BPPV1_IMG,

/**
* A pixel format containing red, green, and blue channels that is PVR 2bpp compressed.
*
* @type {Number}
* @constant
*/
RGB_PVRTC_2BPPV1 : WebGLConstants.COMPRESSED_RGB_PVRTC_2BPPV1_IMG,

/**
* A pixel format containing red, green, blue, and alpha channels that is PVR 4bpp compressed.
*
* @type {Number}
* @constant
*/
RGBA_PVRTC_4BPPV1 : WebGLConstants.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG,

/**
* A pixel format containing red, green, blue, and alpha channels that is PVR 2bpp compressed.
*
* @type {Number}
* @constant
*/
RGBA_PVRTC_2BPPV1 : WebGLConstants.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG,

/**
* A pixel format containing red, green, and blue channels that is ETC1 compressed.
*
* @type {Number}
* @constant
*/
RGB_ETC1 : WebGLConstants.COMPRESSED_RGB_ETC1_WEBGL,

/**
* @private
*/
Expand All @@ -79,7 +151,16 @@ define([
pixelFormat === PixelFormat.RGB ||
pixelFormat === PixelFormat.RGBA ||
pixelFormat === PixelFormat.LUMINANCE ||
pixelFormat === PixelFormat.LUMINANCE_ALPHA;
pixelFormat === PixelFormat.LUMINANCE_ALPHA ||
pixelFormat === PixelFormat.RGB_DXT1 ||
pixelFormat === PixelFormat.RGBA_DXT1 ||
pixelFormat === PixelFormat.RGBA_DXT3 ||
pixelFormat === PixelFormat.RGBA_DXT5 ||
pixelFormat === PixelFormat.RGB_PVRTC_4BPPV1 ||
pixelFormat === PixelFormat.RGB_PVRTC_2BPPV1 ||
pixelFormat === PixelFormat.RGBA_PVRTC_4BPPV1 ||
pixelFormat === PixelFormat.RGBA_PVRTC_2BPPV1 ||
pixelFormat === PixelFormat.RGB_ETC1;
},

/**
Expand All @@ -99,6 +180,75 @@ define([
isDepthFormat : function(pixelFormat) {
return pixelFormat === PixelFormat.DEPTH_COMPONENT ||
pixelFormat === PixelFormat.DEPTH_STENCIL;
},

/**
* @private
*/
isCompressedFormat : function(pixelFormat) {
return pixelFormat === PixelFormat.RGB_DXT1 ||
pixelFormat === PixelFormat.RGBA_DXT1 ||
pixelFormat === PixelFormat.RGBA_DXT3 ||
pixelFormat === PixelFormat.RGBA_DXT5 ||
pixelFormat === PixelFormat.RGB_PVRTC_4BPPV1 ||
pixelFormat === PixelFormat.RGB_PVRTC_2BPPV1 ||
pixelFormat === PixelFormat.RGBA_PVRTC_4BPPV1 ||
pixelFormat === PixelFormat.RGBA_PVRTC_2BPPV1 ||
pixelFormat === PixelFormat.RGB_ETC1;
},

/**
* @private
*/
isDXTFormat : function(pixelFormat) {
return pixelFormat === PixelFormat.RGB_DXT1 ||
pixelFormat === PixelFormat.RGBA_DXT1 ||
pixelFormat === PixelFormat.RGBA_DXT3 ||
pixelFormat === PixelFormat.RGBA_DXT5;
},

/**
* @private
*/
isPVRTCFormat : function(pixelFormat) {
return pixelFormat === PixelFormat.RGB_PVRTC_4BPPV1 ||
pixelFormat === PixelFormat.RGB_PVRTC_2BPPV1 ||
pixelFormat === PixelFormat.RGBA_PVRTC_4BPPV1 ||
pixelFormat === PixelFormat.RGBA_PVRTC_2BPPV1;
},

/**
* @private
*/
isETC1Format : function(pixelFormat) {
return pixelFormat === PixelFormat.RGB_ETC1;
},

/**
* @private
*/
compressedTextureSize : function(pixelFormat, width, height) {
switch (pixelFormat) {
case PixelFormat.RGB_DXT1:
case PixelFormat.RGBA_DXT1:
case PixelFormat.RGB_ETC1:
return Math.floor((width + 3) / 4) * Math.floor((height + 3) / 4) * 8;

case PixelFormat.RGBA_DXT3:
case PixelFormat.RGBA_DXT5:
return Math.floor((width + 3) / 4) * Math.floor((height + 3) / 4) * 16;

case PixelFormat.RGB_PVRTC_4BPPV1:
case PixelFormat.RGBA_PVRTC_4BPPV1:
return Math.floor((Math.max(width, 8) * Math.max(height, 8) * 4 + 7) / 8);

case PixelFormat.RGB_PVRTC_2BPPV1:
case PixelFormat.RGBA_PVRTC_2BPPV1:
return Math.floor((Math.max(width, 16) * Math.max(height, 8) * 2 + 7) / 8);

default:
return 0;
}
}
};

Expand Down
15 changes: 15 additions & 0 deletions Source/Core/WebGLConstants.js
Original file line number Diff line number Diff line change
Expand Up @@ -315,6 +315,21 @@ define([
UNPACK_COLORSPACE_CONVERSION_WEBGL : 0x9243,
BROWSER_DEFAULT_WEBGL : 0x9244,

// WEBGL_compressed_texture_s3tc
COMPRESSED_RGB_S3TC_DXT1_EXT : 0x83F0,
COMPRESSED_RGBA_S3TC_DXT1_EXT : 0x83F1,
COMPRESSED_RGBA_S3TC_DXT3_EXT : 0x83F2,
COMPRESSED_RGBA_S3TC_DXT5_EXT : 0x83F3,

// WEBGL_compressed_texture_pvrtc
COMPRESSED_RGB_PVRTC_4BPPV1_IMG : 0x8C00,
COMPRESSED_RGB_PVRTC_2BPPV1_IMG : 0x8C01,
COMPRESSED_RGBA_PVRTC_4BPPV1_IMG : 0x8C02,
COMPRESSED_RGBA_PVRTC_2BPPV1_IMG : 0x8C03,

// WEBGL_compressed_texture_etc1
COMPRESSED_RGB_ETC1_WEBGL : 0x8D64,

// Desktop OpenGL
DOUBLE : 0x140A,

Expand Down
Loading