band偏移量 java_Java Band.setScalingOffset方法代码示例

import org.esa.snap.core.datamodel.Band; //导入方法依赖的package包/类

@Override

protected void addBands(Product product, SpotDimapMetadata componentMetadata, int componentIndex) {

String[] bandNames = componentMetadata.getBandNames();

String[] bandUnits = componentMetadata.getBandUnits();

int width, height, currentW, currentH;

width = product.getSceneRasterWidth();

height = product.getSceneRasterHeight();

currentW = componentMetadata.getRasterWidth();

currentH = componentMetadata.getRasterHeight();

if (width == currentW && height == currentH) {

try {

if (SpotConstants.DIMAP.equals(componentMetadata.getFormatName())) {

String[] fileNames = componentMetadata.getRasterFileNames();

if (fileNames == null || fileNames.length == 0) {

throw new InvalidMetadataException("No raster file found in metadata");

}

String rasterFileName = componentMetadata.getPath().toLowerCase().replace(componentMetadata.getFileName().toLowerCase(), fileNames[0].toLowerCase());

File rasterFile = productDirectory.getFile(rasterFileName);

GeoTiffProductReader tiffReader = new GeoTiffReaderEx(getReaderPlugIn());

logger.info("Read product nodes");

Product tiffProduct = tiffReader.readProductNodes(rasterFile, null);

if (tiffProduct != null) {

if (product == null) {

product = createProduct(tiffProduct.getSceneRasterWidth(), tiffProduct.getSceneRasterHeight(), wrappingMetadata.getComponentMetadata(0));

}

MetadataElement tiffMetadata = tiffProduct.getMetadataRoot();

if (tiffMetadata != null) {

XmlMetadata.CopyChildElements(tiffMetadata, product.getMetadataRoot());

}

tiffProduct.transferGeoCodingTo(product, null);

product.setPreferredTileSize(tiffProduct.getPreferredTileSize());

int numBands = tiffProduct.getNumBands();

String bandPrefix = "";

logger.info("Read bands");

if (wrappingMetadata.hasMultipleComponents()) {

bandPrefix = "scene_" + String.valueOf(componentIndex) + "_";

String groupPattern = "";

for (int idx = 0; idx < wrappingMetadata.getNumComponents(); idx++) {

groupPattern += "scene_" + String.valueOf(idx) + ":";

}

groupPattern = groupPattern.substring(0, groupPattern.length() - 1);

product.setAutoGrouping(groupPattern);

}

for (int idx = 0; idx < numBands; idx++) {

Band srcBand = tiffProduct.getBandAt(idx);

String bandName = bandPrefix + (idx < bandNames.length ? bandNames[idx] : SpotConstants.DEFAULT_BAND_NAME_PREFIX + idx);

Band targetBand = new ColorPaletteBand(bandName, srcBand.getDataType(), product.getSceneRasterWidth(), product.getSceneRasterHeight(), this.colorPaletteFilePath);

targetBand.setNoDataValue(componentMetadata.getNoDataValue() > -1 ? componentMetadata.getNoDataValue() : srcBand.getNoDataValue());

targetBand.setNoDataValueUsed((componentMetadata.getNoDataValue() > -1));

targetBand.setSpectralWavelength(componentMetadata.getWavelength(idx) > 0 ? componentMetadata.getWavelength(idx) : srcBand.getSpectralWavelength());

targetBand.setSpectralBandwidth(componentMetadata.getBandwidth(idx) > 0 ? componentMetadata.getBandwidth(idx) : srcBand.getSpectralBandwidth());

targetBand.setScalingFactor(srcBand.getScalingFactor());

targetBand.setScalingOffset(srcBand.getScalingOffset());

targetBand.setSolarFlux(srcBand.getSolarFlux());

targetBand.setUnit(srcBand.getUnit() != null ? srcBand.getUnit() : bandUnits[idx]);

targetBand.setSampleCoding(srcBand.getSampleCoding());

targetBand.setImageInfo(srcBand.getImageInfo());

targetBand.setSpectralBandIndex(srcBand.getSpectralBandIndex());

targetBand.setDescription(bandName);

product.addBand(targetBand);

readBandStatistics(targetBand, idx, componentMetadata);

bandMap.put(targetBand, srcBand);

}

}

} else {

logger.warning(String.format("Component product %s is not in DIMAP format!", componentMetadata.getProductName()));

}

} catch (IOException ioEx) {

logger.severe("Error while reading component: " + ioEx.getMessage());

}

} else {

logger.warning(String.format("Cannot add component product %s due to raster size [Found: %d x %d pixels, Expected: %d x %d pixels]",

componentMetadata.getProductName(), currentW, currentH, width, height));

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值