Logo Search packages:      
Sourcecode: kalzium version File versions  Download package

kalziumdataobject.cpp

/***************************************************************************
 *   Copyright (C) 2005, 2006, 2007 by Carsten Niehaus                     *
 *   cniehaus@kde.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.          *
 ***************************************************************************/

#include "kalziumdataobject.h"

#include <elementparser.h>
#include <isotope.h>
#include <isotopeparser.h>
#include <spectrumparser.h>

#include <QFile>
#include <QPainter>

#include <klocale.h>
#include <kdebug.h>
#include <kurl.h>
#include <kstandarddirs.h>
#include <kpixmapcache.h>
#include <kglobal.h>
#include <kunitconversion/converter.h>

00039 struct StaticKalziumDataObject
{
    KalziumDataObject kdo;
};

K_GLOBAL_STATIC( StaticKalziumDataObject, s_kdo )

KalziumDataObject* KalziumDataObject::instance()
{
    return &s_kdo->kdo;
}

KalziumDataObject::KalziumDataObject()
        : m_search( 0 )
{
    // reading elements
    ElementSaxParser * parser = new ElementSaxParser();

    QFile xmlFile( KStandardDirs::locate( "data", "libkdeedu/data/elements.xml" ) );
    QXmlInputSource source(&xmlFile);
    QXmlSimpleReader reader;

    reader.setContentHandler(parser);
    reader.parse(source);

    ElementList = parser->getElements();

    //we don't need parser anymore, let's free its memory
    delete parser;

    //read the spectra
    SpectrumParser * spectrumparser = new SpectrumParser();

    QFile xmlSpFile( KStandardDirs::locate( "data", "libkdeedu/data/spectra.xml" ) );
    QXmlInputSource spsource(&xmlSpFile);
    QXmlSimpleReader sp_reader;

    sp_reader.setContentHandler(spectrumparser);
    sp_reader.parse(spsource);

    m_spectra = spectrumparser->getSpectrums();

    //we don't need spectrumparser anymore, let's free its memory
    delete spectrumparser;

    // reading isotopes
    IsotopeParser * isoparser = new IsotopeParser();

    QFile xmlIsoFile( KStandardDirs::locate( "data", "libkdeedu/data/isotopes.xml" ) );
    QXmlInputSource isosource(&xmlIsoFile);
    QXmlSimpleReader isoreader;

    isoreader.setContentHandler(isoparser);
    isoreader.parse(isosource);

    QList<Isotope*> isotopes = isoparser->getIsotopes();

    //we don't need isoparser anymore, let's free its memory
    delete isoparser;

    foreach( Isotope *iso, isotopes )
    {
        int num = iso->parentElementNumber();
        if ( m_isotopes.contains( num ) ) {
            m_isotopes[num].append( iso );
        } else {
            QList<Isotope*> newlist;
            newlist.append( iso );
            m_isotopes.insert( num, newlist );
        }
    }

    // cache it
    m_numOfElements = ElementList.count();

    qAddPostRoutine( KalziumDataObject::cleanup );
}

KalziumDataObject::~KalziumDataObject()
{
    //Delete all elements
    qDeleteAll(ElementList);

    //Delete all isotopes
    QHashIterator<int, QList<Isotope*> > i(m_isotopes);
    while (i.hasNext()) {
        i.next();
        qDeleteAll( i.value());
    }
}

Element* KalziumDataObject::element( int number )
{
    // checking that we are requesting a valid element
    if ( ( number <= 0 ) || ( number > m_numOfElements ) )
        return 0;
    return ElementList[ number-1 ];
}

00138 QString KalziumDataObject::unitAsString( const int unit ) const
{
    return KUnitConversion::Converter().unit( unit ).data()->symbol();
}

QPixmap KalziumDataObject::pixmap( int number )
{
    // checking that we are requesting a valid element
    if ( ( number <= 0 ) || ( number > m_numOfElements ) )
        return 0;
    if ( PixmapList.isEmpty() )
        loadIconSet();
    return PixmapList[ number-1 ];
}

QList<Isotope*> KalziumDataObject::isotopes( Element * element )
{
    return isotopes( element->dataAsVariant( ChemicalDataObject::atomicNumber ).toInt() );
}

QList<Isotope*> KalziumDataObject::isotopes( int number )
{
    return m_isotopes.contains( number ) ? m_isotopes.value( number ) : QList<Isotope*>();
}

Spectrum * KalziumDataObject::spectrum( int number )
{
    foreach (Spectrum * s, m_spectra ) {
        if (s->parentElementNumber() == number ) {
            return s;
        }
    }

    return 0;
}


void KalziumDataObject::setSearch( Search *srch )
{
    m_search = srch;
}

Search* KalziumDataObject::search() const
{
    return m_search;
}

void KalziumDataObject::cleanup()
{
    KalziumDataObject::instance()->cleanPixmaps();
}

void KalziumDataObject::loadIconSet()
{
    KPixmapCache cache("kalzium");
    //FIXME in case we ever get more than one theme we need
    //a settings-dialog where we can select the different iconsets...
    const QString setname = "school";
    const QString pathname = KGlobal::dirs()->findResourceDir( "appdata", "data/iconsets/" ) + "data/iconsets/";

    for ( int i = 0 ; i < m_numOfElements ; i++ )
    {
        QString filename = pathname + setname + '/' + QString::number( i+1 ) + ".svg";

        QPixmap pix = cache.loadFromSvg( filename, QSize( 40, 40 ) );
        if ( pix.isNull() ) {
            pix = QPixmap( 40, 40 );
            pix.fill(Qt::transparent);

            QPainter p( &pix );
            Element *e =  ElementList.at(i);
            QString esymbol = e->dataAsString( ChemicalDataObject::symbol );
            p.drawText(0,0,40,40, Qt::AlignCenter | Qt::TextWordWrap, esymbol );
            p.end();
        }
        PixmapList << pix;
    }
}

void KalziumDataObject::cleanPixmaps()
{
    PixmapList.clear();
}

Generated by  Doxygen 1.6.0   Back to index