| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 | /*=========================================================================  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 __ctkFileDialog_h#define __ctkFileDialog_h// Qt includes#include <QFileDialog>// CTK includes#include <ctkPimpl.h>#include "ctkWidgetsExport.h"class ctkFileDialogPrivate;/// Customizable QFileDialog./// An extra widget can be added at the bottom of the dialog/// under the file format combobox. The Accept button is also controllable/// using setAcceptButtonEnable()class CTK_WIDGETS_EXPORT ctkFileDialog : public QFileDialog{  Q_OBJECTpublic:  // Superclass typedef  typedef QFileDialog Superclass;  /// Constructor  /// By default, behaves like a QFileDialog  /// \sa QFileDialog()  explicit ctkFileDialog(QWidget *parent = 0,              const QString &caption = QString(),              const QString &directory = QString(),              const QString &filter = QString());  virtual ~ctkFileDialog();    /// Add an extra widget under the file format combobox. If a label is  /// given, it will appear in the first column.  /// The widget is reparented to ctkFileDialog  void setBottomWidget(QWidget* widget, const QString& label=QString());  /// Return the extra widget if any  QWidget* bottomWidget()const;  /// Internally used  bool eventFilter(QObject *obj, QEvent *event);public slots:  /// Can be used to prevent the accept button to be enabled. It's typically  /// a slot that can be connected to assure that the user doesn't accept the  /// dialog if a value is not set in the extra bottom widget.  void setAcceptButtonEnable(bool enable);signals:  /// Signals QFileDialog::file[s]Selected() are fired only when the Ok button  /// is pressed, fileSelectionChanged(QStringList) is emitted when the  /// selection is changed, not just when the dialog is accepted.  void fileSelectionChanged(const QStringList& selected);protected slots:  void onSelectionChanged();protected:  QScopedPointer<ctkFileDialogPrivate> d_ptr;private:  Q_DECLARE_PRIVATE(ctkFileDialog);  Q_DISABLE_COPY(ctkFileDialog);};#endif
 |