~smartboyhw/ubuntu/raring/calligra/2.6.0-0ubuntu1

« back to all changes in this revision

Viewing changes to krita/plugins/colorspaces/ctlcs/KoCtlAccumulator.h

  • Committer: Package Import Robot
  • Author(s): Philip Muškovac
  • Date: 2012-10-23 21:09:16 UTC
  • mfrom: (1.1.13)
  • Revision ID: package-import@ubuntu.com-20121023210916-m82w6zxnxhaxz7va
Tags: 1:2.5.90-0ubuntu1
* New upstream alpha release (LP: #1070436)
  - Add libkactivities-dev and libopenimageio-dev to build-depends
  - Add kubuntu_build_calligraactive.diff to build calligraactive by default
  - Add package for calligraauthor and move files that are shared between
    calligrawords and calligraauthor to calligrawords-common
* Document the patches
* Remove numbers from patches so they follow the same naming scheme as
  the rest of our patches.
* calligra-data breaks replaces krita-data (<< 1:2.5.3) (LP: #1071686)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
 *  Copyright (c) 2009 Cyrille Berger <cberger@cberger.net>
3
 
 *
4
 
 * This library is free software; you can redistribute it and/or
5
 
 * modify it under the terms of the GNU Lesser General Public
6
 
 * License as published by the Free Software Foundation; either
7
 
 * version 2 of the License, or (at your option) any later version.
8
 
 *
9
 
 * This library is distributed in the hope that it will be useful,
10
 
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12
 
 * Lesser General Public License for more details.
13
 
 *
14
 
 * You should have received a copy of the GNU Lesser General Public License
15
 
 * along with this library; see the file COPYING.LIB.  If not, write to
16
 
 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
17
 
 * Boston, MA 02110-1301, USA.
18
 
 */
19
 
 
20
 
#ifndef _KO_CTL_ACCUMULATOR_H_
21
 
#define _KO_CTL_ACCUMULATOR_H_
22
 
 
23
 
#include "KoColorSpaceMaths.h"
24
 
 
25
 
class KoCtlAccumulator
26
 
{
27
 
public:
28
 
    virtual ~KoCtlAccumulator();
29
 
    virtual void mix(const quint8* _pixel, double _weight) = 0;
30
 
    virtual void reset() = 0;
31
 
    virtual void affect(quint8* _pixel, double _alpha) = 0;
32
 
    virtual void affect(quint8* _pixel, qint32 factor, qint32 offset) = 0;
33
 
};
34
 
 
35
 
template<typename _type_>
36
 
class KoCtlAccumulatorImpl : public KoCtlAccumulator
37
 
{
38
 
public:
39
 
    KoCtlAccumulatorImpl(int _pos) : m_pos(_pos) {}
40
 
    virtual ~KoCtlAccumulatorImpl() {}
41
 
    inline const _type_* ptr(const quint8* _pixel) {
42
 
        return reinterpret_cast<const _type_*>(_pixel + m_pos);
43
 
    }
44
 
    inline _type_* ptr(quint8* _pixel) {
45
 
        return reinterpret_cast<_type_*>(_pixel + m_pos);
46
 
    }
47
 
    virtual void mix(const quint8* _pixel, double _weight) {
48
 
        m_value += *ptr(_pixel) * _weight;
49
 
    }
50
 
    virtual void reset() {
51
 
        m_value = 0;
52
 
    }
53
 
    virtual void affect(quint8* _pixel, double _alpha) {
54
 
        typename KoColorSpaceMathsTraits< _type_ >::compositetype v = m_value * _alpha;
55
 
 
56
 
        if (v > KoColorSpaceMathsTraits<_type_>::max) {
57
 
            v = KoColorSpaceMathsTraits<_type_>::max;
58
 
        }
59
 
        if (v < KoColorSpaceMathsTraits<_type_>::min) {
60
 
            v = KoColorSpaceMathsTraits<_type_>::min;
61
 
        }
62
 
        *ptr(_pixel) = v;
63
 
    }
64
 
    virtual void affect(quint8* _pixel, qint32 factor, qint32 offset) {
65
 
        typename KoColorSpaceMathsTraits< _type_ >::compositetype v = m_value / factor + offset;
66
 
 
67
 
        if (v > KoColorSpaceMathsTraits<_type_>::max) {
68
 
            v = KoColorSpaceMathsTraits<_type_>::max;
69
 
        }
70
 
        if (v < KoColorSpaceMathsTraits<_type_>::min) {
71
 
            v = KoColorSpaceMathsTraits<_type_>::min;
72
 
        }
73
 
        *ptr(_pixel) = v;
74
 
    }
75
 
private:
76
 
    int m_pos;
77
 
    typename KoColorSpaceMathsTraits< _type_ >::compositetype m_value;
78
 
};
79
 
 
80
 
#endif