iOS APP图标版本化

点击上方“逆锋起笔”,公众号回复 pdf

领取大佬们推荐的学习资料


作者 | huqigu 
来源 | 简书,点击阅读原文查看作者更多文章

一、需求背景

在我们的项目开发过程中,需要频繁打包给测试人员去测试,有时候我们都不知道测试机上安装的版本是否是最新的,这样会造成很多不必要的麻烦和成本。因此我们需要将buildNumber以水印的方式打在APPIcon上,可以很直观的知道当前是哪一个版本。

二、需求分析

1、如何动态更新图标

Xcode在build过程中可以执行Script脚本,我们可以利用Script在程序运行之前做很多我们想做的事情。

2、如何打水印

ImageMagick 免费的图片处理插件,同时支持多种语言。

github https://github.com/ImageMagick/ImageMagick

官网 http://www.imagemagick.org/

三、实现

1、ImageMagick安装

有两种安装方式,具体可以看这里 ,推荐大家使用第一种,因为我在测试第二种安装的时候碰到了很多坑,需要自己安装依赖,不然很多方法使用不了。

安装

brew install imagemagick

检查是否安装成功

identify -version

2、Xcode项目配置

2.1 AppIcon配置

这里我使用的是唔哩头条的icon,并新建一个AppIcon-Debug 用于存放Debug的图标,后面我们打水印生成的图标会存放到这里。

设置Debug模式下图标为刚才新建的图标组

2.2 脚本配置

我们在项目路径下新建一个脚本文件并执行

$ touch JCIconVersion.sh
$ vim JCIconVersion.sh
$ ./JCIconVersion.sh
-bash: ./JCIconVersion.sh: Permission denied

需要赋予可执行权限

$ chmod +x JCIconVersion.sh

再次执行

$ ./JCIconVersion.sh
hellow world

脚本创建完了并赋予了可执行权限,我们现在将他配置到Xcode中。

先将他添加到项目中,然后在Build Phases中添加Run Script。

注意填写正确的脚本路径

然后我们build一下项目

在这里能看到我们每次Build状态,以及脚本运行情况。

下面就进入脚本代码的编写。

3、Shell脚本编写

3.1 检查是否安装了ImageMagick
#######################################################
# 1、检查是否安装了ImageMagick
#######################################################
echo "????: Checking installed ImageMagick"

convertPath=`which convert`

if [[ ! -f ${convertPath} || -z ${convertPath} ]]; then
    convertValidation=true;
else
    convertValidation=false;
fi

# 未安装 提示并退出
if [ "$convertValidation" == true ]; then
    echo "????: you need to install ImageMagick first, you can use brew to simplify process:\n brew  install  imagemagick"
    exit 0;
else
    echo "✅: Begin convert"
fi

由于我们打水印使用的是convert命令,所以检查convert是否安装就行。

3.2 获取需要的字段
######################################################
# 2. 全局字段
######################################################
# Assets中的appIcon文件名
APPICON_NAME="AppIcon"

# Assets中Debug环境的appIcon文件名
DEBUG_APPICON_NAME="${APPICON_NAME}-Debug"

# 获取app版本号
APP_VERSION=$(/usr/libexec/PlistBuddy -c 'Print CFBundleShortVersionString' "${INFOPLIST_FILE}")

# 获取build号
APP_BUILD_NUM=$(/usr/libexec/PlistBuddy -c 'Print CFBundleVersion' "${INFOPLIST_FILE}")

# Icon上显示的文字内容, 你可以在这里修改标题格式
CAPTION="$APP_VERSION\n($APP_BUILD_NUM)"
3.3 复制AppIcon到AppIcon-Debug
######################################################
# 3. 复制AppIcon到AppIcon-Debug
######################################################
echo "???? Begin copy icon files"

# appicon路径
APPICON_SET_PATH=`find $SRCROOT -name "${APPICON_NAME}.appiconset"`

echo "???? APPICON_SET_PATH=$APPICON_SET_PATH"
if [ "$APPICON_SET_PATH" = "" ]; then
    exitWithMessage "????  Get APPICON_SET_PATH failed." 0
fi

# appicon_debug路径
ASSET_PATH=`echo $(dirname ${APPICON_SET_PATH})`
DEBUG_APPICON_SET_PATH="${ASSET_PATH}/${DEBUG_APPICON_NAME}.appiconset"
echo "???? DEBUG_APPICON_SET_PATH=$DEBUG_APPICON_SET_PATH"
if [ "$DEBUG_APPICON_SET_PATH" = "" ]; then
    exitWithMessage "????  Get DEBUG_APPICON_SET_PATH failed." 0
fi


# 删除appicon_debug里的文件
rm -rf $DEBUG_APPICON_SET_PATH
if [ $? != 0 ];then
    exitWithMessage "????  Remove ${DEBUG_APPICON_SET_PATH} failed." 0
fi

# 复制appicon到appicon_debug
cp -rf $APPICON_SET_PATH $DEBUG_APPICON_SET_PATH
if [ $? != 0 ];then
    exitWithMessage "????  Copy ${APPICON_NAME} to ${DEBUG_APPICON_NAME} failed." 0
fi


echo "✅  Finish copy icon files."
3.4 添加水印
# # 处理icon
# # Processing icon
function processIcon() {

BASE_IMAGE_PATH=$1
echo "BASE_IMAGE_PATH=$BASE_IMAGE_PATH"

BASE_FLODER_PATH=`dirname $BASE_IMAGE_PATH`
cd "$BASE_FLODER_PATH"

# 获取图片宽度
WIDTH=$(identify -format %w ${BASE_IMAGE_PATH})
echo "width $WIDTH"

FONT_SIZE=$(echo "$WIDTH * .15" | bc -l)
echo "font size $FONT_SIZE"

convert ${BASE_IMAGE_PATH}  -font Arial -pointsize ${FONT_SIZE} \
-draw "gravity south \
fill white  text 0,12 '$APP_VERSION($APP_BUILD_NUM)'" \
${BASE_IMAGE_PATH}
}
3.5 处理AppIcon-Debug
#######################################################
# 4. 处理AppIcon-Debug
#######################################################
find "$DEBUG_APPICON_SET_PATH" -type f -name "*.png" -print0 |

while IFS= read -r -d '' file; do

echo "???? ${file}"
processIcon "${file}"

done

echo "✅  Finish all process"

总结

效果如上图,水印效果还不太完善,imagemagick里面还有很多强大的api,能实现更加炫酷的效果,感兴趣的同学可以看看 这里 https://imagemagick.org/Usage/annotating/#wmark_text,有时间我也会完善一下。关注公众号 逆锋起笔,回复 pdf,下载你需要的各种学习资料。

最后附上Demo下载地址:Demo下载 https://github.com/huqigu/AppIconVersion/tree/master



推荐阅读

☞  24 款效率办公神器,简直不要太强大!
☞  Chrome 开发者工具的11 个高级使用技巧
☞  Vue 超清晰思维导图,带你详细梳理知识点
☞  iOS 导航栏整体滑动解决方案(类似淘宝)
☞  12 岁学习编程,17 岁香港高中生成苹果 WWDC2020 Swift 开发者挑战赛赢家!

就差您点一下了 ????????????

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在iOS设备上下载app图标,可以按照以下步骤进行: 1. 打开App Store:在iOS设备的主屏幕上找到App Store的图标,一般是一个蓝色的背景,上面有一个白色的字母“A”。 2. 搜索应用程序:点击App Store图标后,会进入应用商店的主页。在顶部的搜索栏中输入应用程序的名称或关键词,然后点击搜索按钮。 3. 选择应用程序:搜索结果列表中会显示与你输入的关键词相关的应用程序。找到你想要下载的应用程序,点击它的图标以进入应用程序的主页。 4. 下载应用程序:在应用程序的主页上,会显示该应用的详细信息。如果应用程序是免费的,你将看到一个“获取”按钮,点击它即可开始下载。如果应用程序需要付费,你将看到一个显示价格的按钮,点击它后会提示你输入Apple ID密码进行购买。完成购买后,应用程序即可开始下载。 5. 等待下载完成:下载过程可能需要一些时间,具体取决于你的网络连接速度和应用程序的大小。下载过程中,你可以在主屏幕或者应用商店中的“已购买”项目下观察下载进度。 6. 安装应用程序:下载完成后,应用程序的图标将出现在设备的主屏幕上。点击它即可开始安装。如果应用程序需要访问某些权限(如位置信息、通讯录等),系统将会提示你是否授权。 通过以上步骤,你就可以在iOS设备上下载和安装应用程序的图标了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值