00001 /*************************************************************************** 00002 File : MultiPeakFitTool.h 00003 Project : QtiPlot 00004 -------------------------------------------------------------------- 00005 Copyright : (C) 2006,2007 by Ion Vasilief, Knut Franke 00006 Email (use @ for *) : ion_vasilief*yahoo.fr, knut.franke*gmx.de 00007 Description : Plot tool for doing multi-peak fitting. 00008 00009 ***************************************************************************/ 00010 00011 /*************************************************************************** 00012 * * 00013 * This program is free software; you can redistribute it and/or modify * 00014 * it under the terms of the GNU General Public License as published by * 00015 * the Free Software Foundation; either version 2 of the License, or * 00016 * (at your option) any later version. * 00017 * * 00018 * This program is distributed in the hope that it will be useful, * 00019 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00020 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00021 * GNU General Public License for more details. * 00022 * * 00023 * You should have received a copy of the GNU General Public License * 00024 * along with this program; if not, write to the Free Software * 00025 * Foundation, Inc., 51 Franklin Street, Fifth Floor, * 00026 * Boston, MA 02110-1301 USA * 00027 * * 00028 ***************************************************************************/ 00029 #ifndef MULTI_PEAK_FIT_TOOL 00030 #define MULTI_PEAK_FIT_TOOL 00031 00032 #include "PlotToolInterface.h" 00033 #include "../analysis/MultiPeakFit.h" 00034 #include <QObject> 00035 00036 class DataPickerTool; 00037 class ApplicationWindow; 00038 class QwtPlotCurve; 00039 class QwtPlotMarker; 00040 00049 class MultiPeakFitTool : public QObject, public PlotToolInterface 00050 { 00051 Q_OBJECT 00052 public: 00053 MultiPeakFitTool(Graph *graph, ApplicationWindow *app, MultiPeakFit::PeakProfile profile, int num_peaks, const QObject *status_target, const char *status_slot); 00054 virtual ~MultiPeakFitTool(); 00055 00056 virtual int rtti() const {return PlotToolInterface::Rtti_MultiPeakFitTool;}; 00057 signals: 00062 void statusText(const QString&); 00063 protected slots: 00064 void selectPeak(QwtPlotCurve *curve, int point_index); 00065 private: 00066 void finalize(); 00067 int d_selected_peaks; 00068 DataPickerTool *d_picker_tool; 00069 MultiPeakFit *d_fit; 00070 QwtPlotCurve *d_curve; 00071 QList<QwtPlotMarker *> d_lines; 00072 }; 00073 00074 #endif // ifndef MULTI_PEAK_FIT_TOOL