Change copyrights from Nokia to Digia
[profile/ivi/qtwayland.git] / examples / qml-compositor / compositor.js
1 /****************************************************************************
2 **
3 ** Copyright (C) 2012 Digia Plc and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/legal
5 **
6 ** This file is part of the examples of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:BSD$
9 ** You may use this file under the terms of the BSD license as follows:
10 **
11 ** "Redistribution and use in source and binary forms, with or without
12 ** modification, are permitted provided that the following conditions are
13 ** met:
14 **   * Redistributions of source code must retain the above copyright
15 **     notice, this list of conditions and the following disclaimer.
16 **   * Redistributions in binary form must reproduce the above copyright
17 **     notice, this list of conditions and the following disclaimer in
18 **     the documentation and/or other materials provided with the
19 **     distribution.
20 **   * Neither the name of Digia Plc and its Subsidiary(-ies) nor the names
21 **     of its contributors may be used to endorse or promote products derived
22 **     from this software without specific prior written permission.
23 **
24 **
25 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26 ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27 ** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28 ** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
29 ** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
30 ** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
31 ** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32 ** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33 ** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34 ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35 ** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
36 **
37 ** $QT_END_LICENSE$
38 **
39 ****************************************************************************/
40
41 var windowList = null;
42 var indexes = null;
43
44 function relayout() {
45     if (windowList === null || windowList.length == 0)
46         return;
47
48     var dim = Math.ceil(Math.sqrt(windowList.length));
49
50     var cols = dim;
51     var rows = Math.ceil(windowList.length / cols);
52
53     var w = root.width / dim;
54     var h = root.height / rows;
55
56     var i;
57     var ix = 0;
58     var iy = 0;
59     var lastDim = 1;
60
61     indexes = new Array(dim * dim);
62
63     for (i = 0; i < windowList.length; ++i) {
64         if (i > 0) {
65             var currentDim = Math.ceil(Math.sqrt(i + 1));
66             if (currentDim == lastDim) {
67                 if (iy < currentDim - 1) {
68                     ++iy;
69                     if (iy == currentDim - 1)
70                         ix = 0;
71                 } else {
72                     ++ix;
73                 }
74             } else {
75                 iy = 0;
76                 ix = currentDim - 1;
77             }
78             lastDim = currentDim;
79         }
80
81         indexes[iy * dim + ix] = i;
82         windowList[i].index = iy * dim + ix;
83
84         var cx = (ix + 0.5) * w;
85         var cy = (iy + 0.5) * h;
86
87         windowList[i].targetScale = 0.98 * Math.min(w / windowList[i].width, h / windowList[i].height);
88
89         windowList[i].targetX = (cx - windowList[i].width / 2);
90         windowList[i].targetY = (cy - windowList[i].height / 2);
91     }
92 }
93
94 function addWindow(window)
95 {
96     if (windowList == null)
97         windowList = new Array(0);
98
99     windowList.push(window);
100     relayout();
101 }
102
103 function removeWindow(window)
104 {
105     var i;
106     for (i = 0; i < windowList.length; ++i) {
107         if (windowList[i] == window)
108             break;
109     }
110
111     var index = windowList[i].index;
112     var dim = Math.ceil(Math.sqrt(windowList.length));
113     var maxY = Math.floor((windowList.length-1) / dim);
114
115     var shrinking = Math.ceil(Math.sqrt(windowList.length - 1)) != dim;
116
117     while (true) {
118         var ix = index % dim;
119         var iy = Math.floor(index / dim);
120
121         if (shrinking) {
122             if (iy > 0)
123                 --iy;
124             else if (++ix == dim)
125                 break;
126         } else {
127             if (iy < maxY) {
128                 if (ix > 0)
129                     --ix;
130                 else
131                     ++iy;
132             } else {
133                 ++ix;
134             }
135         }
136
137         var next = iy * dim + ix;
138
139         var currentIndex = indexes[index];
140         var nextIndex = indexes[next];
141
142         if (nextIndex == null)
143             break;
144
145         var temp = windowList[currentIndex];
146         windowList[currentIndex] = windowList[nextIndex];
147         windowList[currentIndex].index = currentIndex;
148         windowList[nextIndex] = temp;
149
150         index = next;
151     }
152
153     windowList.splice(indexes[index], 1);
154     relayout();
155 }