Skip to contents

IFFChunk()s represent the structure of the Interchange File Format well, but the iformation is stored as raw data. This method tries to interpret and translate the information into a more comprehensive format.

Usage

# S4 method for class 'IFFChunk'
interpretIFFChunk(x, ...)

Arguments

x

An IFFChunk() object which needs to be interpreted.

...

Currently ignored.

Value

If x is interpretable by this package an S3 class object of IFF.ANY is returned. The content of the returned object will depend on the type of IFFChunk() provided for x. The result can for instance be a raster image (grDevices::as.raster()), a list of audio tuneR::Wave()s, a character string or a named list.

Details

Interchange File Format chunks can hold any kind of information (images, audio, (formatted) text, etc.). This method will try to convert this information into something useful. Information may get lost in the translation, so be careful when converting back to an IFFChunk-class() object using IFFChunk-method().

An error is thrown when the IFFChunk() object is currently not interpretable by this package. See IFFChunk-method() for an overview of currently supported IFF chunks. This list may increase while this package matures.

Author

Pepijn de Vries

Examples

## load an IFF file
example.iff <- read.iff(system.file("ilbm8lores.iff", package = "AmigaFFH"))

## in this case, the file is a FORM container with a bitmap image, and a
## list with a raster object is returned when interpreted:
example.itpt <- interpretIFFChunk(example.iff)
class(example.itpt)
#> [1] "IFF.FORM" "IFF.ANY" 
typeof(example.itpt)
#> [1] "list"
class(example.itpt[[1]])
#> [1] "IFF.ILBM" "IFF.ANY"  "raster"  

## Let's extraxt the bitmap header from the main chunk:
bmhd <- getIFFChunk(example.iff, c("ILBM", "BMHD"))

## When interpreted, a named list is returned with (meta-)information
## on the bitmap image:
bmhd.itpt <- interpretIFFChunk(bmhd)
class(bmhd.itpt)
#> [1] "IFF.BMHD" "IFF.ANY" 
typeof(bmhd.itpt)
#> [1] "list"
print(bmhd.itpt)
#> $w
#> [1] 320
#> 
#> $h
#> [1] 200
#> 
#> $x
#> [1] 0
#> 
#> $y
#> [1] 0
#> 
#> $nPlanes
#> [1] 3
#> 
#> $Masking
#> [1] "mskHasTransparentColour"
#> 
#> $Compression
#> [1] "cmpByteRun1"
#> 
#> $pad
#> [1] 00
#> 
#> $transparentColour
#> [1] 0
#> 
#> $xAspect
#> [1] 44
#> 
#> $yAspect
#> [1] 44
#> 
#> $pageWidth
#> [1] 320
#> 
#> $pageHeight
#> [1] 200
#> 
#> attr(,"class")
#> [1] "IFF.BMHD" "IFF.ANY"