File: Splitter.h

package info (click to toggle)
subcommander 2.0.0~b5p1-2
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 14,880 kB
  • ctags: 9,003
  • sloc: cpp: 63,591; sh: 3,904; xml: 1,984; makefile: 1,166; ansic: 786; ruby: 251; lisp: 24
file content (57 lines) | stat: -rw-r--r-- 1,392 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/* ====================================================================
 * Copyright (c) 2007-2008  Martin Hauner
 *                          http://subcommander.tigris.org
 *
 * Subcommander is licensed as described in the file doc/COPYING, which
 * you should have received as part of this distribution.
 * ====================================================================
 */

#ifndef _SC_SPLITTER_H
#define _SC_SPLITTER_H

// sc
class SplitterHandle;

// qt
#include <QtGui/QSplitter>



/** Splitter with "on handle double click hide first or last child" */
class Splitter : public QSplitter
{
  typedef QSplitter super;
  Q_OBJECT

public:
  enum Hide
  {
    First,    ///< double click on handle hides the first child.
    Last      ///< double click on handle hides the last child.
  };

  /**
   * construct a @a Splitter with the given parent @a parent and hide widget
   * @a hide. Optionally set the splitter @a orientation.
   */
  Splitter( QWidget *parent, Hide hide = First );
  Splitter( QWidget *parent, Qt::Orientation orientation, Hide hide = First );

  /** @c QSplitter overwrite. */
  QSplitterHandle* createHandle();

  /** show or hide the "hide" child. */
  void showHide( bool );

  /** enable or disable the "hide" child. */
  void enableHide( bool );

private:
  int length();

  Hide            _hide;
  SplitterHandle* _handle;
};

#endif // _SC_SPLITTER_H