热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

importorg.esa.snap.core.datamodel.Band;导入方法依赖的package包类OverrideprotectedvoidaddBands(Produ

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

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

}

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

product.setAutoGrouping(groupPattern);

}

for (int idx = 0; idx

Band srcBand = tiffProduct.getBandAt(idx);

String bandName = bandPrefix + (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));

}

}



推荐阅读
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • 本文介绍了使用readlink命令获取文件的完整路径的简单方法,并提供了一个示例命令来打印文件的完整路径。共有28种解决方案可供选择。 ... [详细]
  • 本文整理了Java中org.apache.solr.common.SolrDocument.setField()方法的一些代码示例,展示了SolrDocum ... [详细]
  • 感谢大家对IT十八掌大数据的支持,今天的作业如下:1.实践PreparedStament的CRUD操作。2.对比Statement和PreparedStatement的大批量操作耗时?(1 ... [详细]
  • importjava.util.ArrayList;publicclassPageIndex{privateintpageSize;每页要显示的行privateintpageNum ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • JAVA调用存储过程CallableStatement对象的方法及使用示例
    本文介绍了使用JAVA调用存储过程CallableStatement对象的方法,包括创建CallableStatement对象、传入IN参数、注册OUT参数、传入INOUT参数、检索结果和OUT参数、处理NULL值等。通过示例代码演示了具体的调用过程。 ... [详细]
author-avatar
手机用户2602922383_687
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有