java 图片裁剪上传变红等失真现象、cmyk颜色模式图片裁剪异常现象处理

简介:

1、本文仅为了提供图片上传过程中,部分java图片处理代码。

2、以下代码可以解决部分图片上传裁剪后整体变红等失真现象。

3、以下代码支持cmyk颜色模式的图片上传裁剪。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/**
      * 图片裁剪
      * @param srcImageFile 裁剪前图片地址
      * @param dirImageFile 裁剪后图片地址
      * @param x          图片裁剪属性
      * @param y          图片裁剪属性
      * @param destWidth  图片裁剪属性
      * @param destHeight 图片裁剪属性
      */
     public  static  void  abscut(String srcImageFile,String dirImageFile, int  x, int  y, int  destWidth, int  destHeight) {  
         BufferedImage bi= null ;
         try  {  
             ImageFilter cropFilter;
             Image img = Toolkit.getDefaultToolkit().getImage(srcImageFile); //可讀取丟失ICC信息的圖片(裁剪后图片变红等现象的原因)
             bi = toBufferedImage(img);
             int  srcWidth = bi.getWidth();
             int  srcHeight = bi.getHeight();       
             if  (srcWidth >= destWidth && srcHeight >= destHeight) {  
                 Image image = bi.getScaledInstance(srcWidth, srcHeight,  
                         Image.SCALE_DEFAULT);  
                 cropFilter =  new  CropImageFilter(x, y, destWidth, destHeight);  
                 img = Toolkit.getDefaultToolkit().createImage(  
                         new  FilteredImageSource(image.getSource(), cropFilter));  
                 BufferedImage tag =  new  BufferedImage(destWidth, destHeight,  
                 BufferedImage.TYPE_INT_RGB);  
                 Graphics g = tag.getGraphics();  
                 g.drawImage(img,  0 0 null ); 
                 g.dispose();  
                 ImageIO.write(tag,  "jpg" new  File(dirImageFile));  
             }  
         catch  (Exception e) {  
             System.out.println( "ImageUtils图片裁剪异常:" +e.getLocalizedMessage());
         }
     }  
     
     /**
      * Image 转 BufferedImage
      * @param image
      * @return
      */
     public  static  BufferedImage toBufferedImage(Image image) {
         if  (image  instanceof  BufferedImage) {
             return  (BufferedImage)image;
          }
         // This code ensures that all the pixels in the image are loaded
          image =  new  ImageIcon(image).getImage();
      
         // Determine if the image has transparent pixels; for this method's
         // implementation, see e661 Determining If an Image Has Transparent Pixels
         //boolean hasAlpha = hasAlpha(image);
          
         // Create a buffered image with a format that's compatible with the screen
          BufferedImage bimage =  null ;
          GraphicsEnvironment ge = GraphicsEnvironment.getLocalGraphicsEnvironment();
         try  {
             // Determine the type of transparency of the new buffered image
             int  transparency = Transparency.OPAQUE;
            /* if (hasAlpha) {
                  transparency = Transparency.BITMASK;
              }*/
      
             // Create the buffered image
              GraphicsDevice gs = ge.getDefaultScreenDevice();
              GraphicsConfiguration gc = gs.getDefaultConfiguration();
              bimage = gc.createCompatibleImage(
                  image.getWidth(null), image.getHeight(null), transparency);
          } catch (HeadlessException e) {
             // The system does not have a screen
          }
         if (bimage == null) {
             // Create a buffered image using the default color model
             int type = BufferedImage.TYPE_INT_RGB;
             //int type = BufferedImage.TYPE_3BYTE_BGR;//by wang
             /*if (hasAlpha) {
                  type = BufferedImage.TYPE_INT_ARGB;
              }*/
              bimage =  new  BufferedImage(image.getWidth( null ), image.getHeight( null ), type);
          }
         // Copy image to buffered image
          Graphics g = bimage.createGraphics();
         // Paint the image onto the buffered image
          g.drawImage(image,  0 0 null );
          g.dispose();
         return  bimage;
      }









本文转自 艺晨光 51CTO博客,原文链接:http://blog.51cto.com/ycgit/1735974,如需转载请自行联系原作者
目录
相关文章
|
11月前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
314 1
|
3月前
|
Java 应用服务中间件 Docker
java-web部署模式概述
本文总结了现代 Web 开发中 Spring Boot HTTP 接口服务的常见部署模式,包括 Servlet 与 Reactive 模型、内置与外置容器、物理机 / 容器 / 云环境部署及单体与微服务架构,帮助开发者根据实际场景选择合适的方案。
125 25
|
3月前
|
存储 Java 大数据
Java 大视界 -- Java 大数据在智能家居能源消耗模式分析与节能策略制定中的应用(198)
简介:本文探讨Java大数据技术在智能家居能源消耗分析与节能策略中的应用。通过数据采集、存储与智能分析,构建能耗模型,挖掘用电模式,制定设备调度策略,实现节能目标。结合实际案例,展示Java大数据在智能家居节能中的关键作用。
|
4月前
|
Java 程序员 数据库连接
我们详细地讲解一下 Java 异常及要如何处理
我是小假 期待与你的下一次相遇 ~
|
5月前
|
供应链 JavaScript 前端开发
Java基于SaaS模式多租户ERP系统源码
ERP,全称 Enterprise Resource Planning 即企业资源计划。是一种集成化的管理软件系统,它通过信息技术手段,将企业的各个业务流程和资源管理进行整合,以提高企业的运营效率和管理水平,它是一种先进的企业管理理念和信息化管理系统。 适用于小微企业的 SaaS模式多租户ERP管理系统, 采用最新的技术栈开发, 让企业简单上云。专注于小微企业的应用需求,如企业基本的进销存、询价,报价, 采购、销售、MRP生产制造、品质管理、仓库库存管理、财务应收付款, OA办公单据、CRM等。
288 23
|
11月前
|
Java API 调度
如何避免 Java 中的 TimeoutException 异常
在Java中,`TimeoutException`通常发生在执行操作超过预设时间时。要避免此异常,可以优化代码逻辑,减少不必要的等待;合理设置超时时间,确保其足够完成正常操作;使用异步处理或线程池管理任务,提高程序响应性。
502 13
|
11月前
|
Java
在 Java 中,如何自定义`NumberFormatException`异常
在Java中,自定义`NumberFormatException`异常可以通过继承`IllegalArgumentException`类并重写其构造方法来实现。自定义异常类可以添加额外的错误信息或行为,以便更精确地处理特定的数字格式转换错误。
179 1
|
7月前
|
SQL Java 中间件
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
在BeetISQL 2.13.8版本中,客户使用batch insert向yashandb表插入数据并尝试获取自动生成的sequence id时,出现类型转换异常。原因是beetlsql在prepareStatement时未指定返回列,导致yashan JDBC驱动返回rowid(字符串),与Java Bean中的数字类型tid不匹配。此问题影响业务流程,使无法正确获取sequence id。解决方法包括:1) 在batchInsert时不返回自动生成的sequence id;2) 升级至BeetISQL 3,其已修正该问题。
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
|
7月前
|
SQL druid Oracle
【YashanDB知识库】yasdb jdbc驱动集成druid连接池,业务(java)日志中有token IDENTIFIER start异常
客户Java日志中出现异常,影响Druid的merge SQL功能(将SQL字面量替换为绑定变量以统计性能),但不影响正常业务流程。原因是Druid在merge SQL时传入null作为dbType,导致无法解析递归查询中的`start`关键字。
|
8月前
|
Java 程序员 开发者
Java社招面试题:一个线程运行时发生异常会怎样?
大家好,我是小米。今天分享一个经典的 Java 面试题:线程运行时发生异常,程序会怎样处理?此问题考察 Java 线程和异常处理机制的理解。线程发生异常,默认会导致线程终止,但可以通过 try-catch 捕获并处理,避免影响其他线程。未捕获的异常可通过 Thread.UncaughtExceptionHandler 处理。线程池中的异常会被自动处理,不影响任务执行。希望这篇文章能帮助你深入理解 Java 线程异常处理机制,为面试做好准备。如果你觉得有帮助,欢迎收藏、转发!
489 14