• 一键生成IOS App Icon工具


    每次要提审AppStore,美术总是给一个1024x1024的 Icon ,然后就进入了繁琐的修改图片 size 和 plist 文件 Icon 配置的过程,很繁琐。这些应该是可以偷懒的啊~然后就有了这篇。

    可运行jar包上传在 这里 ,   需要 JRT 环境。

    Apple 后台改了 需要移除alpha通道  这个工具已经不能满足要求  大家不要再下这个了 我重新弄了个 nodejs的。用nodejs 比 java 搞起来简直爽多了啊 

    或者  大家可以上传到 这里 来制作 Icon !

    需求:

      提供一张Icon 1024x1024 png 不带alpha通道,和Assets文件夹内的AppIcon.appiconset内的Content.json文件,

    输出:

      Content.json 中指定的所有Icon。 (包括命名之类的全部搞定,问题虽然小,但是省了很多事)。

    生成结果如图 :

    (1)首先尝试用Grahics2D来draw,

    public static void PngResize(String srcImageFile, String result, int width,int height) {
        try {
            BufferedImage src = ImageIO.read(new File(srcImageFile)); 
            Image image = src.getScaledInstance(width,height,Image.SCALE_DEFAULT);
                
            BufferedImage newImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_ARGB);
            Graphics g = newImage.createGraphics();
            g.drawImage(image, 0, 0, null);
            g.dispose();
            newImage.flush();
            ImageIO.write(newImage, "PNG", new File(result));  
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    发现draw出来的图片毛边情况很严重,所以放弃.

    (2) 后面发现 Thumbnailator 这个Java 类库的处理效果要好很多啊 所以果断用这个

    public static int PngResize(String srcImageFile, String result, float width_, float height_){
        try {
            Thumbnails.of(srcImageFile).size((int)width_, (int)height_).outputQuality(1f).keepAspectRatio(false).toFile(result); 
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

    出来效果对比   很好。记录下

    Thumbnailator 类库还有如下操作:

    //按指定大小把图片进行缩和放(会遵循原图高宽比例)  此处把图片压成400×500的缩略图  变为400*300,遵循原图比例缩或放到400*某个高度
    Thumbnails.of(fromPic).size(400,500).toFile(toPic);////按照比例进行缩小和放大
    Thumbnails.of(fromPic).scale(0.2f).toFile(toPic);//按比例缩小
    Thumbnails.of(fromPic).scale(2f);//按比例放大
    
    //不按比例,就按指定的大小进行缩放
    Thumbnails.of(fromPic).size(100, 100).keepAspectRatio(false).toFile(toPic);
    //或者Thumbnails.of(fromPic).forceSize(100,100).toFile(toPic);
    //旋转图片,rotate(角度),正数则为顺时针,负数则为逆时针
    Thumbnails.of(fromPic).size(200,200).rotate(90).toFile(toPic);
    
    //图片尺寸不变,压缩图片文件大小outputQuality实现,参数1为最高质量
    Thumbnails.of(fromPic).scale(1f).outputQuality(0.25f).toFile(toPic);
    
    //给图片加水印,watermark(位置,水印图,透明度)Positions.CENTER表示加在中间
    Thumbnails.of(fromPic).size(400,400).watermark(Positions.CENTER,ImageIO.read(waterPic),0.5f).outputQuality(0.8f).toFile(toPic);
    
    //用sourceRegion()实现图片裁剪//图片中心300*300的区域,Positions.CENTER表示中心,还有许多其他位置可选
    Thumbnails.of(fromPic).sourceRegion(Positions.CENTER,300,300).size(300,300).toFile(toPic);
    
    //图片中上区域300*300的区域
    Thumbnails.of(fromPic).sourceRegion(Positions.TOP_CENTER,300,300).size(300,300).toFile(toPic);
    
    //用outputFormat(图像格式)转换图片格式,保持原尺寸不变
    Thumbnails.of(fromPic).scale(1f).outputFormat("png").toFile("picture/png格式的图片.png");
    
    //输出成文件流OutputStream
    OutputStream os=new FileOutputStream(toPic);
    Thumbnails.of(fromPic).size(120,120).toOutputStream(os);
    
    //输出BufferedImage,asBufferedImage()返回BufferedImage
    BufferedImage bi=Thumbnails.of(fromPic).size(120,120).asBufferedImage();
    ImageIO.write(bi,"jpg",toPic);
    
    //压缩至指定图片尺寸(例如:横400高300),保持图片不变形,多余部分裁剪掉
    BufferedImage image = ImageIO.read(fromPic);
    Builder<BufferedImage> builder = null;
    
    int imageWidth = image.getWidth();
    int imageHeitht = image.getHeight();
    if ((float)300 / 400 != (float)imageWidth / imageHeitht) {
        if (imageWidth > imageHeitht) {
            image = Thumbnails.of(fromPic).height(300).asBufferedImage();
        } else {
            image = Thumbnails.of(fromPic).width(400).asBufferedImage();
        }
        builder = Thumbnails.of(image).sourceRegion(Positions.CENTER, 400, 300).size(400, 300);
    } else {
        builder = Thumbnails.of(image).size(400, 300);
    }
    builder.outputFormat("jpg").toFile(toPic);

    有关 Thumbnailator 类库的操作,来自于  https://blog.csdn.net/chenleixing/article/details/44685817

    感谢分享.

  • 相关阅读:
    文件权限
    函数指针
    位操作
    宏定义
    GNU gcc常用编译选项
    SHELL编程(六)---------数组和函数
    26.使用中间件的方式包装日志输出
    25.最基本的日志输出方式,内置日志包使用
    24.把熔断器整合到我们的客户端代码中(初步)
    23.熔断器学习,熔断器的三种状态,状态获取
  • 原文地址:https://www.cnblogs.com/lesten/p/9651268.html
Copyright © 2020-2023  润新知