| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 | /*=========================================================================  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.=========================================================================*//*=========================================================================   Program: ParaView   Module:  pqSettings.h   Copyright (c) 2005-2008 Sandia Corporation, Kitware Inc.   All rights reserved.   ParaView is a free software; you can redistribute it and/or modify it   under the terms of the ParaView license version 1.2.    See http://www.paraview.org/paraview/project/license.html for the full ParaView license.   A copy of this license can be obtained by contacting   Kitware Inc.   28 Corporate Drive   Clifton Park, NY 12065   USATHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOTLIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FORA PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS ORCONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, ORPROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OFLIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDINGNEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THISSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.=========================================================================*//// \file ctkSettings.h////// \date 02/03/2010#ifndef __ctkSettings_h#define __ctkSettings_h// Qt includes#include <QSettings>// CTK includes#include "ctkWidgetsExport.h"class QDialog;class QMainWindow;/// \ingroup Widgets/// ctkSettings is a QSettings that additionally can save and restore the /// state (position/size) of QMainWindow and QDialogs.class CTK_WIDGETS_EXPORT ctkSettings : public QSettings{  Q_OBJECTpublic:  /// \see QSettings::QSettings(const QString& ,const QString& , QObject* )  ctkSettings(    const QString& organization,    const QString& application,    QObject* parent = 0);  /// \see QSettings::QSettings(QSettings::Scope ,const QString& ,const QString& , QObject* )  ctkSettings(    QSettings::Scope scope,    const QString& organization,    const QString& application = QString(),    QObject* parent = 0);  /// \see QSettings::QSettings(QSettings::Format ,QSettings::Scope ,const QString& ,const QString& , QObject* )  ctkSettings(    QSettings::Format format,    QSettings::Scope scope,    const QString& organization,    const QString& application = QString(),    QObject* parent = 0);  /// \see QSettings::QSettings(const QString& , QSettings::Format , QObject* )  ctkSettings(const QString& fileName, QSettings::Format format, QObject* parent = 0);  /// \see QSettings::QSettings(QObject*)  ctkSettings(QObject* parent = 0);  /// Saves the position, size and layout of the QMainWindow  void saveState(const QMainWindow& window, const QString& key);  /// Saves the position and size of the QDialog  void saveState(const QDialog& dialog, const QString& key);  /// Restore the position, size and layout of the QMainWindow  /// for a given key  void restoreState(const QString& key, QMainWindow& window);    /// Saves the position, size and layout of the QMainWindow  /// for a given key  void restoreState(const QString& key, QDialog& dialog);  /// Calling this method will cause the modified signal to be emited.  void alertSettingsModified();Q_SIGNALS:  void modified();};#endif
 |