Newer
Older
/*
* Copyright 2011-2012 INSA Rennes
*
* This file is part of EIImage.
*
* EIImage 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 3 of the License, or
* (at your option) any later version.
*
* EIImage 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 EIImage. If not, see <http://www.gnu.org/licenses/>.
*/
#include <QTranslator>
#include <GenericInterface.h>
#include <iostream>
#include <QLibraryInfo>
#include "BuiltinOpSet.h"
#include "Services/PluginManager.h"
#include "Services/EIImageService.h"
#include "Operations/PointOp.h"
#include "Operations/ThresholdOp.h"
#include "Operations/TranslateOp.h"
#include "Operations/RotateOp.h"
#include "Operations/FlipOp.h"
#include "Operations/CenterOp.h"
#include "Operations/SplitColorOp.h"
#include "Operations/CombineColorOp.h"
#include "Operations/SignalToNoiseOp.h"
#include "Operations/MeanSquaredErrorOp.h"
#include "Operations/FFTOp.h"
#include "Operations/RandomImgOp.h"
#include "Operations/NoiseOp.h"
#include "Operations/BFlitOp.h"
#include "Operations/DMMOp.h"
#include "Operations/PseudoColorOp.h"
#include "Operations/CroissanceOp.h"
#include "Operations/ZeroCrossingOp.h"
#include "Operations/HistogramOp.h"
#include "Operations/ColorimetryOp.h"
#include "Operations/SinusSynthesisOp.h"
#include "Operations/ScalingOp.h"
#include "Operations/QuantificationOp.h"
#include "Operations/EntropyOp.h"
#include "Operations/HuffmanOp.h"
#include "Operations/RejectionRingOp.h"
#include "Operations/MICDEncodingOp.h"
#include "Operations/HadamardOp.h"
#include "Operations/DCTOp.h"
#include "Operations/HoughOp.h"
#include "Operations/InverseHoughOp.h"
#include "Operations/PyramidOp.h"
#include "Operations/InversePyramidOp.h"
#include "Operations/ClassAnalysisOp.h"
#include "Operations/ClassResultOp.h"
#include "Operations/SeparatorOp.h"
#include "Services/MorphoMatService.h"
#include "Services/FilteringService.h"
using namespace genericinterface;
using namespace std;
int main(int argc, char** argv)
{
QApplication app(argc, argv);
app.setOrganizationName("insa");
app.setApplicationName("eiimage");
QString lang = QString("en_US");
if(argc > 1) {
lang = QString(argv[1]);
}
QString tr = "qt_";
tr += lang;
if(!qtTranslator.load(tr, QLibraryInfo::location(QLibraryInfo::TranslationsPath))) {
cout << "Error while loading " << tr.toStdString() << endl;
}
QTranslator giTranslator;
if(!giTranslator.load(QString("genericinterface_") + lang.mid(0, 2))) {
cout << "Error while loading genericinterface_en.qm" << endl;
}
app.installTranslator(&giTranslator);
if(!eiiTranslator.load(QString("eiimage_") + lang.mid(0, 2))) {
cout << "Error while loading eiimage_en.qm" << endl;
}
app.installTranslator(&eiiTranslator);
GenericInterface gi("eiimage", Qt::LeftDockWidgetArea);
PluginManager* pluginManager = new PluginManager(&gi);
EIImageService* eiimageService = new EIImageService(&gi);
// gi.addService(eiimageService);
gi.changeService(GenericInterface::WINDOW_SERVICE, eiimageService);
// gi.addService(GenericInterface::WINDOW_SERVICE, eiimageService);
QObject::connect(pluginManager, SIGNAL(addPlugin(OpSet*)), eiimageService, SLOT(addOpSet(OpSet*)));
QObject::connect(pluginManager, SIGNAL(removePlugin(OpSet*)), eiimageService, SLOT(removeOpSet(OpSet*)));
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
BuiltinOpSet* image = new BuiltinOpSet(qApp->translate("", "&Image").toStdString());
image->addOperation(new PointOp());
image->addOperation(new TranslateOp());
image->addOperation(new RotateOp());
image->addOperation(new CenterOp());
image->addOperation(new FlipOp(FlipOp::Horizontal));
image->addOperation(new FlipOp(FlipOp::Vertical));
image->addOperation(new SeparatorOp());
image->addOperation(new SplitColorOp());
image->addOperation(new CombineColorOp());
image->addOperation(new ScalingOp());
image->addOperation(new QuantificationOp());
image->addOperation(new ThresholdOp());
image->addOperation(new HistogramOp());
BuiltinOpSet* tools = new BuiltinOpSet(qApp->translate("", "&Tools").toStdString());
tools->addOperation(new SignalToNoiseOp());
tools->addOperation(new MeanSquaredErrorOp());
tools->addOperation(new EntropyOp());
tools->addOperation(new NoiseOp());
tools->addOperation(new SeparatorOp());
tools->addOperation(new RandomImgOp());
tools->addOperation(new ColorimetryOp());
tools->addOperation(new RejectionRingOp());
tools->addOperation(new SinusSynthesisOp());
BuiltinOpSet* encode = new BuiltinOpSet(qApp->translate("", "&Encoding").toStdString());
encode->addOperation(new HuffmanOp());
encode->addOperation(new MICDEncodingOp());
BuiltinOpSet* morpho = new BuiltinOpSet("&Morpho. math.");
morpho->addOperation(new DMMOp());
morpho->addOperation(new SeparatorOp());
BuiltinOpSet* transfo = new BuiltinOpSet(qApp->translate("", "Transforms").toStdString());
transfo->addOperation(new FFTOp());
transfo->addOperation(new IFFTOp());
transfo->addOperation(new HadamardOp());
transfo->addOperation(new DCTOp());
transfo->addOperation(new HoughOp());
transfo->addOperation(new InverseHoughOp());
BuiltinOpSet* analyse = new BuiltinOpSet(qApp->translate("", "Analysis").toStdString());
analyse->addOperation(new CroissanceOp());
analyse->addOperation(new ZeroCrossingOp());
analyse->addOperation(new PyramidOp());
analyse->addOperation(new InversePyramidOp());
analyse->addOperation(new ClassAnalysisOp());
analyse->addOperation(new ClassResultOp());
analyse->addOperation(new PseudoColorOp());
BuiltinOpSet* filter = new BuiltinOpSet(qApp->translate("", "Filtering").toStdString());
filter->addOperation(new BFlitOp());
eiimageService->addOpSet(image);
eiimageService->addOpSet(encode);
eiimageService->addOpSet(morpho);
eiimageService->addOpSet(analyse);
eiimageService->addOpSet(transfo);
gi.addService(new MorphoMatService);
gi.addService(new filtrme::FilteringService);
eiimageService->addOpSet(filter);
eiimageService->addOpSet(tools);
gi.addService(pluginManager);