Package Exports
- parse-dds
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (parse-dds) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
parse-dds
Parses DDS texture headers in Node and the browser.
This was adapted from @toji's wonderful webgl-texture-utils.
Currently this only supports a limited range of common DDS formats:
- DXT1 (RGB)
- DXT3 (RGBA)
- DXT5 (RGBA)
- Cubemaps (RGBA32f) - like those from cmft and Modified AMD Cubemapgen
See test/index.js for an example in Node, or demo/index.js for a WebGL compressed texture example.
Pull requests welcome.
Example
var parse = require('parse-dds')
var buffer = new Uint8Array(... DDS file ...)
var dds = parse(buffer)
console.log(dds.format) // 'dxt1'
console.log(dds.shape) // [ width, height ]
console.log(dds.images) // [ ... mipmap level data ... ]
// get the compressed texture data for gl.compressedTexImage2D
var image = dds.images[0]
var texture = new Uint8Array(buffer, image.offset, image.length)Install
npm install parse-dds --save-devUsage
dds = parse(arrayBuffer)
Parses an ArrayBuffer and returns the DDS headers for that file.
The returned values:
shapean array representing the[ width, height ]of the textureflagsthe DDS bit flags stored in the fileformata string, either'dxt1','dxt3','dxt5'or'rgba32f'imagesa list of information to extract sub-arrays for each mipmap levelcubemapa boolean indicating whether the file contains a cubemap image
Each image has the form:
{
shape: [ width, height ], // size of this mipmap level
offset: x, // byte offset into the input buffer
length: len, // length of this mipmap level image data
}See Also
- preview-dds for loading and previewing DDS files
License
MIT, see LICENSE.md for details.
