summaryrefslogtreecommitdiffstats
path: root/filters/chalk/tiff/kis_tiff_reader.cc
blob: f2eabd8785e212ce717c5db54b4981ed2c99828c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/*
 *  Copyright (c) 2005-2006 Cyrille Berger <cberger@cberger.net>
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin Street, Fifth Floor,
 * Boston, MA 02110-1301, USA.
 */
 
#include "kis_tiff_reader.h"

#include <kdebug.h>

#include <kis_iterators_pixel.h>
#include <kis_paint_device.h>

#include "kis_tiff_stream.h"

    uint KisTIFFReaderTarget8bit::copyDataToChannels( TQ_UINT32 x, TQ_UINT32 y, TQ_UINT32 dataWidth, TIFFStreamBase* tiffstream)
    {
        KisHLineIterator it = paintDevice() -> createHLineIterator(x, y, dataWidth, true);
        double coeff = TQ_UINT8_MAX / (double)( pow(2, sourceDepth() ) - 1 );
//         kdDebug(41008) << " depth expension coefficient : " << coeff << endl;
        while (!it.isDone()) {
            TQ_UINT8 *d = it.rawData();
            TQ_UINT8 i;
            for(i = 0; i < nbColorsSamples() ; i++)
            {
                d[poses()[i]] = (TQ_UINT8)( tiffstream->nextValue() * coeff );
            }
            postProcessor()->postProcess8bit( d);
            if(transform()) cmsDoTransform(transform(), d, d, 1);
            d[poses()[i]] = TQ_UINT8_MAX;
            for(int k = 0; k < nbExtraSamples(); k++)
            {
                if(k == alphaPos())
                    d[poses()[i]] = (TQ_UINT32) ( tiffstream->nextValue() * coeff );
                else
                    tiffstream->nextValue();
            }
            ++it;
        }
        return 1;
    }
    uint KisTIFFReaderTarget16bit::copyDataToChannels( TQ_UINT32 x, TQ_UINT32 y, TQ_UINT32 dataWidth, TIFFStreamBase* tiffstream)
    {
        KisHLineIterator it = paintDevice() -> createHLineIterator(x, y, dataWidth, true);
        double coeff = TQ_UINT16_MAX / (double)( pow(2, sourceDepth() ) - 1 );
//         kdDebug(41008) << " depth expension coefficient : " << coeff << endl;
        while (!it.isDone()) {
            TQ_UINT16 *d = reinterpret_cast<TQ_UINT16 *>(it.rawData());
            TQ_UINT8 i;
            for(i = 0; i < nbColorsSamples(); i++)
            {
                d[poses()[i]] = (TQ_UINT16)( tiffstream->nextValue() * coeff );
            }
            postProcessor()->postProcess16bit( d);
            if(transform()) cmsDoTransform(transform(), d, d, 1);
            d[poses()[i]] = TQ_UINT16_MAX;
            for(int k = 0; k < nbExtraSamples(); k++)
            {
                if(k == alphaPos())
                    d[poses()[i]] = (TQ_UINT16) ( tiffstream->nextValue() * coeff );
                else
                    tiffstream->nextValue();
            }
            ++it;
        }
        return 1;
    }
    
    uint KisTIFFReaderTarget32bit::copyDataToChannels( TQ_UINT32 x, TQ_UINT32 y, TQ_UINT32 dataWidth, TIFFStreamBase* tiffstream)
    {
        KisHLineIterator it = paintDevice() -> createHLineIterator(x, y, dataWidth, true);
        double coeff = TQ_UINT32_MAX / (double)( pow(2, sourceDepth() ) - 1 );
//         kdDebug(41008) << " depth expension coefficient : " << coeff << endl;
        while (!it.isDone()) {
            TQ_UINT32 *d = reinterpret_cast<TQ_UINT32 *>(it.rawData());
            TQ_UINT8 i;
            for(i = 0; i < nbColorsSamples(); i++)
            {
                d[poses()[i]] = (TQ_UINT32)( tiffstream->nextValue() * coeff );
            }
            postProcessor()->postProcess32bit( d);
            if(transform()) cmsDoTransform(transform(), d, d, 1);
            d[poses()[i]] = TQ_UINT32_MAX;
            for(int k = 0; k < nbExtraSamples(); k++)
            {
                if(k == alphaPos())
                    d[poses()[i]] = (TQ_UINT32) ( tiffstream->nextValue() * coeff );
                else
                    tiffstream->nextValue();
            }
            ++it;
        }
        return 1;
    }
    uint KisTIFFReaderFromPalette::copyDataToChannels(TQ_UINT32 x, TQ_UINT32 y, TQ_UINT32 dataWidth,  TIFFStreamBase* tiffstream)
    {
        KisHLineIterator it = paintDevice() -> createHLineIterator(x, y, dataWidth, true);
        while (!it.isDone()) {
            TQ_UINT16* d = reinterpret_cast<TQ_UINT16 *>(it.rawData());
            uint32 index = tiffstream->nextValue();
            d[2] = m_red[index];
            d[1] = m_green[index];
            d[0] = m_blue[index];
            d[3] = TQ_UINT16_MAX;
            ++it;
        }
        return 1;
    }