Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/src/java.desktop/share/native/libmlib_image/mlib_ImageAffine_NN.c
41152 views
1
/*
2
* Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.
3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
*
5
* This code is free software; you can redistribute it and/or modify it
6
* under the terms of the GNU General Public License version 2 only, as
7
* published by the Free Software Foundation. Oracle designates this
8
* particular file as subject to the "Classpath" exception as provided
9
* by Oracle in the LICENSE file that accompanied this code.
10
*
11
* This code is distributed in the hope that it will be useful, but WITHOUT
12
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14
* version 2 for more details (a copy is included in the LICENSE file that
15
* accompanied this code).
16
*
17
* You should have received a copy of the GNU General Public License version
18
* 2 along with this work; if not, write to the Free Software Foundation,
19
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20
*
21
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22
* or visit www.oracle.com if you need additional information or have any
23
* questions.
24
*/
25
26
27
/*
28
* FUNCTION
29
* Internal functions for mlib_ImageAffine with Nearest Neighbor filtering.
30
*/
31
32
#include "mlib_ImageAffine.h"
33
34
/***************************************************************/
35
#define sp srcPixelPtr
36
#define dp dstPixelPtr
37
38
/***************************************************************/
39
#undef DTYPE
40
#define DTYPE mlib_s32
41
42
#ifdef _MSC_VER
43
/* Workaround for MSC optimizer bug (known affected versions
44
12.00.8168-12.00.8804). See bug 4893435 for details. */
45
#pragma optimize("gs", off)
46
#endif /* _MSC_VER */
47
#ifdef i386 /* do not perform the coping by mlib_d64 data type for x86 */
48
49
mlib_status mlib_ImageAffine_s32_1ch_nn(mlib_affine_param *param)
50
{
51
DECLAREVAR();
52
DTYPE *srcPixelPtr;
53
DTYPE *dstLineEnd;
54
55
for (j = yStart; j <= yFinish; j++) {
56
CLIP(1);
57
dstLineEnd = (DTYPE *) dstData + xRight;
58
59
for (; dp <= dstLineEnd; dp++) {
60
sp = S_PTR(Y) + (X >> MLIB_SHIFT);
61
dp[0] = sp[0];
62
63
X += dX;
64
Y += dY;
65
}
66
}
67
68
return MLIB_SUCCESS;
69
}
70
71
#else
72
73
mlib_status mlib_ImageAffine_s32_1ch_nn(mlib_affine_param *param)
74
{
75
DECLAREVAR();
76
DTYPE *srcPixelPtr;
77
mlib_s32 i, size;
78
79
for (j = yStart; j <= yFinish; j++) {
80
d64_2x32 dd;
81
82
CLIP(1);
83
size = xRight - xLeft + 1;
84
85
if ((mlib_addr) dp & 7) {
86
sp = S_PTR(Y);
87
*dp++ = sp[X >> MLIB_SHIFT];
88
X += dX;
89
Y += dY;
90
size--;
91
}
92
93
for (i = 0; i <= (size - 2); i += 2) {
94
mlib_f32 *sp0, *sp1;
95
96
sp0 = (mlib_f32 *) S_PTR(Y);
97
sp1 = (mlib_f32 *) S_PTR(Y + dY);
98
99
dd.f32s.f0 = sp0[X >> MLIB_SHIFT];
100
dd.f32s.f1 = sp1[(X + dX) >> MLIB_SHIFT];
101
102
*(mlib_d64 *) dp = dd.d64;
103
104
dp += 2;
105
X += 2 * dX;
106
Y += 2 * dY;
107
}
108
109
if (size & 1) {
110
sp = S_PTR(Y);
111
*dp = sp[X >> MLIB_SHIFT];
112
}
113
}
114
115
return MLIB_SUCCESS;
116
}
117
118
#endif /* i386 ( do not perform the coping by mlib_d64 data type for x86 ) */
119
120
/***************************************************************/
121
mlib_status mlib_ImageAffine_s32_2ch_nn(mlib_affine_param *param)
122
{
123
DECLAREVAR();
124
DTYPE *srcPixelPtr;
125
DTYPE *dstLineEnd;
126
127
for (j = yStart; j <= yFinish; j++) {
128
CLIP(2);
129
dstLineEnd = (DTYPE *) dstData + 2 * xRight;
130
131
for (; dp <= dstLineEnd; dp += 2) {
132
sp = S_PTR(Y) + 2 * (X >> MLIB_SHIFT);
133
dp[0] = sp[0];
134
dp[1] = sp[1];
135
136
X += dX;
137
Y += dY;
138
}
139
}
140
141
return MLIB_SUCCESS;
142
}
143
144
/***************************************************************/
145
mlib_status mlib_ImageAffine_s32_3ch_nn(mlib_affine_param *param)
146
{
147
DECLAREVAR();
148
DTYPE *srcPixelPtr;
149
DTYPE *dstLineEnd;
150
151
for (j = yStart; j <= yFinish; j++) {
152
CLIP(3);
153
dstLineEnd = (DTYPE *) dstData + 3 * xRight;
154
155
for (; dp <= dstLineEnd; dp += 3) {
156
sp = S_PTR(Y) + 3 * (X >> MLIB_SHIFT);
157
dp[0] = sp[0];
158
dp[1] = sp[1];
159
dp[2] = sp[2];
160
161
X += dX;
162
Y += dY;
163
}
164
}
165
166
return MLIB_SUCCESS;
167
}
168
169
/***************************************************************/
170
mlib_status mlib_ImageAffine_s32_4ch_nn(mlib_affine_param *param)
171
{
172
DECLAREVAR();
173
DTYPE *srcPixelPtr;
174
DTYPE *dstLineEnd;
175
176
for (j = yStart; j <= yFinish; j++) {
177
CLIP(4);
178
dstLineEnd = (DTYPE *) dstData + 4 * xRight;
179
180
for (; dp <= dstLineEnd; dp += 4) {
181
sp = S_PTR(Y) + 4 * (X >> MLIB_SHIFT);
182
dp[0] = sp[0];
183
dp[1] = sp[1];
184
dp[2] = sp[2];
185
dp[3] = sp[3];
186
187
X += dX;
188
Y += dY;
189
}
190
}
191
192
return MLIB_SUCCESS;
193
}
194
195
/***************************************************************/
196
#undef DTYPE
197
#define DTYPE mlib_d64
198
199
mlib_status mlib_ImageAffine_d64_1ch_nn(mlib_affine_param *param)
200
{
201
DECLAREVAR();
202
DTYPE *srcPixelPtr;
203
DTYPE *dstLineEnd;
204
205
for (j = yStart; j <= yFinish; j++) {
206
CLIP(1);
207
dstLineEnd = (DTYPE *) dstData + xRight;
208
209
for (; dp <= dstLineEnd; dp++) {
210
sp = S_PTR(Y);
211
dp[0] = sp[X >> MLIB_SHIFT];
212
213
X += dX;
214
Y += dY;
215
}
216
}
217
218
return MLIB_SUCCESS;
219
}
220
221
/***************************************************************/
222
mlib_status mlib_ImageAffine_d64_2ch_nn(mlib_affine_param *param)
223
{
224
DECLAREVAR();
225
DTYPE *srcPixelPtr;
226
DTYPE *dstLineEnd;
227
228
for (j = yStart; j <= yFinish; j++) {
229
CLIP(2);
230
dstLineEnd = (DTYPE *) dstData + 2 * xRight;
231
232
for (; dp <= dstLineEnd; dp += 2) {
233
sp = S_PTR(Y) + 2 * (X >> MLIB_SHIFT);
234
dp[0] = sp[0];
235
dp[1] = sp[1];
236
237
X += dX;
238
Y += dY;
239
}
240
}
241
242
return MLIB_SUCCESS;
243
}
244
245
/***************************************************************/
246
mlib_status mlib_ImageAffine_d64_3ch_nn(mlib_affine_param *param)
247
{
248
DECLAREVAR();
249
DTYPE *srcPixelPtr;
250
DTYPE *dstLineEnd;
251
252
for (j = yStart; j <= yFinish; j++) {
253
CLIP(3);
254
dstLineEnd = (DTYPE *) dstData + 3 * xRight;
255
256
for (; dp <= dstLineEnd; dp += 3) {
257
sp = S_PTR(Y) + 3 * (X >> MLIB_SHIFT);
258
dp[0] = sp[0];
259
dp[1] = sp[1];
260
dp[2] = sp[2];
261
262
X += dX;
263
Y += dY;
264
}
265
}
266
267
return MLIB_SUCCESS;
268
}
269
270
/***************************************************************/
271
mlib_status mlib_ImageAffine_d64_4ch_nn(mlib_affine_param *param)
272
{
273
DECLAREVAR();
274
DTYPE *srcPixelPtr;
275
DTYPE *dstLineEnd;
276
277
for (j = yStart; j <= yFinish; j++) {
278
CLIP(4);
279
dstLineEnd = (DTYPE *) dstData + 4 * xRight;
280
281
for (; dp <= dstLineEnd; dp += 4) {
282
sp = S_PTR(Y) + 4 * (X >> MLIB_SHIFT);
283
dp[0] = sp[0];
284
dp[1] = sp[1];
285
dp[2] = sp[2];
286
dp[3] = sp[3];
287
288
X += dX;
289
Y += dY;
290
}
291
}
292
293
return MLIB_SUCCESS;
294
}
295
296
/***************************************************************/
297
#ifdef _MSC_VER
298
/* Workaround for MSC optimizer bug (known affected versions
299
12.00.8168-12.00.8804). See bug 4893435 for details. */
300
#pragma optimize("gs", on)
301
#endif /* _MSC_VER */
302
303