123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- /*=========================================================================
- Library: CTK
- Copyright (c) Kitware Inc.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0.txt
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- =========================================================================*/
- #ifndef __ctkDICOMIndexer_h
- #define __ctkDICOMIndexer_h
- // Qt includes
- #include <QObject>
- #include <QSqlDatabase>
- #include "ctkDICOMCoreExport.h"
- #include "ctkDICOMDatabase.h"
- class ctkDICOMIndexerPrivate;
- /// \ingroup DICOM_Core
- ///
- /// \brief Indexes DICOM images located in local directory into an Sql database
- ///
- class CTK_DICOM_CORE_EXPORT ctkDICOMIndexer : public QObject
- {
- Q_OBJECT
- public:
- explicit ctkDICOMIndexer(QObject *parent = 0);
- virtual ~ctkDICOMIndexer();
- ///
- /// \brief Adds directory to database and optionally copies files to
- /// destinationDirectory.
- ///
- /// Scan the directory using Dcmtk and populate the database with all the
- /// DICOM images accordingly.
- ///
- Q_INVOKABLE void addDirectory(ctkDICOMDatabase& database, const QString& directoryName,
- const QString& destinationDirectoryName = "");
- ///
- /// \brief Adds directory to database by using DICOMDIR and optionally copies files to
- /// destinationDirectory.
- /// Scan the directory using Dcmtk and populate the database with all the
- /// DICOM images accordingly.
- /// \return Returns false if there was an error while processing the DICOMDIR file.
- ///
- Q_INVOKABLE bool addDicomdir(ctkDICOMDatabase& database, const QString& directoryName,
- const QString& destinationDirectoryName = "");
- ///
- /// \brief Adds a QStringList containing the file path to database and optionally copies files to
- /// destinationDirectory.
- ///
- /// Scan the directory using Dcmtk and populate the database with all the
- /// DICOM images accordingly.
- ///
- Q_INVOKABLE void addListOfFiles(ctkDICOMDatabase& database, const QStringList& listOfFiles,
- const QString& destinationDirectoryName = "");
- ///
- /// \brief Adds a file to database and optionally copies the file to
- /// destinationDirectory.
- ///
- /// Scan the file using Dcmtk and populate the database with all the
- /// DICOM fields accordingly.
- ///
- Q_INVOKABLE void addFile(ctkDICOMDatabase& database, const QString filePath,
- const QString& destinationDirectoryName = "");
- Q_INVOKABLE void refreshDatabase(ctkDICOMDatabase& database, const QString& directoryName);
- ///
- /// \brief Deprecated - no op.
- /// \deprecated
- /// Previously ensured that the QFuture threads have all finished indexing
- /// before returning control.
- ///
- Q_INVOKABLE void waitForImportFinished();
- Q_SIGNALS:
- void foundFilesToIndex(int);
- void indexingFileNumber(int);
- void indexingFilePath(QString);
- void progress(int);
- void indexingComplete();
- public Q_SLOTS:
- void cancel();
- protected:
- QScopedPointer<ctkDICOMIndexerPrivate> d_ptr;
- private:
- Q_DECLARE_PRIVATE(ctkDICOMIndexer);
- Q_DISABLE_COPY(ctkDICOMIndexer);
- };
- #endif
|