VirtualBox

source: vbox/trunk/src/VBox/Additions/WINNT/VBoxTray/helpers.cpp@ 9461

Last change on this file since 9461 was 8155, checked in by vboxsync, 17 years ago

The Big Sun Rebranding Header Change

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.6 KB
Line 
1/** @file
2 * helpers - Guest Additions Service helper functions
3 */
4
5/*
6 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
17 * Clara, CA 95054 USA or visit http://www.sun.com if you need
18 * additional information or have any questions.
19 */
20
21#include <malloc.h>
22#include <windows.h>
23
24#include "helpers.h"
25
26static unsigned nextAdjacentRectXP (RECTL *paRects, unsigned nRects, unsigned iRect)
27{
28 unsigned i;
29 for (i = 0; i < nRects; i++)
30 {
31 if (paRects[iRect].right == paRects[i].left)
32 {
33 return i;
34 }
35 }
36 return ~0;
37}
38
39static unsigned nextAdjacentRectXN (RECTL *paRects, unsigned nRects, unsigned iRect)
40{
41 unsigned i;
42 for (i = 0; i < nRects; i++)
43 {
44 if (paRects[iRect].left == paRects[i].right)
45 {
46 return i;
47 }
48 }
49 return ~0;
50}
51
52static unsigned nextAdjacentRectYP (RECTL *paRects, unsigned nRects, unsigned iRect)
53{
54 unsigned i;
55 for (i = 0; i < nRects; i++)
56 {
57 if (paRects[iRect].bottom == paRects[i].top)
58 {
59 return i;
60 }
61 }
62 return ~0;
63}
64
65unsigned nextAdjacentRectYN (RECTL *paRects, unsigned nRects, unsigned iRect)
66{
67 unsigned i;
68 for (i = 0; i < nRects; i++)
69 {
70 if (paRects[iRect].top == paRects[i].bottom)
71 {
72 return i;
73 }
74 }
75 return ~0;
76}
77
78void resizeRect(RECTL *paRects, unsigned nRects, unsigned iPrimary, unsigned iResized, int NewWidth, int NewHeight)
79{
80 RECTL *paNewRects = (RECTL *)alloca (sizeof (RECTL) * nRects);
81 memcpy (paNewRects, paRects, sizeof (RECTL) * nRects);
82 paNewRects[iResized].right += NewWidth - (paNewRects[iResized].right - paNewRects[iResized].left);
83 paNewRects[iResized].bottom += NewHeight - (paNewRects[iResized].bottom - paNewRects[iResized].top);
84
85 /* Verify all pairs of originally adjacent rectangles for all 4 directions.
86 * If the pair has a "good" delta (that is the first rectangle intersects the second)
87 * at a direction and the second rectangle is not primary one (which can not be moved),
88 * move the second rectangle to make it adjacent to the first one.
89 */
90
91 /* X positive. */
92 unsigned iRect;
93 for (iRect = 0; iRect < nRects; iRect++)
94 {
95 /* Find the next adjacent original rect in x positive direction. */
96 unsigned iNextRect = nextAdjacentRectXP (paRects, nRects, iRect);
97 DDCLOG(("next %d -> %d\n", iRect, iNextRect));
98
99 if (iNextRect == ~0 || iNextRect == iPrimary)
100 {
101 continue;
102 }
103
104 /* Check whether there is an X intesection between these adjacent rects in the new rectangles
105 * and fix the intersection if delta is "good".
106 */
107 int delta = paNewRects[iRect].right - paNewRects[iNextRect].left;
108
109 if (delta > 0)
110 {
111 DDCLOG(("XP intersection right %d left %d, diff %d\n",
112 paNewRects[iRect].right, paNewRects[iNextRect].left,
113 delta));
114
115 paNewRects[iNextRect].left += delta;
116 paNewRects[iNextRect].right += delta;
117 }
118 }
119
120 /* X negative. */
121 for (iRect = 0; iRect < nRects; iRect++)
122 {
123 /* Find the next adjacent original rect in x negative direction. */
124 unsigned iNextRect = nextAdjacentRectXN (paRects, nRects, iRect);
125 DDCLOG(("next %d -> %d\n", iRect, iNextRect));
126
127 if (iNextRect == ~0 || iNextRect == iPrimary)
128 {
129 continue;
130 }
131
132 /* Check whether there is an X intesection between these adjacent rects in the new rectangles
133 * and fix the intersection if delta is "good".
134 */
135 int delta = paNewRects[iRect].left - paNewRects[iNextRect].right;
136
137 if (delta < 0)
138 {
139 DDCLOG(("XN intersection left %d right %d, diff %d\n",
140 paNewRects[iRect].left, paNewRects[iNextRect].right,
141 delta));
142
143 paNewRects[iNextRect].left += delta;
144 paNewRects[iNextRect].right += delta;
145 }
146 }
147
148 /* Y positive (in the computer sence, top->down). */
149 for (iRect = 0; iRect < nRects; iRect++)
150 {
151 /* Find the next adjacent original rect in y positive direction. */
152 unsigned iNextRect = nextAdjacentRectYP (paRects, nRects, iRect);
153 DDCLOG(("next %d -> %d\n", iRect, iNextRect));
154
155 if (iNextRect == ~0 || iNextRect == iPrimary)
156 {
157 continue;
158 }
159
160 /* Check whether there is an Y intesection between these adjacent rects in the new rectangles
161 * and fix the intersection if delta is "good".
162 */
163 int delta = paNewRects[iRect].bottom - paNewRects[iNextRect].top;
164
165 if (delta > 0)
166 {
167 DDCLOG(("YP intersection bottom %d top %d, diff %d\n",
168 paNewRects[iRect].bottom, paNewRects[iNextRect].top,
169 delta));
170
171 paNewRects[iNextRect].top += delta;
172 paNewRects[iNextRect].bottom += delta;
173 }
174 }
175
176 /* Y negative (in the computer sence, down->top). */
177 for (iRect = 0; iRect < nRects; iRect++)
178 {
179 /* Find the next adjacent original rect in x negative direction. */
180 unsigned iNextRect = nextAdjacentRectYN (paRects, nRects, iRect);
181 DDCLOG(("next %d -> %d\n", iRect, iNextRect));
182
183 if (iNextRect == ~0 || iNextRect == iPrimary)
184 {
185 continue;
186 }
187
188 /* Check whether there is an Y intesection between these adjacent rects in the new rectangles
189 * and fix the intersection if delta is "good".
190 */
191 int delta = paNewRects[iRect].top - paNewRects[iNextRect].bottom;
192
193 if (delta < 0)
194 {
195 DDCLOG(("YN intersection top %d bottom %d, diff %d\n",
196 paNewRects[iRect].top, paNewRects[iNextRect].bottom,
197 delta));
198
199 paNewRects[iNextRect].top += delta;
200 paNewRects[iNextRect].bottom += delta;
201 }
202 }
203
204 memcpy (paRects, paNewRects, sizeof (RECTL) * nRects);
205 return;
206}
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette