/*========================================================================= Library: CTK Copyright (c) 2010 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.commontk.org/LICENSE 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 __ctkDynamicSpacer_h #define __ctkDynamicSpacer_h // Qt includes #include // CTK includes #include #include "CTKWidgetsExport.h" class ctkDynamicSpacerPrivate; /// Description /// A spacer widget that has a dynamic size policy controllable via its slot /// activate(bool). It can be usefully when you don't want a rigid layout. class CTK_WIDGETS_EXPORT ctkDynamicSpacer : public QWidget { Q_OBJECT Q_PROPERTY(QSizePolicy activeSizePolicy READ activeSizePolicy WRITE setActiveSizePolicy); Q_PROPERTY(QSizePolicy inactiveSizePolicy READ inactiveSizePolicy WRITE setInactiveSizePolicy); Q_PROPERTY(bool activate READ isActivated WRITE activate); public: /// Constructor, builds a ctkDynamicSpacer, inactive by default ctkDynamicSpacer(QWidget *parent = 0); virtual ~ctkDynamicSpacer(); /// The active size policy of the spacer. By default the same as QWidget QSizePolicy activeSizePolicy() const; void setActiveSizePolicy(QSizePolicy sizePolicy); inline void setActiveSizePolicy(QSizePolicy::Policy horizontal, QSizePolicy::Policy vertical); /// The inactive size policy of the spacer. By default the same as QWidget. QSizePolicy inactiveSizePolicy() const; void setInactiveSizePolicy(QSizePolicy sizePolicy); inline void setInactiveSizePolicy(QSizePolicy::Policy horizontal, QSizePolicy::Policy vertical); /// Return the what size policy is current: /// false is inactive Size Policy that is current /// true is active SizePolicy that is current bool isActivated()const; public slots: /// Change the size policy. If enable is true, activeSizePolicy is used, /// inactiveSizePolicy otherwise void activate(bool enable); private: CTK_DECLARE_PRIVATE(ctkDynamicSpacer); }; void ctkDynamicSpacer::setActiveSizePolicy(QSizePolicy::Policy horizontal, QSizePolicy::Policy vertical) { this->setActiveSizePolicy(QSizePolicy(horizontal, vertical)); } void ctkDynamicSpacer::setInactiveSizePolicy(QSizePolicy::Policy horizontal, QSizePolicy::Policy vertical) { this->setInactiveSizePolicy(QSizePolicy(horizontal, vertical)); } #endif