summaryrefslogtreecommitdiffstats
path: root/chalk/core/kis_palette.h
blob: 2e842b52c06fecf09a04bbe445bdb48414314efc (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
/*
 *  Copyright (c) 2005 Boudewijn Rempt <boud@valdyas.org>
 *
 *  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.
 */
#ifndef KIS_PALETTE_
#define KIS_PALETTE_

#include <tqimage.h>
#include <tqcolor.h>
#include <tqvaluevector.h>

#include <tdeio/job.h>
#include <kpalette.h>

#include "kis_types.h"
#include "kis_resource.h"
#include "kis_global.h"
#include "kis_gradient.h"
#include "kis_alpha_mask.h"

class TQPoint;
class TQPixmap;
class KisPaintDevice;

struct KisPaletteEntry {
    TQColor color;
    TQString name;
    bool operator==(const KisPaletteEntry& rhs) const {
        return color == rhs.color && name == rhs.name;
    }
};

/**
 * Open Gimp, Photoshop or RIFF palette files. This is a straight port
 * from the Gimp.
 */
class KisPalette : public KisResource {
    typedef KisResource super;

    Q_OBJECT
  

public:
    /**
     * Create a palette from the colours in an image
     */
    KisPalette(const TQImage * img, TQ_INT32 nColors, const TQString & name);

    /**
     * Create a palette from the colours in a paint device
     */
    KisPalette(const KisPaintDeviceSP device, TQ_INT32 nColors, const TQString & name);

    /**
     * Create a palette from the colours in a gradient
     */
    KisPalette(const KisGradient * gradient, TQ_INT32 nColors, const TQString & name);

    /**
     * Load a palette from a file. This can be a Gimp
     * palette, a RIFF palette or a Photoshop palette.
     */
    KisPalette(const TQString& filename);

    /// Create an empty palette
    KisPalette();

    /// Explicit copy constructor (KisResource copy constructor is private)
    KisPalette(const KisPalette& rhs);

    virtual ~KisPalette();

    virtual bool load();
    virtual bool save();
    virtual TQImage img();


public:

    void add(const KisPaletteEntry &);
    void remove(const KisPaletteEntry &);
    KisPaletteEntry getColor(TQ_UINT32 index);
    TQ_INT32 nColors();

private:
    bool init();

private:

    TQByteArray m_data;
    bool m_ownData;
    TQImage m_img;
    TQString m_name;
    TQString m_comment;
    TQ_INT32 m_columns;
    TQValueVector<KisPaletteEntry> m_colors;

};
#endif // KIS_PALETTE_