1 | // returns pair of x and y |
2 | static Pair<Float, Float> bwCentroid(BWImage img, bool dark) {
|
3 | int w = img.getWidth(), h = img.getHeight(); |
4 | double sumX = 0, sumY = 0; |
5 | double midX = (w-1)/2.0, midY = (h-1)/2.0; // optimized for odd image dimensions |
6 | for y to h: for x to w: {
|
7 | float weight = img.getPixel(x, y); |
8 | if (dark) weight = 1-weight; |
9 | sumX += weight*(x-midX); |
10 | sumY += weight*(y-midY); |
11 | } |
12 | double baseX = midX*h, baseY = midY*w; |
13 | ret new Pair((float) (midX+sumX/baseX), (float) (midY+sumY/baseY)); |
14 | } |
Began life as a copy of #1005814
download show line numbers debug dex old transpilations
Travelled to 14 computer(s): aoiabmzegqzx, bhatertpkbcr, cbybwowwnfue, cfunsshuasjs, gwrvuhgaqvyk, ishqpsrjomds, lpdgvwnxivlt, mqqgnosmbjvj, pyentgdyhuwx, pzhvpgtvlbxg, sawdedvomwva, tslmcundralx, tvejysmllsmz, vouqrxazstgt
No comments. add comment
| Snippet ID: | #1005817 |
| Snippet name: | bwCentroid - get centroid of dark or light pixels in BWImage |
| Eternal ID of this version: | #1005817/1 |
| Text MD5: | 2946ffee8aec0b1fb56a230021188c47 |
| Author: | stefan |
| Category: | javax / imaging |
| Type: | JavaX fragment (include) |
| Public (visible to everyone): | Yes |
| Archived (hidden from active list): | No |
| Created/modified: | 2016-12-10 15:46:45 |
| Source code size: | 536 bytes / 14 lines |
| Pitched / IR pitched: | No / No |
| Views / Downloads: | 757 / 826 |
| Referenced in: | [show references] |