Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
Synopsis
- type DctCoefficients = DcCoefficient
- data JpgUnpackerParameter = JpgUnpackerParameter {
- dcHuffmanTree :: !HuffmanPackedTree
- acHuffmanTree :: !HuffmanPackedTree
- componentIndex :: !Int
- restartInterval :: !Int
- componentWidth :: !Int
- componentHeight :: !Int
- subSampling :: !(Int, Int)
- coefficientRange :: !(Int, Int)
- successiveApprox :: !(Int, Int)
- readerIndex :: !Int
- indiceVector :: !Int
- blockIndex :: !Int
- blockMcuX :: !Int
- blockMcuY :: !Int
- decodeInt :: Int -> BoolReader s Int32
- dcCoefficientDecode :: HuffmanPackedTree -> BoolReader s DcCoefficient
- deQuantize :: MacroBlock Int16 -> MutableMacroBlock s Int16 -> ST s (MutableMacroBlock s Int16)
- decodeRrrrSsss :: HuffmanPackedTree -> BoolReader s (Int, Int)
- zigZagReorderForward :: Storable a => MutableMacroBlock s a -> MutableMacroBlock s a -> ST s (MutableMacroBlock s a)
- zigZagReorderForwardv :: (Storable a, Num a) => Vector a -> Vector a
- zigZagReorder :: MutableMacroBlock s Int16 -> MutableMacroBlock s Int16 -> ST s (MutableMacroBlock s Int16)
- inverseDirectCosineTransform :: MutableMacroBlock s Int16 -> ST s (MutableMacroBlock s Int16)
- unpackInt :: Int -> BoolReader s Int32
- unpackMacroBlock :: Int -> Int -> Int -> Int -> Int -> Int -> MutableImage s PixelYCbCr8 -> MutableMacroBlock s Int16 -> ST s ()
- rasterMap :: Monad m => Int -> Int -> (Int -> Int -> m ()) -> m ()
- decodeMacroBlock :: MacroBlock DctCoefficients -> MutableMacroBlock s Int16 -> MutableMacroBlock s Int16 -> ST s (MutableMacroBlock s Int16)
- decodeRestartInterval :: BoolReader s Int32
- toBlockSize :: Int -> Int
Documentation
type DctCoefficients = DcCoefficient Source #
Same as for DcCoefficient, to provide nicer type signatures
data JpgUnpackerParameter Source #
JpgUnpackerParameter | |
|
Instances
Show JpgUnpackerParameter Source # | |
Defined in Codec.Picture.Jpg.Internal.Common showsPrec :: Int -> JpgUnpackerParameter -> ShowS # show :: JpgUnpackerParameter -> String # showList :: [JpgUnpackerParameter] -> ShowS # |
dcCoefficientDecode :: HuffmanPackedTree -> BoolReader s DcCoefficient Source #
deQuantize :: MacroBlock Int16 -> MutableMacroBlock s Int16 -> ST s (MutableMacroBlock s Int16) Source #
Apply a quantization matrix to a macroblock
decodeRrrrSsss :: HuffmanPackedTree -> BoolReader s (Int, Int) Source #
zigZagReorderForward :: Storable a => MutableMacroBlock s a -> MutableMacroBlock s a -> ST s (MutableMacroBlock s a) Source #
zigZagReorder :: MutableMacroBlock s Int16 -> MutableMacroBlock s Int16 -> ST s (MutableMacroBlock s Int16) Source #
inverseDirectCosineTransform :: MutableMacroBlock s Int16 -> ST s (MutableMacroBlock s Int16) Source #
unpackInt :: Int -> BoolReader s Int32 Source #
Unpack an int of the given size encoded from MSB to LSB.
:: Int | Component count |
-> Int | Width coefficient |
-> Int | Height coefficient |
-> Int | Component index |
-> Int | x |
-> Int | y |
-> MutableImage s PixelYCbCr8 | |
-> MutableMacroBlock s Int16 | |
-> ST s () |
Given a size coefficient (how much a pixel span horizontally and vertically), the position of the macroblock, return a list of indices and value to be stored in an array (like the final image)
decodeMacroBlock :: MacroBlock DctCoefficients -> MutableMacroBlock s Int16 -> MutableMacroBlock s Int16 -> ST s (MutableMacroBlock s Int16) Source #
This is one of the most important function of the decoding, it form the barebone decoding pipeline for macroblock. It's all there is to know for macro block transformation
decodeRestartInterval :: BoolReader s Int32 Source #
toBlockSize :: Int -> Int Source #