gpt4 book ai didi

bufferedimage - 使用 IndexColorModel 将光栅转换为 BufferedImage

转载 作者:行者123 更新时间:2023-12-04 05:32:09 27 4
gpt4 key购买 nike

我正在尝试使用 ImageIO 从 DICOM 文件中获取的只有 一个波段 的光栅显示图像。我不想使用 ImageIO 直接读取缓冲图像,因为我需要文件中的真实值(使用 ImageIO 直接获得的 BufferedImage 中包含的栅格总是有点不同,并标准化为 (0-255))。

我使用以下代码获取栅格:

Iterator<ImageReader> iter = ImageIO.getImageReadersByFormatName("DICOM");
ImageReader reader = iter.next();
DicomImageReadParam param = (DicomImageReadParam) reader.getDefaultReadParam();
ImageInputStream iis = ImageIO.createImageInputStream(dicomFile);
reader.setInput(iis, true);
Raster raster = reader.readRaster(0, param);

然后,将其转换为具有自定义 IndexColorModel 的 BufferedImage:

IndexColorModel colModel = grayColorModel(window, level);
BufferedImage buffered = new BufferedImage(colModel, (WritableRaster) raster, colModel.isAlphaPremultiplied(), null);

使用以下函数构建 IndexColorModel:

public IndexColorModel grayColorModel(int window, float level) {
window = window;
byte[] r = new byte[window];
byte[] g = new byte[window];
byte[] b = new byte[window];

for (int i = 0; i < window; i++) {
int val = (int) Math.round((255 - level) * 2 * i / window + 2 * level - 255);
if (val > 255) {
val = 255;
}
if (val < 0) {
val = 0;
}
r[ i] = (byte) val;
g[ i] = (byte) val;
b[ i] = (byte) val;
}

return (new IndexColorModel(**NR OF BITS**, window, r, g, b));
}

我遇到的问题与将信息从只有一个 channel 的光栅链接到 IndexColorModel 有某种关系,IndexColorModel 有 3 个。当我在位数中使用 8 时,数据类型根本不匹配,我得到以下错误:

java.lang.IllegalArgumentException: Raster ShortInterleavedRaster: width = 512 height = 512 #numDataElements 1 is incompatible with ColorModel IndexColorModel: #pixelBits = 8 numComponents = 3 color space = java.awt.color.ICC_ColorSpace@28ec9a1a transparency = 1 transIndex   = -1 has alpha = false isAlphaPre = false
at java.awt.image.BufferedImage.<init>(BufferedImage.java:630)

当我使用大于 8 的数字时,我没有得到错误,但呈现的图像没有正确的强度。最高值和最低值仅以黑色显示。

我看到问题出在数据类型和 channel 数量上,但我在四处盘旋,但我不知道 Raster 如何使用 IndexColorModel 以及如何使它们兼容。

了解这个问题后,我什至可以更自由地根据光栅中的像素值创建其他色标。

谁有这方面的经验?

谢谢

最佳答案

刚刚解决了。唯一的大问题是 indexcolormodel 需要足够大才能映射所有值。如果栅格包含的某个值大于映射值数组的大小,则颜色模型仅返回 0 并且图像上有黑点而不是白点。然后你就得到最大值并使颜色图足够大。我希望这可以防止其他人在这么简单的事情上浪费时间......

鉴于此,IndexColorModel 的最终代码如下所示:

public IndexColorModel grayColorModel(int window, float level, int maxval) {
int length = window;
if (maxval > window) {
length = maxval;
}

byte[] r = new byte[length];
byte[] g = new byte[length];
byte[] b = new byte[length];

for (int i = 0; i < length; i++) {
int val = Math.round((255 / (float) window) * ((float) i - level + (float) window * 0.5f));
if (val > 255) {
val = 255;
}
if (val < 0) {
val = 0;
}
r[ i] = (byte) val;
g[ i] = (byte) val;
b[ i] = (byte) val;
}
return (new IndexColorModel(16, length, r, g, b));
}

关于bufferedimage - 使用 IndexColorModel 将光栅转换为 BufferedImage,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23043978/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com