java常用的几个图片处理工具对Tiff文件的支持

ImageMagick

官网 https://imagemagick.org/, 支持多种格式。命令行工具很适合调试。功能很强大. 还有一款工具GraphicsMagick 是从ImageMagick的基础上研发出来的。

OpenCV

官网 https://opencv.org/ , github地址https://github.com/opencv/opencv,非常活跃的一个开源工具,原来免费的教程,现在已经开始包装成视频,进行收费了,我买了教程,看了下,和以前官网看过的文字版教程没多大差别。github关注已经达到了72.3k。

ImageJ

官网 https://imagej.net/ij/

ImageJ is open source software for processing and analyzing scientific images.

基于ImageJ已经又研发了ImageJ2(目前github关注量1k)和Fiji的产品。

java 复制代码
// Open the TIFF image
ImagePlus imagePlus = new ImagePlus(f);

// Get the image processor
ImageProcessor imageProcessor = imagePlus.getProcessor();

// Add text to the image
int x = 0; // X-coordinate of text
int y = 0; // Y-coordinate of text

String   textToAdd = "These three lines of\ntext will be overlayed on\nthe current image";

Font font = new Font("SansSerif", Font.PLAIN, 56);
imageProcessor.setFont(font);
imageProcessor.setColor(Color.RED);
imageProcessor.drawString(textToAdd, x, y); // Draw the text

// Display the modified image (optional)
//        imagePlus.show();

// Save the modified image
ImagePlus outputImage = new ImagePlus("Modified Image", imageProcessor);
IJ.saveAs(outputImage,"jpeg", f31);
IJ.saveAsTiff(outputImage, f41);
final ImagePlus imagePlus1 = IJ.openImage(f41);
IJ.save(imagePlus1, fpng);

commons-imaging

Apache维护的产品,目前github关注量381

java 复制代码
final File file = new File(f);
final BufferedImage overlay = Imaging.getBufferedImage(file);
// Add text to the image
int x = 0; // X-coordinate of text
int y = 0; // Y-coordinate of text

Font font = new Font("SansSerif", Font.PLAIN, 56);
String   textToAdd = "These three lines of\ntext will be overlayed on\nthe current image";
addTextToImage(overlay, textToAdd, x, y, Color.RED, font);

ImageIO.write(overlay, "JPEG", new File(fa1));
//        ImageIO.write(overlay, "TIFF", new File(fa2));
saveImageWithText(overlay, fa2);
Imaging.writeImage(overlay, Files.newOutputStream(Paths.get(fa4png)), ImageFormats.PNG);
java 复制代码
    // Method to add text to the image
    private static void addTextToImage(BufferedImage image, String text, int x, int y, Color color, Font font) {
        Graphics2D g2d = image.createGraphics();
        g2d.setColor(color);
        g2d.setFont(font);
//        g2d.drawString(text, x, y);
        drawString(g2d, text, x, y);
        g2d.dispose();
    }
   private static void drawString(Graphics g, String text, int x, int y) {
        for (String line : text.split("\n"))
            g.drawString(line, x, y += g.getFontMetrics().getHeight());
    }

//    // Method to save the modified image with text using Common Imaging
    private static void saveImageWithText(BufferedImage image, String outputPath) throws IOException, ImageWriteException {
        // Create a new instance of ImageWriteParam for TIFF format
        final TiffImagingParameters params = new TiffImagingParameters();
        params.setCompression(TiffConstants.TIFF_COMPRESSION_UNCOMPRESSED);

        // Write the BufferedImage with text to a TIFF file
//        Imaging.writeImage(image, new File(outputPath), ImageFormat.IMAGE_FORMAT_TIFF, params);
         new TiffImageParser().writeImage(image, Files.newOutputStream(Paths.get(outputPath)), params);
    }

TwelveMonkeys

目前github关注量1.7k

JDeli 是一个付费软件

如下是测试结果

photoshop可以看到通道增加了专色通道。

ImageMagick opencv imagej commons-imaging TwelveMonkeys JDeli(付费软件)
带有2 个专色通道的tiff图片 不支持 不支持 支持 支持 不支持 支持
将文字写入到图片中 / / 支持 支持
文字写入保存为jpg格式 / / 写入红色的字体变成了黑红 写入红色的字体变成了黑红
文字写入保存为tiff格式 / / 写入红色的字体正常 写入红色的字体正常 写入红色的字体正常
支持Tiff 格式alpha通道 / / 不支持 不支持 不支持 不支持
相关推荐
如若1234 小时前
SoftGroup训练FORinstance森林点云数据集——从零到AP=0.506完整复现
人工智能·python·深度学习·神经网络·计算机视觉
rit84324997 小时前
matlab实现自适应稀疏表示同时完成图像融合与去噪
人工智能·计算机视觉·matlab
yong99907 小时前
基于SIFT的MATLAB图像拼接实现
人工智能·计算机视觉·matlab
shenxianasi8 小时前
【论文精读】Flamingo: a Visual Language Model for Few-Shot Learning
人工智能·深度学习·机器学习·计算机视觉·语言模型·自然语言处理
向哆哆8 小时前
金属材料表面六种缺陷类型数据集:工业视觉检测的优质训练资源
人工智能·计算机视觉·视觉检测
Lun3866buzha9 小时前
【计算机视觉】基于YOLOv8-AFPN-P2345的面部区域检测与识别系统实现详解
人工智能·yolo·计算机视觉
咚咚王者9 小时前
人工智能之视觉领域 计算机视觉 第四章 图像基本操作
人工智能·opencv·计算机视觉
AI周红伟9 小时前
周红伟:自媒体的AI时刻到了,Seedance2.0生成AI视频的具体技术原理是什么?抖音终于战胜了Sora2
人工智能·计算机视觉
爱打代码的小林9 小时前
基于 Lucas-Kanade 光流法实现视频特征点追踪
opencv·计算机视觉·音视频
向哆哆9 小时前
100类中药材图像识别数据集分享(适用于目标检测任务)
人工智能·目标检测·计算机视觉