kis_colorspace_factory_registry.cc 5.52 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_xyz_colorspace.h"
32
#include "kis_alpha_colorspace.h"
Casper Boemann's avatar
Casper Boemann committed
33
#include "kis_lab_colorspace.h"
34 35


36
KisColorSpaceFactoryRegistry::KisColorSpaceFactoryRegistry(QStringList profileFilenames)
37
{
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
    // 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
56 57 58
    KisProfile *labProfile = new KisProfile(cmsCreateLabProfile(NULL));
    addProfile(labProfile);

59 60 61 62 63
    // Load all colorspace modules
    KTrader::OfferList offers = KTrader::self() -> query(QString::fromLatin1("Krita/ColorSpace"),
                                                         QString::fromLatin1("(Type == 'Service') and "
                                                                             "([X-KDE-Version] == 2)"));

64 65 66 67
    if (offers.empty()) {
        KMessageBox::sorry(0, i18n("Cannot start Krita: no colorspaces available."));
        abort();
    }
68

69
    KTrader::OfferList::ConstIterator iter;
70 71 72 73 74 75 76 77 78
    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";
    }
Casper Boemann's avatar
Casper Boemann committed
79
    add(new KisLabColorSpaceFactory());
80 81
}

82
KisColorSpaceFactoryRegistry::KisColorSpaceFactoryRegistry()
83 84 85
{
}

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

90
KisProfile *  KisColorSpaceFactoryRegistry::getProfileByName(const QString & name)
91 92 93 94 95 96 97 98
{
    if (m_profileMap.find(name) == m_profileMap.end()) {
        return 0;
    }

    return m_profileMap[name];
}

99 100 101 102 103 104
QValueVector<KisProfile *>  KisColorSpaceFactoryRegistry::profilesFor(KisID id)
{
    return profilesFor(get(id));
}

QValueVector<KisProfile *>  KisColorSpaceFactoryRegistry::profilesFor(KisColorSpaceFactory * csf)
105
{
106

107
    QValueVector<KisProfile *>  profiles;
108

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

Casper Boemann's avatar
Casper Boemann committed
119 120 121 122 123 124 125
void KisColorSpaceFactoryRegistry::addProfile(KisProfile *p)
{
      if (p -> valid()) {
          m_profileMap[p->productName()] = p;
      }
}

126 127 128 129 130 131 132 133 134 135
void KisColorSpaceFactoryRegistry::addPaintDeviceAction(KisColorSpace* cs,
        KisPaintDeviceAction* action) {
    m_paintDevActionMap[cs -> id()].append(action);
}

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

136
KisColorSpace * KisColorSpaceFactoryRegistry::getColorSpace(const KisID & csID, const QString & pName)
137
{
138 139 140 141 142 143 144 145
    QString profileName = pName;

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

        if(!csf)
            return 0;
146

147
        profileName = csf->defaultProfile();
148
    }
149

150
    QString name = csID.id() + "<comb>" + profileName;
151

152 153 154 155
    if (m_csMap.find(name) == m_csMap.end()) {
        KisColorSpaceFactory *csf = get(csID);
        if(!csf)
            return 0;
156

157
        KisProfile *p = getProfileByName(profileName);
158

159
        KisColorSpace *cs = csf -> createColorSpace(this, p);
160 161 162 163
        if(!cs)
            return 0;

        m_csMap[name] = cs;
164 165
    }

166 167 168 169
    if(m_csMap.contains(name))
        return m_csMap[name];
    else
        return 0;
170 171
}

172 173 174

KisColorSpace * KisColorSpaceFactoryRegistry::getColorSpace(const KisID & csID, const KisProfile * profile)
{
175 176 177 178 179
    if( profile ) {
        return getColorSpace( csID, profile->productName());
    } else {
        return getColorSpace( csID, "");
    }
180
}
181

182 183
KisColorSpace * KisColorSpaceFactoryRegistry::getAlpha8()
{
184
   return m_alphaCs;
185
}
186 187 188 189 190 191 192

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

#include "kis_colorspace_factory_registry.moc"