static L<BWImage> unclusterImages(BWImage img) { int w = img.getWidth(), h = img.getHeight(); L<Int> bc = unclusterImages_findBlackCols(img); L<Int> br = unclusterImages_findBlackRows(img); if (!bc.contains(0) || !br.contains(0) || !bc.contains(w-1) || !br.contains(h-1)) null; new L<BWImage> images; for (int y = 1; y < l(br)-1; y++) for (int x = 1; x < l(bc)-1; x++) { int x1 = bc.get(x)+1, cw = bc.get(x+1)-x1; int y1 = br.get(y)+1, ch = br.get(y+1)-y1; images.add(img.clip(x1, y1, cw, ch)); } ret images; } static L<Int> unclusterImages_findBlackCols(BWImage img) { new L<Int> l; int w = img.getWidth(), h = img.getHeight(); outer: for (int x = 0; x < w; x++) { for (int y = 0; y < h; y++) if (img.getPixel(x, y) > 0.1f) continue outer; l.add(x); } ret l; } static L<Int> unclusterImages_findBlackRows(BWImage img) { new L<Int> l; int w = img.getWidth(), h = img.getHeight(); outer: for (int y = 0; y < h; y++) { for (int x = 0; x < w; x++) if (img.getPixel(x, y) > 0.1f) continue outer; l.add(y); } ret l; }
download show line numbers debug dex old transpilations
Travelled to 14 computer(s): aoiabmzegqzx, bhatertpkbcr, cbybwowwnfue, cfunsshuasjs, ddnzoavkxhuk, gwrvuhgaqvyk, ishqpsrjomds, lpdgvwnxivlt, mqqgnosmbjvj, pyentgdyhuwx, pzhvpgtvlbxg, tslmcundralx, tvejysmllsmz, vouqrxazstgt
No comments. add comment
Snippet ID: | #1004640 |
Snippet name: | unclusterImages |
Eternal ID of this version: | #1004640/1 |
Text MD5: | 3f07a8e4beda796e0a03f88b76d0f234 |
Author: | stefan |
Category: | javax / images |
Type: | JavaX fragment (include) |
Public (visible to everyone): | Yes |
Archived (hidden from active list): | No |
Created/modified: | 2016-08-24 17:26:02 |
Source code size: | 1165 bytes / 40 lines |
Pitched / IR pitched: | No / No |
Views / Downloads: | 571 / 551 |
Referenced in: | [show references] |