srecord noeq Hi15ImageStreaks(Hi15Image inputImage) { // x values of streak ends new IntBuffer streakData; int[] lineStarts; run { var streakData = this.streakData; int w = inputImage.w(), h = inputImage.h(); lineStarts = new int[h]; short[] pixels = inputImage.pixels; int iPixel = 0; for y to h: { lineStarts[y] = streakData.size(); int lineEnd = iPixel+w; while (iPixel < lineEnd) { short color = pixels[iPixel]; do ++iPixel; while (iPixel < lineEnd && pixels[iPixel] == color); streakData.add(iPixel); } } } selfType runAndReturn() { run(); this; } int nStreaks() { ret streakData.size(); } int h() { ret lineStarts.length; } ItIt streaksAsRectsIterator() { ret iffNull(new IF0 { int iStreak; int x, y; public Rect get() { if (y >= h()) null; if (iStreak >= nStreaks()) null; if (y+1 < h && iStreak >= lineStarts[y+1]) { ++y; x = 0; } int x2 = streakData.get(iStreak++); Rect r = rect(x2, y, x2-x, 1); x = x2; ret r; } }); } }