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.
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.
See also
Other iff.operations:
IFFChunk-class
,
WaveToIFF()
,
as.raster.AmigaBasicShape()
,
getIFFChunk()
,
rasterToIFF()
,
rawToIFFChunk()
,
read.iff()
,
write.iff()
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"