summaryrefslogtreecommitdiffstats
path: root/twin/placement.h
diff options
context:
space:
mode:
authorTimothy Pearson <[email protected]>2011-11-07 21:50:33 -0600
committerTimothy Pearson <[email protected]>2011-11-07 21:50:33 -0600
commit0b6057404f65218182ab27a9483a21065ef61fca (patch)
treeb8b06dfa2deb965bebfbe131a772124e3e693a96 /twin/placement.h
parent43d99cc2477266cb9072e179137f0e8485370b3d (diff)
downloadtdebase-0b6057404f65218182ab27a9483a21065ef61fca.tar.gz
tdebase-0b6057404f65218182ab27a9483a21065ef61fca.zip
Rename kwin to twin (Part 2 of 2)
Diffstat (limited to 'twin/placement.h')
-rw-r--r--twin/placement.h92
1 files changed, 92 insertions, 0 deletions
diff --git a/twin/placement.h b/twin/placement.h
new file mode 100644
index 000000000..65db2df34
--- /dev/null
+++ b/twin/placement.h
@@ -0,0 +1,92 @@
+/*****************************************************************
+ KWin - the KDE window manager
+ This file is part of the KDE project.
+
+Copyright (C) 1999, 2000 Matthias Ettrich <[email protected]>
+Copyright (C) 1997 to 2002 Cristian Tibirna <[email protected]>
+Copyright (C) 2003 Lubos Lunak <[email protected]>
+
+You can Freely distribute this program under the GNU General Public
+License. See the file "COPYING" for the exact licensing terms.
+******************************************************************/
+
+#ifndef KWIN_PLACEMENT_H
+#define KWIN_PLACEMENT_H
+
+#include <tqpoint.h>
+#include <tqvaluelist.h>
+
+namespace KWinInternal
+{
+
+class Workspace;
+class Client;
+
+class Placement
+ {
+ public:
+
+ Placement(Workspace* w);
+
+ /**
+ * Placement policies. How workspace decides the way windows get positioned
+ * on the screen. The better the policy, the heavier the resource use.
+ * Normally you don't have to worry. What the WM adds to the startup time
+ * is nil compared to the creation of the window itself in the memory
+ */
+ enum Policy
+ {
+ NoPlacement, // not really a placement
+ Default, // special, means to use the global default
+ Unknown, // special, means the function should use its default
+ Random,
+ Smart,
+ Cascade,
+ Centered,
+ ZeroCornered,
+ UnderMouse, // special
+ OnMainWindow, // special
+ Maximizing
+ };
+
+ void place(Client* c, TQRect& area );
+
+ void placeAtRandom (Client* c, const TQRect& area, Policy next = Unknown );
+ void placeCascaded (Client* c, TQRect& area, Policy next = Unknown );
+ void placeSmart (Client* c, const TQRect& area, Policy next = Unknown );
+ void placeMaximizing (Client* c, TQRect& area, Policy next = Unknown );
+ void placeCentered (Client* c, const TQRect& area, Policy next = Unknown );
+ void placeZeroCornered(Client* c, const TQRect& area, Policy next = Unknown );
+ void placeDialog (Client* c, TQRect& area, Policy next = Unknown );
+ void placeUtility (Client* c, TQRect& area, Policy next = Unknown );
+
+ void reinitCascading( int desktop );
+
+ static Policy policyFromString( const TQString& policy, bool no_special );
+ static const char* policyToString( Policy policy );
+
+ private:
+
+ void place(Client* c, TQRect& area, Policy policy, Policy nextPlacement = Unknown );
+ void placeUnderMouse(Client* c, TQRect& area, Policy next = Unknown );
+ void placeOnMainWindow(Client* c, TQRect& area, Policy next = Unknown );
+ TQRect checkArea( const Client*c, const TQRect& area );
+
+ Placement();
+
+ //CT needed for cascading+
+ struct DesktopCascadingInfo
+ {
+ TQPoint pos;
+ int col;
+ int row;
+ };
+
+ TQValueList<DesktopCascadingInfo> cci;
+
+ Workspace* m_WorkspacePtr;
+ };
+
+} // namespace
+
+#endif