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


Java WritableRaster.setSample方法代碼示例

本文整理匯總了Java中java.awt.image.WritableRaster.setSample方法的典型用法代碼示例。如果您正苦於以下問題:Java WritableRaster.setSample方法的具體用法?Java WritableRaster.setSample怎麽用?Java WritableRaster.setSample使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.awt.image.WritableRaster的用法示例。


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

示例1: createOverview

import java.awt.image.WritableRaster; //導入方法依賴的package包/類
/**
 * create a quicklook image from the GeoImageReader
 * @param gir the source image
 * @param width the output width
 * @param height the output height
 * @return a BufferedImage representing the quicklook
 */
public static BufferedImage createOverview(GeoImageReader gir, int width, int height,int band){
    int nPass=gir.getHeight()/Constant.GEOIMAGE_TILE_SIZE;
    int xstep=gir.getWidth()/width;
    int ystep=gir.getHeight()/height;
    width=gir.getWidth()/xstep;
    height= gir.getHeight()/ystep;
    BufferedImage out=new BufferedImage(width,height, BufferedImage.TYPE_USHORT_GRAY);
    WritableRaster raster=out.getRaster();
    for(int i=0;i<nPass;i++){
        int[] t=gir.readTile(0, i*Constant.GEOIMAGE_TILE_SIZE, gir.getWidth(), Constant.GEOIMAGE_TILE_SIZE,band);
        for(int x=0;x<width;x++){
            for(int y=i*height/nPass;y<(i+1)*height/nPass;y++){
                raster.setSample(x, y, 0, t[x*xstep*(y-i*height/nPass)*ystep]);
            }
        }
    }
    return out;
}
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:26,代碼來源:GeoImageUtils.java

示例2: output

import java.awt.image.WritableRaster; //導入方法依賴的package包/類
public void output(File paramFile)
{
  BufferedImage localBufferedImage = new BufferedImage(width, height, 10);
  WritableRaster localWritableRaster = localBufferedImage.getRaster();
  
  int i = 0;
  if (i >= height) {
    ImageIO.write(localBufferedImage, "png", paramFile);
  } else {
    for (int j = 0;; j++)
    {
      if (j >= width)
      {
        i++; break;
      }
      localWritableRaster.setSample(j, i, 0, data[(i * height + j)]);
    }
  }
}
 
開發者ID:adnanmitf09,項目名稱:Rubus,代碼行數:20,代碼來源:Mandelbrot.java

示例3: getIndexedImage

import java.awt.image.WritableRaster; //導入方法依賴的package包/類
protected RenderedImage getIndexedImage() {
    IndexColorModel icm = getIndexColorModel();

    BufferedImage dst =
        new BufferedImage(src.getWidth(), src.getHeight(),
                          BufferedImage.TYPE_BYTE_INDEXED, icm);

    WritableRaster wr = dst.getRaster();
    for (int y =0; y < dst.getHeight(); y++) {
        for (int x = 0; x < dst.getWidth(); x++) {
            Color aColor = getSrcColor(x,y);
            wr.setSample(x, y, 0, findColorIndex(root, aColor));
        }
    }

    return dst;
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:18,代碼來源:PaletteBuilder.java

示例4: createIndexedImage

import java.awt.image.WritableRaster; //導入方法依賴的package包/類
protected static BufferedImage createIndexedImage(int w, int h,
                                                  IndexColorModel icm)
{
    BufferedImage img = new BufferedImage(w, h,
                                          BufferedImage.TYPE_BYTE_INDEXED,
                                          icm);

    int mapSize = icm.getMapSize();
    int width = w / mapSize;

    WritableRaster wr = img.getRaster();
    for (int i = 0; i < mapSize; i++) {
        for (int y = 0; y < h; y++) {
            for (int x = 0; x < width; x++) {
                wr.setSample(i * width + x, y, 0, i);
            }
        }
    }
    return img;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:21,代碼來源:TransparencyTest.java

示例5: output

import java.awt.image.WritableRaster; //導入方法依賴的package包/類
public void output(File out, short data[]) throws IOException {
	BufferedImage img = new BufferedImage(width, height, BufferedImage.TYPE_BYTE_GRAY);
	WritableRaster r = img.getRaster();

	for (int y = 0; y < height; y++) {
		for (int x = 0; x < width; x++) {
			// System.out.print(" "+x+","+y);
			r.setSample(x, y, 0, data[y * height + x]);
		}
		// System.out.println();
	}

	ImageIO.write(img, "png", out);
}
 
開發者ID:adnanmitf09,項目名稱:Rubus,代碼行數:15,代碼來源:Mandelbrot.java

示例6: output

import java.awt.image.WritableRaster; //導入方法依賴的package包/類
@Ignore
public void output(File out) throws IOException {
	BufferedImage img = new BufferedImage(width, height, BufferedImage.TYPE_BYTE_GRAY);
	WritableRaster r = img.getRaster();

	for(int y = 0; y < height; y++) {
		for(int x = 0; x < width; x++) {
			r.setSample(x, y, 0, data[y * height + x]);
		}
	}

	ImageIO.write(img, "png", out);
}
 
開發者ID:adnanmitf09,項目名稱:Rubus,代碼行數:14,代碼來源:Mandelbrot.java

示例7: propertyChange

import java.awt.image.WritableRaster; //導入方法依賴的package包/類
@Override
    synchronized public void propertyChange(PropertyChangeEvent evt) {
        if ((aviOutputStream != null && isWriteEnabled())
                && (evt.getPropertyName() == AEFrameChipRenderer.EVENT_NEW_FRAME_AVAILBLE)
                && !chip.getAeViewer().isPaused()) {
            FloatBuffer frame = ((AEFrameChipRenderer)chip.getRenderer()).getPixmap();

            BufferedImage bufferedImage = new BufferedImage(chip.getSizeX(), chip.getSizeY(), BufferedImage.TYPE_3BYTE_BGR);
            WritableRaster raster = bufferedImage.getRaster();
            int sx = chip.getSizeX(), sy = chip.getSizeY();
            for (int y = 0; y < sy; y++) {
                for (int x = 0; x < sx; x++) {
                    int k = renderer.getPixMapIndex(x, y);
//                    bufferedImage.setRGB(x, y, (int) (frame[k] * 1024));
                    int yy = sy - y - 1;
                    int r = (int) (frame.get(k) * 255); // must flip image vertially according to java convention that image starts at upper left
                    int g = (int) (frame.get(k+1) * 255); // must flip image vertially according to java convention that image starts at upper left
                    int b = (int) (frame.get(k+2) * 255); // must flip image vertially according to java convention that image starts at upper left
                    raster.setSample(x, yy, 0, r);
                    raster.setSample(x, yy, 1, g);
                    raster.setSample(x, yy, 2, b);
                }
            }
            try {
                aviOutputStream.writeFrame(bufferedImage);
                int timestamp = renderer.getTimestampFrameEnd();
                writeTimecode(timestamp);
                incrementFramecountAndMaybeCloseOutput();

            } catch (IOException ex) {
                Logger.getLogger(DavisFrameAviWriter.class.getName()).log(Level.SEVERE, null, ex);
            }
        } else if (evt.getPropertyName() == AEInputStream.EVENT_REWIND) {
            doCloseFile();
        }
    }
 
開發者ID:SensorsINI,項目名稱:jaer,代碼行數:37,代碼來源:DavisFrameAviWriter.java

示例8: reformatDiscontiguousData

import java.awt.image.WritableRaster; //導入方法依賴的package包/類
/**
 * Reformats bit-discontiguous data into the {@code DataBuffer}
 * of the supplied {@code WritableRaster}.
 */
private static void reformatDiscontiguousData(byte[] buf,
                                              int[] bitsPerSample,
                                              int stride,
                                              int w,
                                              int h,
                                              WritableRaster raster)
    throws IOException {

    // Get SampleModel info.
    SampleModel sm = raster.getSampleModel();
    int numBands = sm.getNumBands();

    // Initialize input stream.
    ByteArrayInputStream is = new ByteArrayInputStream(buf);
    ImageInputStream iis = new MemoryCacheImageInputStream(is);

    // Reformat.
    long iisPosition = 0L;
    int y = raster.getMinY();
    for(int j = 0; j < h; j++, y++) {
        iis.seek(iisPosition);
        int x = raster.getMinX();
        for(int i = 0; i < w; i++, x++) {
            for(int b = 0; b < numBands; b++) {
                long bits = iis.readBits(bitsPerSample[b]);
                raster.setSample(x, y, b, (int)bits);
            }
        }
        iisPosition += stride;
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:36,代碼來源:TIFFDecompressor.java


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