Utilities----im提供的一些工具类

①、读取图片文件信息---Info类

我们之前的做法:

op.format("width:%w,height:%h,path:%d%f,size:%b%[EXIF:DateTimeOriginal]");

IdentifyCmd identifyCmd = new IdentifyCmd(useGM);

使用工具类Info:

Info imageInfo = new Info(filename,true);
System.out.println("Format: " + imageInfo.getImageFormat());
System.out.println("Width: " + imageInfo.getImageWidth());
System.out.println("Height: " + imageInfo.getImageHeight());
System.out.println("Geometry: " + imageInfo.getImageGeometry());
System.out.println("Depth: " + imageInfo.getImageDepth());
System.out.println("Class: " + imageInfo.getImageClass());

第二个参数true,表示只获取图片的基本信息。

***这个工具类,在1.3.0版本之前,方法实现有问题。针对TIF和GIF图片,

imageInfo.getImageWidth()  返回的是第一帧的图片宽度(原文是first scene)
这个问题我也不懂,只是写出来下,大家都注意下,详细的还是看文档吧。


②、读取某个目录下所有指定后缀的图片文件---FilenameLoader类
你还在用这种批量图片处理方式么?
public void resizeImages(String... pImageNames)
恭喜你,out了。嘿嘿,开玩笑^-^
让我们来看下新的方法:
ExtensionFilter filter = new ExtensionFilter("jpg");	//指定后缀
filter.setRecursion(true); //递归扫描
filter.ignoreDotDirs(true); //忽略那些带点的隐藏目录(此处是个人说法,看到过,Android手机里很多这目录,但是不懂到底怎样命名)
FilenameLoader loader = new FilenameLoader(filter);
List<String> files = loader.loadFilenames(mydir); //mydir文件夹路径
这个类在API文档中有详细介绍。


③、既然有批量转换,我们也需要命令这一大堆目标文件的名称---FilenamePatternResolver类
// define operation and command
IMOperation op = new IMOperation();
op.addImage(); // input-file
op.addImage(); // output-file
ConvertCmd cmd = new ConvertCmd(); // load files
ExtensionFilter filter = new ExtensionFilter("jpg");
FilenameLoader loader = new FilenameLoader(filter);
List<String> files = loader.loadFilenames(mydir); // create the resolver-----看这里,baby go
FilenamePatternResolver resolver =
new FilenamePatternResolver("%P/%f.tif"); // now iterate over all files
for (String img:files) {
cmd.run(op,img,resolver.createName(img));
}

个人理解:你不用每次都拼凑目标图片名字了,有很便利的方法实现。
  • %P: full pathname of source-image (i.e. the directory)
  • %p: last component of %P(用于相对路径?)
  • %F: full filename without directory part
  • %f: filename without directory part and extension
  • %e: only the extension
  • %D: drive-letter (on windows systems). Not available for source-files with an UNC-name.(盘符C:...)

这样就好理解 new FilenamePatternResolver("%P/%f.tif");了,就是绝对目录路径+文件名+tif

④、Debugging--窝不是类,只是一种操作方法

版本号>1.0,这个一般都是成立的。

IMOperation op = new IMOperation();
...
ConvertCmd cmd = new ConvertCmd();
cmd.createScript("myscript.sh",op);

没错,就是它了。把最后要执行的cmd+op备份到myscrip.sht脚本中。

在windows下,createScript()生成的脚本会自动加上 .bat 后缀

⑤、批量转换处理(适用于客户端程序,不适合web-application)

ExtensionFilter filter = new ExtensionFilter("jpg");
filter.setRecursion(false);
FilenameLoader loader = new FilenameLoader(filter);
List<String> images=loader.loadFilenames(dir);

After you have the list, you create your BatchConverter and use it's run()-method
to process the images:

// create a simple thumbnail operation
op = new IMOperation();
op.size(80);
op.addImage(); // placeholder input filename
op.thumbnail(80);
op.addImage(); // placeholder output filename // create a template for the output-files:
// we put them in targetDir with the same filename as the original
// images
String template=targetDir+"%F"; // create instance of BatchConverter and convert images-----看这里,baby go
BatchConverter bc = new BatchConverter(BatchConverter.Mode.PARALLEL);
bc.run(op,images,targetDir+"%F");

BatchConverter有三种执行模式:BatchConverter.SEQUENTIAL, BatchConverter.PARALLEL,BatchConverter.BATCH。

分别为顺序处理,并行处理(CPU多核),批处理(单核)

最后,还是推荐大家去看下官方英文文档,本人水平有限,本着交流的精神,所以才发帖献丑一番,主要是为了记录自己的学习过程。

im4java学习---阅读documentation文档的更多相关文章

  1. Emacs阅读chm文档

    .title { text-align: center; margin-bottom: .2em } .subtitle { text-align: center; font-size: medium ...

  2. 阅读MDN文档之CSS选择器介绍(一)

    本文为阅读MDN文档笔记 目录 Different types of Selectors Attribute Selectors Presence and value attribute select ...

  3. MongoDB学习笔记:文档Crud Shell

    MongoDB学习笔记:文档Crud Shell   文档插入 一.插入语法 db.collection.insertOne() 将单个文档插入到集合中.db.collection.insertMan ...

  4. redis module 学习—官网文档整理

    前言 redis在4.0版本中,推出了一个非常吸引的特性,可以通过编写插件的模式,来动态扩展redis的能力.在4.0之前,如果用户想拥有一个带TTL的INCRBY 命令,那么用户只能自己去改代码,重 ...

  5. apidoc学习(接口文档定义取代word)

    apidoc的安装,参考:https://blog.csdn.net/qq_36386771/article/details/82149848 生产文档,需要先编写一个apidoc.json对接口文档 ...

  6. ElasticSearch 5学习(8)——分布式文档存储(wait_for_active_shards新参数分析)

    学完ES分布式集群的工作原理以及一些基本的将数据放入索引然后检索它们的所有方法,我们可以继续学习在分布式系统中,每个分片的文档是被如何索引和查询的. 路由 首先,我们需要明白,文档和分片之间是如何匹配 ...

  7. 阅读MDN文档之StylingBoxes(五)

    目录 BoxModelRecap Box properties Overflow Background clip Background origin Outline Advanced box prop ...

  8. 使用perldoc阅读perl文档

    perl在安装的时候,就给我们送上一份大礼,组织精美,解释详细的perl百科全书已经安装在你的电脑里面了,遇到问题不要在去搜索那些博客了,还是练练英文,看看perldoc吧,呵呵. 1.用perldo ...

  9. python 学习之FAQ:文档内容写入报错

    2017.3.29 FAQ 1. 文档内容写入报错 使用with open() as file: 写入文档时,出现'\xa9'特殊字符写入报错,通过print('\xa9')打印输出“©”. > ...

随机推荐

  1. 动态规划----FatMouse’s Speed(HDU 1160)

    参考:https://blog.csdn.net/u012655441/article/details/64920825 https://blog.csdn.net/wy19910326/articl ...

  2. 当app出现线上奔溃,该如何办?

    1.如何追踪app崩溃率,如何解决线上闪退 当iOS设备上的App应用闪退时,操作系统会生成一个crash日志,保存在设备上.crash日志上有很多有用的信息,比如每个正在执行线程的完整堆栈跟踪信息和 ...

  3. Dubbo原理及配置

    技术交流群:233513714 Dubbo的背景 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进 ...

  4. innodb_index_stats

    mysql> select * from mysql.innodb_index_stats WHERE database_name='test' and table_name='recordsI ...

  5. facebook hash key

    private void printHashKey() { try { PackageInfo info = getPackageManager().getPackageInfo( "xxx ...

  6. Spring实战第五章学习笔记————构建Spring Web应用程序

    Spring实战第五章学习笔记----构建Spring Web应用程序 Spring MVC基于模型-视图-控制器(Model-View-Controller)模式实现,它能够构建像Spring框架那 ...

  7. ajax中用jsonp接收json数据

    最近在做查快递网页时遇到一个问题,调用的快递100的api,但是快递100api不允许跨域请求,就是用127.0.0.1发的请求会直接被拦截. 只是个简单的网页,不想自己做服务器转发,最后找到了一个y ...

  8. 福大软工1816:Alpha(1/10)

    Alpha 冲刺 (1/10) 队名:第三视角 组长博客链接 本次作业链接 团队部分 团队燃尽图 工作情况汇报 张扬(组长) 过去两天完成了哪些任务: 文字/口头描述: 1.自己学习wxpy.pyqt ...

  9. spark1.6.0伪分布式搭建

    环境: hadoop2.6.0 jdk1.8 ubuntu 14.04 64位 1 安装scala环境 版本是scala-2.10.6,官网下载地址http://www.scala-lang.org/ ...

  10. lintcode-117-跳跃游戏 II

    117-跳跃游戏 II 给出一个非负整数数组,你最初定位在数组的第一个位置. 数组中的每个元素代表你在那个位置可以跳跃的最大长度. 你的目标是使用最少的跳跃次数到达数组的最后一个位置. 样例 给出数组 ...