You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

85 lines
2.4KB

  1. //
  2. // "$Id: Fl_Pack.H 7903 2010-11-28 21:06:39Z matt $"
  3. //
  4. // Pack header file for the Fast Light Tool Kit (FLTK).
  5. //
  6. // Copyright 1998-2010 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. int spacing_;
  49. public:
  50. enum { // values for type(int)
  51. VERTICAL = 0,
  52. HORIZONTAL = 1
  53. };
  54. protected:
  55. void draw();
  56. public:
  57. Fl_Pack(int x,int y,int w ,int h,const char *l = 0);
  58. /**
  59. Gets the number of extra pixels of blank space that are added
  60. between the children.
  61. */
  62. int spacing() const {return spacing_;}
  63. /**
  64. Sets the number of extra pixels of blank space that are added
  65. between the children.
  66. */
  67. void spacing(int i) {spacing_ = i;}
  68. /** Same as Fl_Group::type() */
  69. uchar horizontal() const {return type();}
  70. };
  71. #endif
  72. //
  73. // End of "$Id: Fl_Pack.H 7903 2010-11-28 21:06:39Z matt $".
  74. //