kis_colorspace_factory_registry.cc 6.24 KB
Newer Older
1
/*
2
 *  Copyright (c) 2003 Patrick Julien  <freak@codepimps.org>
3
 *  Copyright (c) 2004 Cyrille Berger <cberger@cberger.net>
4 5 6 7 8 9 10 11 12 13 14 15 16
 *
 *  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
17
 *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18
 */
19

20
#include "kdebug.h"
21 22 23 24
#include <kparts/plugin.h>
#include <kservice.h>
#include <ktrader.h>
#include <kparts/componentfactory.h>
25 26
#include <kmessagebox.h>
#include <klocale.h>
Boudewijn Rempt's avatar
Boudewijn Rempt committed
27
#include "kis_debug_areas.h"
28
#include "kis_colorspace.h"
29 30
#include "kis_profile.h"
#include "kis_colorspace_factory_registry.h"
31
#include "kis_alpha_colorspace.h"
Casper Boemann's avatar
Casper Boemann committed
32
#include "kis_lab_colorspace.h"
33 34


35
KisColorSpaceFactoryRegistry::KisColorSpaceFactoryRegistry(QStringList profileFilenames)
36
{
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
    // Create the built-in colorspaces

    m_alphaCs = new KisAlphaColorSpace(this, 0);

    // Load the profiles
    if (!profileFilenames.empty()) {
        KisProfile * profile = 0;
        for ( QStringList::Iterator it = profileFilenames.begin(); it != profileFilenames.end(); ++it ) {
            profile = new KisProfile(*it);
            Q_CHECK_PTR(profile);

            profile -> load();
            if (profile -> valid()) {
                m_profileMap[profile->productName()] = profile;
            }
        }
    }

Casper Boemann's avatar
Casper Boemann committed
55 56
    KisProfile *labProfile = new KisProfile(cmsCreateLabProfile(NULL));
    addProfile(labProfile);
Casper Boemann's avatar
Casper Boemann committed
57 58 59 60
    add(new KisLabColorSpaceFactory());
/* XXX where to put this
    KisHistogramProducerFactoryRegistry::instance() -> add(
                new KisBasicHistogramProducerFactory<KisBasicU16HistogramProducer>
61
                (KisID("LABAHISTO", i18n("L*a*b* Histogram")), new KisLabColorSpace(this, 0);) );
Casper Boemann's avatar
Casper Boemann committed
62
*/
Casper Boemann's avatar
Casper Boemann committed
63

64 65 66 67 68
    // Load all colorspace modules
    KTrader::OfferList offers = KTrader::self() -> query(QString::fromLatin1("Krita/ColorSpace"),
                                                         QString::fromLatin1("(Type == 'Service') and "
                                                                             "([X-KDE-Version] == 2)"));

69 70 71 72
    if (offers.empty()) {
        KMessageBox::sorry(0, i18n("Cannot start Krita: no colorspaces available."));
        abort();
    }
73

74
    KTrader::OfferList::ConstIterator iter;
75 76 77 78 79 80 81 82 83
    for(iter = offers.begin(); iter != offers.end(); ++iter)
    {
        KService::Ptr service = *iter;
        int errCode = 0;
        KParts::Plugin* plugin =
             KParts::ComponentFactory::createInstanceFromService<KParts::Plugin> ( service, this, 0, QStringList(), &errCode);
        if ( plugin )
            kdDebug(DBG_AREA_PLUGINS) << "found colorspace " << service -> property("Name").toString() << "\n";
    }
84 85
}

86
KisColorSpaceFactoryRegistry::KisColorSpaceFactoryRegistry()
87 88 89
{
}

90
KisColorSpaceFactoryRegistry::~KisColorSpaceFactoryRegistry()
91
{
92 93
}

94
KisProfile *  KisColorSpaceFactoryRegistry::getProfileByName(const QString & name)
95 96 97 98 99 100 101 102
{
    if (m_profileMap.find(name) == m_profileMap.end()) {
        return 0;
    }

    return m_profileMap[name];
}

103 104 105 106 107 108
QValueVector<KisProfile *>  KisColorSpaceFactoryRegistry::profilesFor(KisID id)
{
    return profilesFor(get(id));
}

QValueVector<KisProfile *>  KisColorSpaceFactoryRegistry::profilesFor(KisColorSpaceFactory * csf)
109
{
110

111
    QValueVector<KisProfile *>  profiles;
112

113
    QMap<QString, KisProfile * >::Iterator it;
114
    for (it = m_profileMap.begin(); it != m_profileMap.end(); ++it) {
115
        KisProfile *  profile = it.data();
116
        if (profile->colorSpaceSignature() == csf->colorSpaceSignature()) {
117 118
            profiles.push_back(profile);
        }
119
    }
120 121 122
    return profiles;
}

Casper Boemann's avatar
Casper Boemann committed
123 124 125 126 127 128 129
void KisColorSpaceFactoryRegistry::addProfile(KisProfile *p)
{
      if (p -> valid()) {
          m_profileMap[p->productName()] = p;
      }
}

130 131 132 133 134 135 136 137 138 139
void KisColorSpaceFactoryRegistry::addPaintDeviceAction(KisColorSpace* cs,
        KisPaintDeviceAction* action) {
    m_paintDevActionMap[cs -> id()].append(action);
}

QValueVector<KisPaintDeviceAction *>
KisColorSpaceFactoryRegistry::paintDeviceActionsFor(KisColorSpace* cs) {
    return m_paintDevActionMap[cs -> id()];
}

140
KisColorSpace * KisColorSpaceFactoryRegistry::getColorSpace(const KisID & csID, const QString & pName)
141
{
142 143 144 145 146 147 148 149
    QString profileName = pName;

    if(profileName == "")
    {
        KisColorSpaceFactory *csf = get(csID);

        if(!csf)
            return 0;
150

151
        profileName = csf->defaultProfile();
152
    }
153

154
    QString name = csID.id() + "<comb>" + profileName;
155

156 157 158 159
    if (m_csMap.find(name) == m_csMap.end()) {
        KisColorSpaceFactory *csf = get(csID);
        if(!csf)
            return 0;
160

161
        KisProfile *p = getProfileByName(profileName);
162

163
        KisColorSpace *cs = csf -> createColorSpace(this, p);
164 165 166 167
        if(!cs)
            return 0;

        m_csMap[name] = cs;
168 169
    }

170 171 172 173
    if(m_csMap.contains(name))
        return m_csMap[name];
    else
        return 0;
174 175
}

176 177 178

KisColorSpace * KisColorSpaceFactoryRegistry::getColorSpace(const KisID & csID, const KisProfile * profile)
{
179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198
    if( profile )
    {
        KisColorSpace *cs = getColorSpace( csID, profile->productName());

        if(!cs)
        {
            // The profile was not stored and thus not the combination either
            KisColorSpaceFactory *csf = get(csID);
            if(!csf)
                return 0;

            KisColorSpace *cs = csf -> createColorSpace(this, const_cast<KisProfile *>(profile));
            if(!cs )
                return 0;

            QString name = csID.id() + "<comb>" + profile->productName();
            m_csMap[name] = cs;
        }

        return cs;
199 200 201
    } else {
        return getColorSpace( csID, "");
    }
202
}
203

204 205
KisColorSpace * KisColorSpaceFactoryRegistry::getAlpha8()
{
206
   return m_alphaCs;
207
}
208 209 210 211 212 213 214

KisColorSpace * KisColorSpaceFactoryRegistry::getRGB8()
{
    return getColorSpace(KisID("RGBA", ""), "");
}

#include "kis_colorspace_factory_registry.moc"