shell技巧3 - 自动生成AppIcon

简介: 1、前言上一篇讲到 shell技巧2 - 图片旋转缩放转换格式等,而平时iOS开发中,Xcode中Assets.xcassets的AppIcon 需要设计师或开发者自行放置对应尺寸的图标,虽然我经常使用macOS下的 Prepo 应用生成多尺寸的图标,但是依然需要一张一张的放置到Xcode中,并且步骤非常不智能化,部分图标需要人工对应位置放置。

1、前言

上一篇讲到 shell技巧2 - 图片旋转缩放转换格式等,而平时iOS开发中,Xcode中Assets.xcassetsAppIcon 需要设计师或开发者自行放置对应尺寸的图标,虽然我经常使用macOS下的 Prepo 应用生成多尺寸的图标,但是依然需要一张一张的放置到Xcode中,并且步骤非常不智能化,部分图标需要人工对应位置放置。如果通过使用 sips 命令,其实可以自动生成对应尺寸的图片,就可以灵活和自动化的批量生成AppIcon的全部图标,绝对的方便和效率!说到就马上实践吧!

2、AppIcon 要求

平时,我们的应用的图标,都会在 Assets.xcassets 的AppIcon 设置,对于 iOS 来说,需要配置如下图标:

img_7d3c0f42443717348ba4b6c2e2220cc8.png
20180915-Xcode-Assets.xcassets-AppIcon.png

其中,因为App如果只支持iOS7以上,1x 的设备也不需要支持了,那么大概导出需要如下的尺寸:

pt 像素密度(scale) 尺寸(px) 用途 支持系统版本
20pt 2x 40*40 iPhone Notificafion iOS 7-12
20pt 3x 60*60 iPhone Notificafion iOS 7-12
29pt 2x 58*58 iPhone Spotlight/Settings iOS 5-6/5-12
29pt 3x 87*87 iPhone Spotlight/Settings iOS 5-6/5-12
40pt 2x 80*80 iPhone Spotlight iOS 7-12
40pt 3x 120*120 iPhone Spotlight iOS 7-12
60pt 2x 120*120 iPhone App iOS 7-12
60pt 3x 180*180 iPhone App iOS 7-12
20pt 2x 40*40 iPad Notificafion iOS 7-12
29pt 2x 58*58 iPad Settings iOS 5-12
40pt 2x 80*80 iPad Spotlight iOS 7-12
76pt 2x 152*152 iPad App iOS 7-12
83.5 2x 167*167 iPad Pro App iOS 9-12
1024pt 1x 1024*1024 App Store iOS 7-12

从上面表格可以看出,这些尺寸还是有一些重复的,所以导出尺寸时,其实没有那么多的啊,因为如果相同尺寸,可以使用同一张图片,来减少包的体积啊。

3、shell 编程

通过使用 sips 命令进行图片处理,这里简单的写一下iOS App图标生成,apple watch 或 macOS app的图标生成的示例,希望大家能举一反三,这都是授鱼不如授渔!

先说一下操作步骤:

1.在终端执行shell脚本:

sh /Users/HTC/Desktop/make_iOSAppIcon.sh 

2.然后拖拽1024图片路径到终端:

================================================
Enter origin image path: /Users/HTC/Desktop/apple.jpg 

3.执行成功:

------- start processing -------
info:   resize copy 1024 successfully.
info:   resize 1024 successfully.
info:   resize 180 successfully.
info:   resize 167 successfully.
info:   resize 152 successfully.
info:   resize 120 successfully.
info:   resize 87 successfully.
info:   resize 80 successfully.
info:   resize 60 successfully.
info:   resize 58 successfully.
info:   resize 40 successfully.
info:   resize 1024 to jpg successfully.

creat iOS AppIcon finished!

------- end processing -------

生成的图标和json文件:


img_01ed3ee91bafe0bcd241256a479f8016.png
20180915-creat-AppIcon.png

4.然后找到输出的文件夹(默认是在填写的图片的同级目录),复制到Xcode项目中 Project/Assets.xcassets/AppIcon.appiconset/ 即可。(如果还要省略这一步,也可以直接将生成的输出到项目的目录中,这步就交给读者需要自行添加啊)

img_70f8d4478918689fc3cd04f47b03bddc.png
20180915-move-to-Xcode-Assets.xcassets-AppIcon.png

5.打开Xcode,就能看到图片已经自动显示好!


img_cd91d4c47ddce2a32fc22f229f17a665.png
20180915-Xcode-Assets.xcassets-AppIcon-icon.png

这里说一下大概的思路,其实也不难,首先判断输出的路径,如果不是目录不存在的目录格式不符合的图片,就可以图片处理,否则重新输入路径。然后创建图片同级的文件夹用于生成的图标和配置的json文件,由于 “1024”图片最大,所以,先转成png,然后从大到小,一张一张剪切,另外,需要注意,1024如果是png,因为有透明度的话上传到AppStore是不成功的,所以,这里最后转换1024图片格式为jpg,这样保证万无一失。其它图标都是png,也不用切成圆角,因为苹果最终显示时系统自动切成图角。

4、源代码

具体的代码,可参考我的Github代码:

#!/bin/bash

# 定义用到的变量
image_path=""

# 定义读取输入字符的函数
getImagePath() {
    echo -e "\n================================================"
    # 监听输入并且赋值给变量
    read -p "Enter origin image path: " image_path
    # 如果字符串的长度为零则为真为空值,从新监听,否则执行旋转函数
    if  test -z "$image_path"; then
         getImagePath
    else
        # 如果文件存在且为目录则为真
        if test -d "$image_path"; then
            echo -e "\n------- [Error] the file path is directory --------"
            getImagePath
        else
            # 如果文件存在且可读则为真
            if test -r "$image_path"; then
                ext="\.jpeg|\.jpg|\.png|\.JPEG|\.JPG|\.PNG|\.gif|\.bmp"
                # get the images that need process.
                valid_img=$(echo "$image_path" | grep -E "${ext}")
                # 匹配到图片格式才处理
                if test -z "$valid_img"; then
                    echo -e "\n------- [Error] the file is not's legal format --------"
                    getImagePath
                else
                    creatAppIcon    
                fi
            else            
                echo -e "\n------- [Error] the file path is not's find --------"
                getImagePath
            fi  
        fi
    fi
}

creatAppIcon() {
    echo -e "\n------- start processing -------"
    
    # 图片的上一级目录
    prev_path=$(dirname "$image_path")
    
    # 输出icon的目录
    icon_paht="${prev_path}/iOS_icon_`date +%Y%m%d_%H%M%S`"
    
    # 创建目录
    mkdir -p ${icon_paht}
    
    # 1024 icon 特别处理
    icon_1024_path="${icon_paht}/icon-1024.png"
    cp ${image_path} ${icon_1024_path}
    
    sips -s format png ${image_path} --out ${icon_1024_path} > /dev/null 2>&1
    [ $? -eq 0 ] && echo -e "info:\tresize copy 1024 successfully." || echo -e "info:\tresize copy 1024 failed."
    
    sips -z 1024 1024 ${icon_1024_path} > /dev/null 2>&1
    [ $? -eq 0 ] && echo -e "info:\tresize 1024 successfully." || echo -e "info:\tresize 1024 failed."
    
    prev_size_path=${icon_1024_path} #用于复制小图,减少内存消耗
    # 需要生成的图标尺寸
    icons=(180 167 152 120 87 80 60 58 40)
    for size in ${icons[@]}
    do
        size_path="${icon_paht}/icon-${size}.png"
        cp ${prev_size_path} ${size_path}
        prev_size_path=${size_path}
        sips -Z $size ${size_path} > /dev/null 2>&1
        [ $? -eq 0 ] && echo -e "info:\tresize ${size} successfully." || echo -e "info:\tresize ${size} failed."
    done
    
    # 转换1024图片为jpg,防止有透明区域导致上传 App Store 失败
    icon_1024_jpg_path="${icon_paht}/icon-1024.jpg"
    mv ${icon_1024_path} ${icon_1024_jpg_path}
    sips -s format jpeg ${icon_1024_jpg_path} --out ${icon_1024_jpg_path} > /dev/null 2>&1
    [ $? -eq 0 ] && echo -e "info:\tresize 1024 to jpg successfully." || echo -e "info:\tresize 1024 to jpg  failed."
    
    contents_json_path="${icon_paht}/Contents.json"
    # 生成图标对应的配置文件
    echo '{
        "images" : [
            {
                "size" : "20x20",
                "idiom" : "iphone",
                "filename" : "icon-40.png",
                "scale" : "2x"
            },
            {
                "size" : "20x20",
                "idiom" : "iphone",
                "filename" : "icon-60.png",
                "scale" : "3x"
            },
            {
                "size" : "29x29",
                "idiom" : "iphone",
                "filename" : "icon-58.png",
                "scale" : "2x"
            },
            {
                "size" : "29x29",
                "idiom" : "iphone",
                "filename" : "icon-87.png",
                "scale" : "3x"
            },
            {
                "size" : "40x40",
                "idiom" : "iphone",
                "filename" : "icon-80.png",
                "scale" : "2x"
            },
            {
                "size" : "40x40",
                "idiom" : "iphone",
                "filename" : "icon-120.png",
                "scale" : "3x"
            },
            {
                "size" : "60x60",
                "idiom" : "iphone",
                "filename" : "icon-120.png",
                "scale" : "2x"
            },
            {
                "size" : "60x60",
                "idiom" : "iphone",
                "filename" : "icon-180.png",
                "scale" : "3x"
            },
            {
                "idiom" : "ipad",
                "size" : "20x20",
                "scale" : "1x"
            },
            {
                "size" : "20x20",
                "idiom" : "ipad",
                "filename" : "icon-40.png",
                "scale" : "2x"
            },
            {
                "idiom" : "ipad",
                "size" : "29x29",
                "scale" : "1x"
            },
            {
                "size" : "29x29",
                "idiom" : "ipad",
                "filename" : "icon-58.png",
                "scale" : "2x"
            },
            {
                "idiom" : "ipad",
                "size" : "40x40",
                "scale" : "1x"
            },
            {
                "size" : "40x40",
                "idiom" : "ipad",
                "filename" : "icon-80.png",
                "scale" : "2x"
            },
            {
                "idiom" : "ipad",
                "size" : "76x76",
                "scale" : "1x"
            },
            {
                "size" : "76x76",
                "idiom" : "ipad",
                "filename" : "icon-152.png",
                "scale" : "2x"
            },
            {
                "size" : "83.5x83.5",
                "idiom" : "ipad",
                "filename" : "icon-167.png",
                "scale" : "2x"
            },
            {
                "size" : "1024x1024",
                "idiom" : "ios-marketing",
                "filename" : "icon-1024.jpg",
                "scale" : "1x"
            }
        ],
        "info" : {
            "version" : 1,
            "author" : "xcode"
        }
    }' > ${contents_json_path}
        
    echo -e "\n creat iOS AppIcon finished!"
    echo -e "\n------- end processing -------"
}


# 首先执行函数,填写1024图片的路径赋值
getImagePath

5、总结

通过 ship 命令和 shell脚本和前面几篇技巧,大家应该能感受到shell脚本编程的魅力,希望大家能举一反三,授鱼不如授渔!生活工作中结合 sehll 脚本,提高效率和自动化,珍爱时间不是梦!

其实,只要用命令有终端的地方,都是可以用shell脚本!后续有更多会继续给大家期待~

参考


  • 如有疑问,欢迎在评论区一起讨论!
  • 如有不正确的地方,欢迎指导!


注:本文首发于 iHTCboy's blog,如若转载,请注来源

目录
相关文章
|
2月前
|
Shell
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
114 1
|
1月前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
67 2
6种方法打造出色的Shell脚本
|
1月前
|
XML JSON 监控
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
62 1
|
1月前
|
Ubuntu Shell 开发工具
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
51 2
|
2月前
|
监控 网络协议 Shell
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
59 6
|
1月前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
2月前
|
监控 Unix Shell
shell脚本编程学习
【10月更文挑战第1天】shell脚本编程
83 12
|
2月前
|
存储 运维 监控
自动化运维:使用Shell脚本简化日常任务
【9月更文挑战第35天】在IT运维的日常工作中,重复性的任务往往消耗大量的时间。本文将介绍如何通过编写简单的Shell脚本来自动化这些日常任务,从而提升效率。我们将一起探索Shell脚本的基础语法,并通过实际案例展示如何应用这些知识来创建有用的自动化工具。无论你是新手还是有一定经验的运维人员,这篇文章都会为你提供新的视角和技巧,让你的工作更加轻松。
77 2
|
3月前
|
Shell
shell脚本变量 $name ${name}啥区别
shell脚本变量 $name ${name}啥区别
|
3月前
|
人工智能 监控 Shell
常用的 55 个 Linux Shell 脚本(包括基础案例、文件操作、实用工具、图形化、sed、gawk)
这篇文章提供了55个常用的Linux Shell脚本实例,涵盖基础案例、文件操作、实用工具、图形化界面及sed、gawk的使用。
764 2