ctkDynamicSpacer.h 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /*=========================================================================
  2. Library: CTK
  3. Copyright (c) Kitware Inc.
  4. Licensed under the Apache License, Version 2.0 (the "License");
  5. you may not use this file except in compliance with the License.
  6. You may obtain a copy of the License at
  7. http://www.commontk.org/LICENSE
  8. Unless required by applicable law or agreed to in writing, software
  9. distributed under the License is distributed on an "AS IS" BASIS,
  10. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. See the License for the specific language governing permissions and
  12. limitations under the License.
  13. =========================================================================*/
  14. #ifndef __ctkDynamicSpacer_h
  15. #define __ctkDynamicSpacer_h
  16. // Qt includes
  17. #include <QWidget>
  18. // CTK includes
  19. #include <ctkPimpl.h>
  20. #include "ctkWidgetsExport.h"
  21. class ctkDynamicSpacerPrivate;
  22. /// Description
  23. /// A spacer widget that has a dynamic size policy controllable via its slot
  24. /// activate(bool). It can be usefully when you don't want a rigid layout.
  25. class CTK_WIDGETS_EXPORT ctkDynamicSpacer : public QWidget
  26. {
  27. Q_OBJECT
  28. Q_PROPERTY(QSizePolicy activeSizePolicy READ activeSizePolicy WRITE setActiveSizePolicy);
  29. Q_PROPERTY(QSizePolicy inactiveSizePolicy READ inactiveSizePolicy WRITE setInactiveSizePolicy);
  30. Q_PROPERTY(bool active READ isActive WRITE setActive);
  31. public:
  32. /// Constructor, builds a ctkDynamicSpacer, inactive by default
  33. ctkDynamicSpacer(QWidget *parent = 0);
  34. virtual ~ctkDynamicSpacer();
  35. /// The active size policy of the spacer. By default the same as QWidget
  36. QSizePolicy activeSizePolicy() const;
  37. void setActiveSizePolicy(QSizePolicy sizePolicy);
  38. inline void setActiveSizePolicy(QSizePolicy::Policy horizontal, QSizePolicy::Policy vertical);
  39. /// The inactive size policy of the spacer. By default the same as QWidget.
  40. QSizePolicy inactiveSizePolicy() const;
  41. void setInactiveSizePolicy(QSizePolicy sizePolicy);
  42. inline void setInactiveSizePolicy(QSizePolicy::Policy horizontal, QSizePolicy::Policy vertical);
  43. /// Return the what size policy is current:
  44. /// false is inactive Size Policy that is current
  45. /// true is active SizePolicy that is current
  46. bool isActive()const;
  47. inline bool isInactive()const;
  48. public slots:
  49. /// Change the size policy. If enable is true, activeSizePolicy is used,
  50. /// inactiveSizePolicy otherwise
  51. void setActive(bool enable);
  52. inline void setInactive(bool disable);
  53. protected:
  54. QScopedPointer<ctkDynamicSpacerPrivate> d_ptr;
  55. private:
  56. Q_DECLARE_PRIVATE(ctkDynamicSpacer);
  57. Q_DISABLE_COPY(ctkDynamicSpacer);
  58. };
  59. void ctkDynamicSpacer::setActiveSizePolicy(QSizePolicy::Policy horizontal, QSizePolicy::Policy vertical)
  60. {
  61. this->setActiveSizePolicy(QSizePolicy(horizontal, vertical));
  62. }
  63. void ctkDynamicSpacer::setInactiveSizePolicy(QSizePolicy::Policy horizontal, QSizePolicy::Policy vertical)
  64. {
  65. this->setInactiveSizePolicy(QSizePolicy(horizontal, vertical));
  66. }
  67. bool ctkDynamicSpacer::isInactive()const
  68. {
  69. return !this->isActive();
  70. }
  71. void ctkDynamicSpacer::setInactive(bool disable)
  72. {
  73. this->setActive(!disable);
  74. }
  75. #endif