ETC1
  public
  
  
  
  class
  ETC1
  
    extends Object
  
  
  
  
  
  
| java.lang.Object | |
| ↳ | android.opengl.ETC1 | 
Methods for encoding and decoding ETC1 textures.
The standard for the ETC1 texture format can be found at http://www.khronos.org/registry/gles/extensions/OES/OES_compressed_ETC1_RGB8_texture.txt
The PKM file format is of a 16-byte header that describes the image bounds followed by the encoded ETC1 texture data.
See also:
Summary
| Constants | |
|---|---|
| int | DECODED_BLOCK_SIZESize in bytes of a decoded block. | 
| int | ENCODED_BLOCK_SIZESize in bytes of an encoded block. | 
| int | ETC1_RGB8_OESAccepted by the internalformat parameter of glCompressedTexImage2D. | 
| int | ETC_PKM_HEADER_SIZESize of a PKM file header, in bytes. | 
| Public constructors | |
|---|---|
| 
      ETC1()
       | |
| Public methods | |
|---|---|
| 
        
        
        static
        
        
        void | 
      decodeBlock(Buffer in, Buffer out)
      Decode a block of pixels. | 
| 
        
        
        static
        
        
        void | 
      decodeImage(Buffer in, Buffer out, int width, int height, int pixelSize, int stride)
      Decode an entire image. | 
| 
        
        
        static
        
        
        void | 
      encodeBlock(Buffer in, int validPixelMask, Buffer out)
      Encode a block of pixels. | 
| 
        
        
        static
        
        
        void | 
      encodeImage(Buffer in, int width, int height, int pixelSize, int stride, Buffer out)
      Encode an entire image. | 
| 
        
        
        static
        
        
        void | 
      formatHeader(Buffer header, int width, int height)
      Format a PKM header | 
| 
        
        
        static
        
        
        int | 
      getEncodedDataSize(int width, int height)
      Return the size of the encoded image data (does not include size of PKM header). | 
| 
        
        
        static
        
        
        int | 
      getHeight(Buffer header)
      Read the image height from a PKM header | 
| 
        
        
        static
        
        
        int | 
      getWidth(Buffer header)
      Read the image width from a PKM header | 
| 
        
        
        static
        
        
        boolean | 
      isValid(Buffer header)
      Check if a PKM header is correctly formatted. | 
| Inherited methods | |
|---|---|
Constants
DECODED_BLOCK_SIZE
public static final int DECODED_BLOCK_SIZE
Size in bytes of a decoded block.
Constant Value: 48 (0x00000030)
ENCODED_BLOCK_SIZE
public static final int ENCODED_BLOCK_SIZE
Size in bytes of an encoded block.
Constant Value: 8 (0x00000008)
ETC1_RGB8_OES
public static final int ETC1_RGB8_OES
Accepted by the internalformat parameter of glCompressedTexImage2D.
Constant Value: 36196 (0x00008d64)
ETC_PKM_HEADER_SIZE
public static final int ETC_PKM_HEADER_SIZE
Size of a PKM file header, in bytes.
Constant Value: 16 (0x00000010)
Public constructors
ETC1
public ETC1 ()
Public methods
decodeBlock
public static void decodeBlock (Buffer in, Buffer out)
Decode a block of pixels.
| Parameters | |
|---|---|
| in | Buffer: a native order direct buffer of size ENCODED_BLOCK_SIZE that contains the
 ETC1 compressed version of the data. | 
| out | Buffer: a native order direct buffer of size DECODED_BLOCK_SIZE that will receive
 the decoded data. The data represents a
 4 x 4 square of 3-byte pixels in form R, G, B. Byte (3 * (x + 4 * y) is the R
 value of pixel (x, y). | 
decodeImage
public static void decodeImage (Buffer in, Buffer out, int width, int height, int pixelSize, int stride)
Decode an entire image.
| Parameters | |
|---|---|
| in | Buffer: native order direct buffer of the encoded data. | 
| out | Buffer: native order direct buffer of the image data. Will be written such that
 pixel (x,y) is at pIn + pixelSize * x + stride * y. Must be
 large enough to store entire image. | 
| width | int | 
| height | int | 
| pixelSize | int: must be 2 or 3. 2 is an GL_UNSIGNED_SHORT_5_6_5 image,
 3 is a GL_BYTE RGB image. | 
| stride | int | 
encodeBlock
public static void encodeBlock (Buffer in, int validPixelMask, Buffer out)
Encode a block of pixels.
| Parameters | |
|---|---|
| in | Buffer: a native order direct buffer of size DECODED_BLOCK_SIZE that represent a
 4 x 4 square of 3-byte pixels in form R, G, B. Byte (3 * (x + 4 * y) is the R
 value of pixel (x, y). | 
| validPixelMask | int: is a 16-bit mask where bit (1 << (x + y * 4)) indicates whether
 the corresponding (x,y) pixel is valid. Invalid pixel color values are ignored when compressing. | 
| out | Buffer: a native order direct buffer of size ENCODED_BLOCK_SIZE that receives the
 ETC1 compressed version of the data. | 
encodeImage
public static void encodeImage (Buffer in, int width, int height, int pixelSize, int stride, Buffer out)
Encode an entire image.
| Parameters | |
|---|---|
| in | Buffer: a native order direct buffer of the image data. Formatted such that
           pixel (x,y) is at pIn + pixelSize * x + stride * y; | 
| width | int | 
| height | int | 
| pixelSize | int: must be 2 or 3. 2 is an GL_UNSIGNED_SHORT_5_6_5 image,
 3 is a GL_BYTE RGB image. | 
| stride | int | 
| out | Buffer: a native order direct buffer of the encoded data.
 Must be large enough to store entire encoded image. | 
formatHeader
public static void formatHeader (Buffer header, int width, int height)
Format a PKM header
| Parameters | |
|---|---|
| header | Buffer: native order direct buffer of the header. | 
| width | int: the width of the image in pixels. | 
| height | int: the height of the image in pixels. | 
getEncodedDataSize
public static int getEncodedDataSize (int width, 
                int height)Return the size of the encoded image data (does not include size of PKM header).
| Parameters | |
|---|---|
| width | int | 
| height | int | 
| Returns | |
|---|---|
| int | |
getHeight
public static int getHeight (Buffer header)
Read the image height from a PKM header
| Parameters | |
|---|---|
| header | Buffer: native order direct buffer of the header. | 
| Returns | |
|---|---|
| int | |
getWidth
public static int getWidth (Buffer header)
Read the image width from a PKM header
| Parameters | |
|---|---|
| header | Buffer: native order direct buffer of the header. | 
| Returns | |
|---|---|
| int | |
isValid
public static boolean isValid (Buffer header)
Check if a PKM header is correctly formatted.
| Parameters | |
|---|---|
| header | Buffer: native order direct buffer of the header. | 
| Returns | |
|---|---|
| boolean | |
