Fl_Pack2.H 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. //
  2. // "$Id: Fl_Pack.H 6664 2009-02-18 09:27:54Z AlbrechtS $"
  3. //
  4. // Pack header file for the Fast Light Tool Kit (FLTK).
  5. //
  6. // Copyright 1998-2009 by Bill Spitzak and others.
  7. //
  8. // This library is free software; you can redistribute it and/or
  9. // modify it under the terms of the GNU Library General Public
  10. // License as published by the Free Software Foundation; either
  11. // version 2 of the License, or (at your option) any later version.
  12. //
  13. // This library is distributed in the hope that it will be useful,
  14. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. // Library General Public License for more details.
  17. //
  18. // You should have received a copy of the GNU Library General Public
  19. // License along with this library; if not, write to the Free Software
  20. // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
  21. // USA.
  22. //
  23. // Please report all bugs and problems on the following page:
  24. //
  25. // http://www.fltk.org/str.php
  26. //
  27. /* \file
  28. Fl_Pack widget . */
  29. #ifndef Fl_Pack_H
  30. #define Fl_Pack_H
  31. #include <FL/Fl_Group.H>
  32. /**
  33. This widget was designed to add the functionality of compressing and
  34. aligning widgets.
  35. <P>If type() is Fl_Pack::HORIZONTAL all the children are
  36. resized to the height of the Fl_Pack, and are moved next to
  37. each other horizontally. If type() is not Fl_Pack::HORIZONTAL
  38. then the children are resized to the width and are stacked below each
  39. other. Then the Fl_Pack resizes itself to surround the child
  40. widgets.
  41. <P>This widget is needed for the Fl_Tabs.
  42. In addition you may want to put the Fl_Pack inside an
  43. Fl_Scroll.
  44. <P>The resizable for Fl_Pack is set to NULL by default.</p>
  45. <P>See also: Fl_Group::resizable()
  46. */
  47. //class FL_EXPORT Fl_Pack : public Fl_Group {
  48. DECLARE_CLASS_CHEAP_RTTI_2(Fl_Pack, Fl_Group)
  49. int spacing_;
  50. public:
  51. enum { // values for type(int)
  52. VERTICAL = 0,
  53. HORIZONTAL = 1
  54. };
  55. protected:
  56. void draw();
  57. public:
  58. Fl_Pack(int x,int y,int w ,int h,const char *l = 0);
  59. /**
  60. Gets the number of extra pixels of blank space that are added
  61. between the children.
  62. */
  63. int spacing() const {return spacing_;}
  64. /**
  65. Sets the number of extra pixels of blank space that are added
  66. between the children.
  67. */
  68. void spacing(int i) {spacing_ = i;}
  69. /** Same as Fl_Group::type() */
  70. uchar horizontal() const {return type();}
  71. };
  72. #endif
  73. //
  74. // End of "$Id: Fl_Pack.H 6664 2009-02-18 09:27:54Z AlbrechtS $".
  75. //