PageRenderTime 57ms CodeModel.GetById 22ms RepoModel.GetById 0ms app.codeStats 1ms

/enhanced/java/branches/mrh/classlib/modules/awt/src/main/native/gl/shared/SurfaceDataStructure.cpp

https://bitbucket.org/varialus/harmony
C++ | 765 lines | 627 code | 112 blank | 26 comment | 104 complexity | 33de160c9f393ae388578ba36f9d2d68 MD5 | raw file
Possible License(s): Apache-2.0
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. /**
  18. * @author Igor V. Stolyarov
  19. */
  20. #include <stdlib.h>
  21. #include <stdlib.h>
  22. #include <memory.h>
  23. #include "SurfaceDataStructure.h"
  24. #include "org_apache_harmony_awt_gl_ImageSurface.h"
  25. #include "LUTTables.h"
  26. #ifdef _WIN32
  27. #include "GDIBlitter.h"
  28. #endif
  29. int parseMask(unsigned int mask, int *shift, int *maxVal){
  30. int bits = 0;
  31. *shift = 0;
  32. *maxVal = 0;
  33. if (mask != 0) {
  34. // Deleting final zeros
  35. while ((mask & 1) == 0) {
  36. mask >>= 1;
  37. (*shift)++;
  38. }
  39. *maxVal = mask;
  40. // Counting component bits
  41. while ((mask & 1) == 1) {
  42. mask >>= 1;
  43. bits++;
  44. }
  45. }
  46. return bits;
  47. }
  48. int getShift(unsigned int mask){
  49. int shift = 0;
  50. if (mask != 0) {
  51. while ((mask & 1) == 0) {
  52. mask >>= 1;
  53. shift++;
  54. }
  55. }
  56. return shift;
  57. }
  58. inline void updateCache
  59. (SURFACE_STRUCTURE *srcSurf, JNIEnv *env, jobject srcData, bool alphaPre, int x, int y, int width, int height){
  60. int src_stride, dst_stride, src_offset, dst_offset;
  61. int h = height;
  62. int w = width;
  63. void *bmpDataPtr = srcSurf->bmpData;
  64. void *srcDataPtr = env->GetPrimitiveArrayCritical((jarray)srcData, 0);
  65. switch(srcSurf->ss_type){
  66. case INT_RGB:
  67. {
  68. unsigned int *src, *dst;
  69. #ifdef unix
  70. unsigned int *s, *d;
  71. #endif
  72. src_stride = srcSurf->scanline_stride;
  73. dst_stride = srcSurf->width;
  74. src_offset = y * src_stride + x;
  75. dst_offset = y * dst_stride + x;
  76. src = (unsigned int *)srcDataPtr + src_offset;
  77. dst = (unsigned int *)bmpDataPtr + dst_offset;
  78. for(int _y = 0; _y < h; _y++, src += src_stride, dst += dst_stride){
  79. #ifdef _WIN32
  80. memcpy(dst, src, w * sizeof(int));
  81. #endif
  82. #ifdef unix
  83. s = src, d = dst;
  84. for(int _x = 0; _x < w; _x++, s++, d++){
  85. *d = 0xff000000 | *s;
  86. }
  87. #endif
  88. }
  89. }
  90. break;
  91. case INT_ARGB:
  92. {
  93. if(alphaPre){
  94. unsigned char *src, *s, *dst, *d, sa;
  95. src_stride = srcSurf->scanline_stride_byte;
  96. dst_stride = srcSurf->width << 2;
  97. src_offset = y * src_stride + ((x + w) << 2) - 1;
  98. dst_offset = y * dst_stride + ((x + w) << 2) - 1;
  99. src = (unsigned char *)srcDataPtr + src_offset;
  100. dst = (unsigned char *)bmpDataPtr + dst_offset;
  101. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  102. s = src;
  103. d = dst;
  104. for(int _x = w; _x > 0; _x--){
  105. sa = *s--;
  106. *d-- = sa;
  107. if(sa != 255){
  108. *d-- = MUL(sa, *s--);
  109. *d-- = MUL(sa, *s--);
  110. *d-- = MUL(sa, *s--);
  111. srcSurf->hasRealAlpha = true;
  112. }else{
  113. *d-- = *s--;
  114. *d-- = *s--;
  115. *d-- = *s--;
  116. }
  117. }
  118. }
  119. srcSurf->isAlphaPre = true;
  120. }else{
  121. unsigned int *src, *dst;
  122. src_stride = srcSurf->scanline_stride;
  123. dst_stride = srcSurf->width;
  124. src_offset = y * src_stride + x;
  125. dst_offset = y * dst_stride + x;
  126. src = (unsigned int *)srcDataPtr + src_offset;
  127. dst = (unsigned int *)bmpDataPtr + dst_offset;
  128. for(int _y = 0; _y < h; _y++, src += src_stride, dst += dst_stride){
  129. memcpy(dst, src, w * sizeof(int));
  130. }
  131. srcSurf->isAlphaPre = false;
  132. }
  133. }
  134. break;
  135. case INT_ARGB_PRE:
  136. {
  137. unsigned char *src, *s, *dst, *d, sa;
  138. src_stride = srcSurf->scanline_stride_byte;
  139. dst_stride = srcSurf->width << 2;
  140. src_offset = y * src_stride + ((x + w) << 2) - 1;
  141. dst_offset = y * dst_stride + ((x + w) << 2) - 1;
  142. src = (unsigned char *)srcDataPtr + src_offset;
  143. dst = (unsigned char *)bmpDataPtr + dst_offset;
  144. if(alphaPre){
  145. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  146. s = src;
  147. d = dst;
  148. for(int _x = w; _x > 0; _x--){
  149. sa = *s--;
  150. *d-- = sa;
  151. *d-- = *s--;
  152. *d-- = *s--;
  153. *d-- = *s--;
  154. if(sa != 255){
  155. srcSurf->hasRealAlpha = true;
  156. }
  157. }
  158. }
  159. srcSurf->isAlphaPre = true;
  160. }else{
  161. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  162. s = src;
  163. d = dst;
  164. for(int _x = w; _x > 0; _x--){
  165. sa = *s--;
  166. *d-- = sa;
  167. *d-- = DIV(sa, *s--);
  168. *d-- = DIV(sa, *s--);
  169. *d-- = DIV(sa, *s--);
  170. }
  171. }
  172. srcSurf->isAlphaPre = false;
  173. }
  174. }
  175. break;
  176. case INT_BGR:
  177. {
  178. unsigned char *src, *s, *dst, *d;
  179. src_stride = srcSurf->scanline_stride_byte;
  180. dst_stride = srcSurf->width << 2;
  181. src_offset = y * src_stride + ((x + w) << 2) - 1;
  182. dst_offset = y * dst_stride + ((x + w) << 2) - 1;
  183. src = (unsigned char *)srcDataPtr + src_offset;
  184. dst = (unsigned char *)bmpDataPtr + dst_offset;
  185. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  186. s = src;
  187. d = dst;
  188. for(int _x = w; _x > 0; _x--){
  189. *d = 255;
  190. s--;
  191. *(d - 3) = *s--;
  192. *(d - 2) = *s--;
  193. *(d - 1) = *s--;
  194. d -= 4;
  195. }
  196. }
  197. }
  198. break;
  199. case BYTE_BGR:
  200. {
  201. unsigned char *src, *s, *dst, *d;
  202. src_stride = srcSurf->scanline_stride_byte;
  203. dst_stride = srcSurf->width << 2;
  204. src_offset = y * src_stride + (x + w) * 3 - 1;
  205. dst_offset = y * dst_stride + ((x + w) << 2) - 1;
  206. src = (unsigned char *)srcDataPtr + src_offset;
  207. dst = (unsigned char *)bmpDataPtr + dst_offset;
  208. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  209. s = src;
  210. d = dst;
  211. for(int _x = w; _x > 0; _x--){
  212. *d-- = 255;
  213. *d-- = *s--;
  214. *d-- = *s--;
  215. *d-- = *s--;
  216. }
  217. }
  218. }
  219. break;
  220. case BYTE_ABGR:
  221. {
  222. unsigned char *src, *s, *dst, *d, a, r, g, b;
  223. src_stride = srcSurf->scanline_stride_byte;
  224. dst_stride = srcSurf->width << 2;
  225. src_offset = y * src_stride + ((x + w) << 2) - 1;
  226. dst_offset = y * dst_stride + ((x + w) << 2) - 1;
  227. src = (unsigned char *)srcDataPtr + src_offset;
  228. dst = (unsigned char *)bmpDataPtr + dst_offset;
  229. if(alphaPre){
  230. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  231. s = src;
  232. d = dst;
  233. for(int _x = w; _x > 0; _x--){
  234. r = *s--;
  235. g = *s--;
  236. b = *s--;
  237. a = *s--;
  238. *d-- = a;
  239. if(a != 255){
  240. *d-- = MUL(a, r);
  241. *d-- = MUL(a, g);
  242. *d-- = MUL(a, b);
  243. srcSurf->hasRealAlpha = true;
  244. }else{
  245. *d-- = r;
  246. *d-- = g;
  247. *d-- = b;
  248. }
  249. }
  250. }
  251. srcSurf->isAlphaPre = true;
  252. }else{
  253. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  254. s = src;
  255. d = dst;
  256. for(int _x = w; _x > 0; _x--){
  257. r = *s--;
  258. g = *s--;
  259. b = *s--;
  260. a = *s--;
  261. *d-- = a;
  262. *d-- = r;
  263. *d-- = g;
  264. *d-- = b;
  265. }
  266. }
  267. srcSurf->isAlphaPre = false;
  268. }
  269. }
  270. break;
  271. case BYTE_ABGR_PRE:
  272. {
  273. unsigned char *src, *s, *dst, *d, a, r, g, b;
  274. src_stride = srcSurf->scanline_stride_byte;
  275. dst_stride = srcSurf->width << 2;
  276. src_offset = y * src_stride + ((x + w) << 2) - 1;
  277. dst_offset = y * dst_stride + ((x + w) << 2) - 1;
  278. src = (unsigned char *)srcDataPtr + src_offset;
  279. dst = (unsigned char *)bmpDataPtr + dst_offset;
  280. if(alphaPre){
  281. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  282. s = src;
  283. d = dst;
  284. for(int _x = w; _x > 0; _x--){
  285. r = *s--;
  286. g = *s--;
  287. b = *s--;
  288. a = *s--;
  289. if(a != 255){
  290. srcSurf->hasRealAlpha = true;
  291. }
  292. *d-- = a;
  293. *d-- = r;
  294. *d-- = g;
  295. *d-- = b;
  296. }
  297. }
  298. srcSurf->isAlphaPre = true;
  299. }else{
  300. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  301. s = src;
  302. d = dst;
  303. for(int _x = w; _x > 0; _x--){
  304. r = *s--;
  305. g = *s--;
  306. b = *s--;
  307. a = *s--;
  308. *d-- = a;
  309. if(a != 255){
  310. *d-- = DIV(a, r);
  311. *d-- = DIV(a, g);
  312. *d-- = DIV(a, b);
  313. }else{
  314. *d-- = r;
  315. *d-- = g;
  316. *d-- = b;
  317. }
  318. }
  319. }
  320. srcSurf->isAlphaPre = false;
  321. }
  322. }
  323. break;
  324. case USHORT_555:
  325. case USHORT_565:
  326. {
  327. unsigned char *dst, *d;
  328. unsigned short *src, *s, pixel;
  329. unsigned int mr = srcSurf->max_red;
  330. unsigned int mg = srcSurf->max_green;
  331. unsigned int mb = srcSurf->max_red;
  332. unsigned int rm = srcSurf->red_mask;
  333. unsigned int gm = srcSurf->green_mask;
  334. unsigned int bm = srcSurf->blue_mask;
  335. unsigned int rs = srcSurf->red_sht;
  336. unsigned int gs = srcSurf->green_sht;
  337. unsigned int bs = srcSurf->blue_sht;
  338. src_stride = srcSurf->scanline_stride;
  339. dst_stride = srcSurf->width << 2;
  340. src_offset = y * src_stride + x + w - 1;
  341. dst_offset = y * dst_stride + ((x + w) << 2) - 1;
  342. src = (unsigned short *)srcDataPtr + src_offset;
  343. dst = (unsigned char *)bmpDataPtr + dst_offset;
  344. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  345. d = dst;
  346. s = src;
  347. for(int _x = w; _x > 0; _x--){
  348. pixel = *s--;
  349. *d-- = 255;
  350. *d-- = DIV(mb, ((pixel & rm) >> rs));
  351. *d-- = DIV(mg, ((pixel & gm) >> gs));
  352. *d-- = DIV(mr, ((pixel & bm) >> bs));
  353. }
  354. }
  355. }
  356. break;
  357. case USHORT_GRAY:
  358. {
  359. unsigned char *dst, *d, pixel;
  360. unsigned short *src, *s;
  361. src_stride = srcSurf->scanline_stride;
  362. dst_stride = srcSurf->width << 2;
  363. src_offset = y * src_stride + (x << 1);
  364. dst_offset = y * dst_stride + (x << 2);
  365. src = (unsigned short *)srcDataPtr + src_offset;
  366. dst = (unsigned char *)bmpDataPtr + dst_offset;
  367. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  368. s = src;
  369. d = dst;
  370. for(int _x = w; _x > 0; _x--){
  371. pixel = (unsigned char)(*s++ / 257);
  372. *d++ = pixel;
  373. *d++ = pixel;
  374. *d++ = pixel;
  375. *d++ = 255;
  376. }
  377. }
  378. }
  379. break;
  380. case BYTE_BINARY:
  381. {
  382. unsigned char *src, *s;
  383. unsigned int *dst, *d, pixel, bitnum, elem, shift, bitMask;
  384. unsigned int pixelBits = srcSurf->pixel_stride;
  385. int *cm = srcSurf->colormap;
  386. src_stride = srcSurf->scanline_stride;
  387. dst_stride = srcSurf->width;
  388. src_offset = y * src_stride;
  389. dst_offset = y * dst_stride + x;
  390. src = (unsigned char *)srcDataPtr + src_offset;
  391. dst = (unsigned int *)bmpDataPtr + dst_offset;
  392. for(int y = h; y > 0; y--, src += src_stride, dst += dst_stride){
  393. d = dst;
  394. for(int x = 0; x < w; x++){
  395. bitnum = x * pixelBits;
  396. s = src + bitnum / 8;
  397. elem = *s;
  398. shift = 8 - (bitnum & 7) - pixelBits;
  399. bitMask = (1 << pixelBits) - 1;
  400. pixel = (elem >> shift) & bitMask;
  401. *d++ = 0xff000000 | *(cm + pixel);
  402. }
  403. }
  404. }
  405. break;
  406. case BYTE_INDEXED:
  407. {
  408. int transparency = srcSurf->transparency;
  409. unsigned char *src, *s;
  410. unsigned int *dst, *d, pixel, r, g, b, a;
  411. int *cm = srcSurf->colormap;
  412. int tp = srcSurf->transparent_pixel;
  413. src_stride = srcSurf->scanline_stride;
  414. dst_stride = srcSurf->width;
  415. src_offset = y * src_stride + x + w - 1;
  416. dst_offset = y * dst_stride + x + w - 1;
  417. src = (unsigned char *)srcDataPtr + src_offset;
  418. dst = (unsigned int *)bmpDataPtr + dst_offset;
  419. if(transparency == GL_OPAQUE){
  420. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  421. s = src;
  422. d = dst;
  423. for(int _x = w; _x > 0; _x--){
  424. *d-- = 0xff000000 | *(cm + *s--);
  425. }
  426. }
  427. }else if(transparency == GL_BITMASK){
  428. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  429. s = src;
  430. d = dst;
  431. for(int _x = w; _x > 0; _x--){
  432. pixel = *s--;
  433. if(pixel != tp){
  434. *d-- = 0xff000000 | *(cm + pixel);
  435. }else{
  436. srcSurf->hasRealAlpha = true;
  437. *d-- = 0;
  438. }
  439. }
  440. }
  441. }else{
  442. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  443. s = src;
  444. d = dst;
  445. for(int _x = w; _x > 0; _x--){
  446. pixel = *(cm + *s--);
  447. a = (pixel >> 24) & 0xff;
  448. if(alphaPre){
  449. if(a == 255){
  450. *d-- = pixel;
  451. }else{
  452. r = (pixel >> 16) & 0xff;
  453. g = (pixel >> 8) & 0xff;
  454. b = pixel & 0xff;
  455. r = MUL(a, r);
  456. g = MUL(a, g);
  457. b = MUL(a, b);
  458. *d-- = (a << 24) | (r << 16) | (g << 8) | b;
  459. }
  460. srcSurf->isAlphaPre = true;
  461. }else{
  462. if(a == 0) *d-- = 0;
  463. else *d-- = pixel;
  464. srcSurf->isAlphaPre = false;
  465. }
  466. }
  467. }
  468. }
  469. }
  470. break;
  471. case BYTE_GRAY:
  472. {
  473. unsigned char *src, *s, *dst, *d, pixel;
  474. src_stride = srcSurf->scanline_stride;
  475. dst_stride = srcSurf->width << 2;
  476. src_offset = y * src_stride + x;
  477. dst_offset = y * dst_stride + (x << 2);
  478. src = (unsigned char *)srcDataPtr + src_offset;
  479. dst = (unsigned char *)bmpDataPtr + dst_offset;
  480. for(int _y = h; _y > 0; _y--, src += src_stride, dst += dst_stride){
  481. s = src;
  482. d = dst;
  483. for(int _x = w; _x > 0; _x--){
  484. pixel = *s++;
  485. *d++ = pixel;
  486. *d++ = pixel;
  487. *d++ = pixel;
  488. *d++ = 255;
  489. }
  490. }
  491. }
  492. break;
  493. }
  494. env->ReleasePrimitiveArrayCritical((jarray)srcData, srcDataPtr, 0);
  495. }
  496. /*
  497. * Class: org_apache_harmony_awt_gl_ImageSurface
  498. * Method: createSurfStruct
  499. * Signature: (IIIIIIIIII[I[II[IIZ[I[IIZZI)J
  500. */
  501. JNIEXPORT jlong JNICALL Java_org_apache_harmony_awt_gl_ImageSurface_createSurfStruct
  502. (JNIEnv * env, jobject obj, jint surfType, jint width, jint height, jint cmType,
  503. jint csType, jint smType, jint dataType, jint numComponents, jint pixelStride,
  504. jint scanlineStride, jintArray bits, jintArray masks, jint colorMapSize,
  505. jintArray colorMap, jint transpPixel, jboolean isGrayPalette, jintArray bankIndeces,
  506. jintArray bandOffsets, jint offset, jboolean hasAlpha, jboolean isAlphaPre,
  507. jint transparency){
  508. SURFACE_STRUCTURE *surf = (SURFACE_STRUCTURE *)calloc(sizeof(SURFACE_STRUCTURE), 1);
  509. if(surf != NULL){
  510. surf->ss_type = surfType;
  511. surf->width = width;
  512. surf->height = height;
  513. surf->cm_type = cmType;
  514. surf->cs_type = csType;
  515. surf->data_type = dataType;
  516. surf->num_components = numComponents;
  517. surf->pixel_stride = pixelStride;
  518. surf->scanline_stride = scanlineStride;
  519. surf->offset = offset;
  520. surf->has_alpha = hasAlpha;
  521. surf->isAlphaPre = isAlphaPre != 0;
  522. surf->transparency = transparency;
  523. if(dataType == TYPE_BYTE){
  524. surf->scanline_stride_byte = scanlineStride;
  525. }else if(dataType == TYPE_USHORT){
  526. surf->scanline_stride_byte = scanlineStride << 1;
  527. }else if(dataType == TYPE_INT){
  528. surf->scanline_stride_byte = scanlineStride << 2;
  529. }
  530. void *p;
  531. int *s, *d;
  532. switch(cmType){
  533. case DIRECT_CM:
  534. surf->bits = (int *)malloc(surf->num_components * sizeof(int));
  535. p = env->GetPrimitiveArrayCritical(bits, 0);
  536. d = surf->bits;
  537. s = (int *)p;
  538. for(int i = 0; i < numComponents; i++){
  539. *d++ = *s++;
  540. }
  541. env->ReleasePrimitiveArrayCritical(bits, p, 0);
  542. p = env->GetPrimitiveArrayCritical(masks, 0);
  543. s = (int *)p;
  544. surf->red_mask = *s++;
  545. surf->green_mask = *s++;
  546. surf->blue_mask = *s++;
  547. if(hasAlpha){
  548. surf->alpha_mask = *s;
  549. }
  550. env->ReleasePrimitiveArrayCritical(masks, p, 0);
  551. surf->red_sht = getShift(surf->red_mask);
  552. surf->max_red = (1 << surf->bits[0]) - 1;
  553. surf->green_sht = getShift(surf->green_mask);
  554. surf->max_green = (1 << surf->bits[1]) - 1;
  555. surf->blue_sht = getShift(surf->blue_mask);
  556. surf->max_blue = (1 << surf->bits[2]) - 1;
  557. if(hasAlpha){
  558. surf->alpha_sht = getShift(surf->alpha_mask);
  559. surf->max_alpha = ( 1 << surf->bits[3]) - 1;
  560. }
  561. break;
  562. case INDEX_CM:
  563. surf->colormap_size = colorMapSize;
  564. surf->transparent_pixel = transpPixel;
  565. surf->isGrayPallete = isGrayPalette;
  566. surf->colormap = (int *)malloc(colorMapSize * sizeof(int));
  567. p = env->GetPrimitiveArrayCritical(colorMap, 0);
  568. memcpy(surf->colormap, p, colorMapSize * sizeof(int));
  569. env->ReleasePrimitiveArrayCritical(colorMap, p, 0);
  570. break;
  571. case COMPONENT_CM:
  572. surf->bank_indexes = (int *)malloc(numComponents * sizeof(int));
  573. surf->band_offsets = (int *)malloc(numComponents * sizeof(int));
  574. p = env->GetPrimitiveArrayCritical(bankIndeces, 0);
  575. memcpy((void *)surf->bank_indexes, p, numComponents * sizeof(int));
  576. env->ReleasePrimitiveArrayCritical(bankIndeces, p, 0);
  577. p = env->GetPrimitiveArrayCritical(bandOffsets, 0);
  578. memcpy((void *)surf->band_offsets, p, numComponents * sizeof(int));
  579. env->ReleasePrimitiveArrayCritical(bandOffsets, p, 0);
  580. break;
  581. }
  582. surf->invalidated = true;
  583. surf->bmp_byte_stride = surf->width << 2;
  584. #ifdef _WIN32
  585. surf->bmpInfo.bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
  586. surf->bmpInfo.bmiHeader.biWidth = surf->width;
  587. surf->bmpInfo.bmiHeader.biHeight = -surf->height;
  588. surf->bmpInfo.bmiHeader.biPlanes = 1;
  589. surf->bmpInfo.bmiHeader.biBitCount = 32;
  590. surf->bmpInfo.bmiHeader.biSizeImage = surf->bmp_byte_stride * surf->height;
  591. surf->bmpInfo.bmiHeader.biCompression = BI_BITFIELDS;
  592. DWORD *colors = (DWORD *)surf->bmpInfo.bmiColors;
  593. colors[0] = 0xff0000;
  594. colors[1] = 0xff00;
  595. colors[2] = 0xff;
  596. HDC dc = GetDC(NULL);
  597. surf->srcDC = CreateCompatibleDC(NULL);
  598. if(GetDeviceCaps(dc, BITSPIXEL) != 32) {
  599. surf->bitmap = CreateDIBSection(NULL, (BITMAPINFO *)&surf->bmpInfo, DIB_RGB_COLORS, &surf->bmpData, NULL, 0);
  600. } else {
  601. surf->bitmap = CreateCompatibleBitmap(dc, surf->width, surf->height);
  602. surf->bmpData = malloc(surf->bmp_byte_stride * surf->height);
  603. surf->isTrueColor = TRUE;
  604. }
  605. ReleaseDC(NULL, dc);
  606. if(surf->srcDC != NULL && surf->bitmap != NULL){
  607. SelectObject(surf->srcDC, surf->bitmap);
  608. }
  609. surf->isAlphaPre = true;
  610. #else
  611. surf->bmpData = malloc(surf->bmp_byte_stride * surf->height);
  612. #endif
  613. }
  614. return (jlong)surf;
  615. }
  616. JNIEXPORT jlong JNICALL Java_org_apache_harmony_awt_gl_ImageSurface_updateCache
  617. (JNIEnv *env, jobject obj, jlong ptr, jobject data, jboolean alphaPre){
  618. SURFACE_STRUCTURE *surf = (SURFACE_STRUCTURE *)ptr;
  619. jlong cachePtr = 0;
  620. if(surf != NULL){
  621. updateCache(surf, env, data, alphaPre != 0, 0, 0, surf->width, surf->height);
  622. cachePtr = (jlong)surf->bmpData;
  623. }
  624. return cachePtr;
  625. }
  626. JNIEXPORT void JNICALL Java_org_apache_harmony_awt_gl_ImageSurface_dispose
  627. (JNIEnv *env, jobject obj, jlong ptr){
  628. SURFACE_STRUCTURE *surf = (SURFACE_STRUCTURE *)ptr;
  629. if(surf != NULL){
  630. if(surf->bits) free(surf->bits);
  631. if(surf->colormap) free(surf->colormap);
  632. if(surf->bank_indexes) free(surf->bank_indexes);
  633. if(surf->band_offsets) free(surf->band_offsets);
  634. #ifdef _WIN32
  635. if(surf->isTrueColor){
  636. if(surf->bmpData) free(surf->bmpData);
  637. }
  638. if(surf->bitmap) DeleteObject(surf->bitmap);
  639. if(surf->srcDC) DeleteDC(surf->srcDC);
  640. #else
  641. if(surf->bmpData) free(surf->bmpData);
  642. #endif
  643. free(surf);
  644. }
  645. }
  646. JNIEXPORT void JNICALL Java_org_apache_harmony_awt_gl_ImageSurface_setImageSize
  647. (JNIEnv *env, jobject obj, jlong ptr, jint width, jint height) {
  648. SURFACE_STRUCTURE *surf = (SURFACE_STRUCTURE *)ptr;
  649. surf->scanline_stride = surf->scanline_stride / surf->width * width;
  650. surf->scanline_stride_byte = surf->scanline_stride_byte / surf->width * width;
  651. surf->width = width;
  652. surf->height = height;
  653. }