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

spectrumwidget.h

/***************************************************************************
 *   Copyright (C) 2005, 2006 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.             *
 ***************************************************************************/
#ifndef SPECTRUMWIDGET_H
#define SPECTRUMWIDGET_H

#include <QWidget>

#include "spectrum.h"
#include "prefs.h"

/**
 * @author Carsten Niehaus
 */
00032 class SpectrumWidget : public QWidget
{
    Q_OBJECT

public:
    SpectrumWidget( QWidget *parent );

    ~SpectrumWidget() {}

    void setSpectrum( Spectrum* spec );

    Spectrum* spectrum()const {
        return m_spectrum;
    }

    /**
     * This limits the width of the spectrum in terms of
     * wavelength. For example you can set it to only
     * show the area between 500 and 550 nm
     *
     * @param left the left border
     * @param right the right border
     */
    void setBorders( double left, double right );

    /**
     * there are several possible types.
     */
00060     enum SpectrumType
    {
        EmissionSpectrum = 0,
        AbsorptionSpectrum
    };

    /**
     * sets the type of the spectrum to @p t
     * @param t the type of the spectrum
     */
00070     void setType( int t ) {
        m_type = t;
    }

    /**
     * @return the currently active type
     * of the spectrum
     */
00078     int spectrumType() const {
        return m_type;
    }

    /**
     * @return the adjusted value of the @p color. The
     * correction depends on @p factor which has been
     * figured out emperically
     */
    int Adjust( double color, double factor );

    /**
     * @return the postion in the widget of a band
     * with the wavelength @p wavelength
     *
     * @param wavelength the wavelength for which the position is needed
     */
00095     inline int xPos( double wavelength ) {
        return ( int ) ( ( wavelength-m_startValue ) * width() / ( m_endValue - m_startValue ) );
    }

    /**
     * based on the current position of the mouse-cursor the nearest
     * peak is searched. If found, it will be emitted.
     *
     * @see peakSelected
     */
    void findPeakFromMouseposition( double wavelength );

    /**
     * @param xpos The ratio of the position relative to the width
     * of the widget.
     * @return the wavelength on position @p xpos
     */
00112     inline double Wavelength( double xpos ) {
        return m_startValue + (  (  m_endValue-m_startValue ) *  xpos );
    }

    /**
     * This method changes the three values @p r, @p g and @p b to the
     * correct values
     * @param wavelength the wavelength for which the color is searched
     * @return the wavelenth color
     */
    QColor wavelengthToRGB( double wavelength );

private:
    QList<double> m_spectra;

    int m_type;

    Spectrum *m_spectrum;

    QPixmap m_pixmap;

    void paintBands( QPainter* p );
    void drawZoomLine( QPainter* p );

    /**
     * Draw the scale
     */
    void drawTickmarks( QPainter *p );

    double m_startValue;
    double m_endValue;

    double m_gamma;
    int m_intensityMax;

    int m_realHeight;

    /**
     * this QPoint stores the information where
     * the left mouse button has been pressed. This
     * is used for the mouse zooming
     */
00154     QPoint m_LMBPointPress;

    QPoint m_LMBPointCurrent;

public slots:
    ///(re)create startconditions
    void resetSpectrum();

    /**
     * set the maximum value to @p value
     */
00165     void setRightBorder( int value ) {
        if (value != m_endValue) {
            m_endValue = value;
            if ( m_endValue < m_startValue ) {
                m_startValue = m_endValue-1;
            }
            update();
        }
    }

    /**
     * set the minimum value to @p value
     */
00178     void setLeftBorder( int value ) {
        if (value != m_startValue) {
            m_startValue = value;
            if ( m_startValue > m_endValue ) {
                m_endValue = m_startValue+1;
            }
            update();
        }
    }

    /**
     * activates the spectrum of the type @p spectrumtype
     */
00191     void slotActivateSpectrum( int spectrumtype ) {
        m_type = spectrumtype;
        Prefs::setSpectrumType( spectrumtype );
        Prefs::self()->writeConfig();
        update();
    }

signals:
    /**
     * the minimum and maximum displayed wavelength have
     * changed so emit the new minimum and maximum
     */
    void bordersChanged( int, int );

    /**
     * the user selected a peak
     */
    void peakSelected( Spectrum::peak * peak );

private slots:
    void slotZoomIn();
    void slotZoomOut();

protected:
    virtual void paintEvent( QPaintEvent *e );
    virtual void keyPressEvent(QKeyEvent *e);
    virtual void mouseMoveEvent( QMouseEvent *e );
    virtual void mousePressEvent( QMouseEvent *e );
    virtual void mouseReleaseEvent( QMouseEvent *e );
};

#endif // SPECTRUMWIDGET_H

Generated by  Doxygen 1.6.0   Back to index