當前位置: 首頁>>代碼示例>>Java>>正文


Java FloodFiller類代碼示例

本文整理匯總了Java中ij.process.FloodFiller的典型用法代碼示例。如果您正苦於以下問題:Java FloodFiller類的具體用法?Java FloodFiller怎麽用?Java FloodFiller使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


FloodFiller類屬於ij.process包,在下文中一共展示了FloodFiller類的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: fill

import ij.process.FloodFiller; //導入依賴的package包/類
public void fill(ImageProcessor ip, int foreground, int background) {
	int width = ip.getWidth();
	int height = ip.getHeight();
	FloodFiller ff = new FloodFiller(ip);
	ip.setColor(127);
	for (int y=0; y<height; y++) {
		if (ip.getPixel(0,y)==background) ff.fill(0, y);
		if (ip.getPixel(width-1,y)==background) ff.fill(width-1, y);
	}
	for (int x=0; x<width; x++){
		if (ip.getPixel(x,0)==background) ff.fill(x, 0);
		if (ip.getPixel(x,height-1)==background) ff.fill(x, height-1);
	}
	byte[] pixels = (byte[])ip.getPixels();
	int n = width*height;
	for (int i=0; i<n; i++) {
		if (pixels[i]==127)
			pixels[i] = (byte)background;
		else
			pixels[i] = (byte)foreground;
	}
}
 
開發者ID:mstritt,項目名稱:orbit-image-analysis,代碼行數:23,代碼來源:BinaryOrbit.java

示例2: fillHoles

import ij.process.FloodFiller; //導入依賴的package包/類
/**
 * Fill holes in a binary image.
 * 
 * Assumes 255 is foreground, 0 is background.
 * 
 * Based on code in ImageJ's Binary class.
 * 
 * @param bp
 * @return
 */
public static void fillHoles(ByteProcessor bp) {
	int w = bp.getWidth();
	int h = bp.getHeight();
	FloodFiller ff = new FloodFiller(bp);
	bp.setValue(127);
	for (int x = 0; x < w; x++) {
		if (bp.getPixel(x, 0) == 0)
			ff.fill8(x, 0);
		if (bp.getPixel(x, h-1) == 0)
			ff.fill8(x, h-1);
	}
	for (int y = 0; y < h; y++) {
		if (bp.getPixel(0, y) == 0)
			ff.fill8(0, y);
		if (bp.getPixel(w-1, y) == 0)
			ff.fill8(w-1, y);
	}
	for (int i = 0; i < w*h; i++) {
		if (bp.get(i) == 127)
			bp.set(i, 0);
		else
			bp.set(i, 255);
	}
}
 
開發者ID:qupath,項目名稱:qupath,代碼行數:35,代碼來源:ROILabeling.java

示例3: labelImage

import ij.process.FloodFiller; //導入依賴的package包/類
public static ShortProcessor labelImage(ImageProcessor ip, float threshold, boolean conn8) {
	int w = ip.getWidth();
	int h = ip.getHeight();
	short shortMax = (short)65535;
	ShortProcessor sp = new ShortProcessor(w, h);
	short[] pxShort = (short[])sp.getPixels();
	for (int i = 0; i < w*h; i++) {
		if (ip.getf(i) > threshold)
			pxShort[i] = shortMax;
	}
	// Loop through and flood fill
	FloodFiller ff = new FloodFiller(sp);
	double label = 0;
	for (int i = 0; i < pxShort.length; i++) {
		if (pxShort[i] == shortMax) {
			label++;
			sp.setValue(label);
			if (conn8)
				ff.fill8(i % w, i / w);
			else
				ff.fill(i % w, i / w);
		}
	}
	sp.setMinAndMax(0, label);
	return sp;
}
 
開發者ID:qupath,項目名稱:qupath,代碼行數:27,代碼來源:ROILabeling.java

示例4: fill

import ij.process.FloodFiller; //導入依賴的package包/類
/**
 * Fill the image processor closed loops. Only fill background regions defined by the Laplacian image.
 * 
 * @param maskIp
 *            The mask image
 * @param laplacianIp
 *            The original image laplacian
 */
void fill(ImageProcessor maskIp, ImageProcessor laplacianIp)
{
	// TODO - Check the fill option is working ... 

	// Adapted from ij.plugin.binary.Binary.fill(...)
	int background = NONE;
	int width = maskIp.getWidth();
	int height = maskIp.getHeight();
	FloodFiller ff = new FloodFiller(maskIp);
	maskIp.setColor(FILL);
	for (int y = 0; y < height; y++)
	{
		if (maskIp.get(0, y) == background && laplacianIp.get(0, y) < 0)
			ff.fill(0, y);
		if (maskIp.get(width - 1, y) == background && laplacianIp.get(width - 1, y) < 0)
			ff.fill(width - 1, y);
	}
	for (int x = 0; x < width; x++)
	{
		if (maskIp.get(x, 0) == background && laplacianIp.get(x, 0) < 0)
			ff.fill(x, 0);
		if (maskIp.get(x, height - 1) == background && laplacianIp.get(x, height - 1) < 0)
			ff.fill(x, height - 1);
	}

	// Why is the fill reversed?
	//		byte[] pixels = (byte[]) maskIp.getPixels();
	//		int n = width * height;
	//		for (int i = 0; i < n; i++)
	//		{
	//			if (pixels[i] == FILL)
	//				pixels[i] = NONE;
	//			else
	//				pixels[i] = FILL;
	//		}
}
 
開發者ID:aherbert,項目名稱:GDSC,代碼行數:45,代碼來源:EdgeMask.java


注:本文中的ij.process.FloodFiller類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。