当前位置:   article > 正文

xcode新版本single view_iOS APP图标版本化

single view app没有了

f80b5f2951070467b4dbbbf4c7e83182.png

作者 | 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的图标,后面我们打水印生成的图标会存放到这里。

c1e9e1cae8ee2d1eb6e326322be45ff1.png

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

2696d142fedbf7d82f300fb6c632c23f.png

2.2 脚本配置

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

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

需要赋予可执行权限

$ chmod +x JCIconVersion.sh

再次执行

$ ./JCIconVersion.shhellow world

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

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

注意填写正确的脚本路径

9a28b45c41ab0bf4eae30a9daf5b13b7.png

然后我们build一下项目

3af9245e34920d1e8f84d682955cacb3.png

56f0d43ceafa19e2aee1c8f7e9f40b1c.png

在这里能看到我们每次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" = "" ]; thenexitWithMessage "?  Get APPICON_SET_PATH failed." 0fi# 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" = "" ]; thenexitWithMessage "?  Get DEBUG_APPICON_SET_PATH failed." 0fi# 删除appicon_debug里的文件rm -rf $DEBUG_APPICON_SET_PATHif [ $? != 0 ];thenexitWithMessage "?  Remove ${DEBUG_APPICON_SET_PATH} failed." 0fi# 复制appicon到appicon_debugcp -rf $APPICON_SET_PATH $DEBUG_APPICON_SET_PATHif [ $? != 0 ];thenexitWithMessage "?  Copy ${APPICON_NAME} to ${DEBUG_APPICON_NAME} failed." 0fiecho "✅  Finish copy icon files."
3.4 添加水印
# # 处理icon# # Processing iconfunction processIcon() {BASE_IMAGE_PATH=$1echo "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; doecho "? ${file}"processIcon "${file}"doneecho "✅  Finish all process"

总结

28a270bd808fa565876b717c4df68ac5.png

效果如上图,水印效果还不太完善,imagemagick里面还有很多强大的api,能实现更加炫酷的效果,感兴趣的同学可以看看 这里 https://imagemagick.org/Usage/annotating/#wmark_text,有时间我也会完善一下。

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



推荐阅读 ☞  苹果发布新的 Swift Server 框架:Swift Cluster Membership,这次的目标是集群☞  Sketch vs. Figma:为什么 Figma 会赢?我们又能从中学到什么?☞  苹果正式更新应用审核流程,以后可以对审核指南提建议了☞  Arm64e 符号翻译与 PAC 问题☞  DartNative 内存自动管理

就差您点一下了 ???

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/382978
推荐阅读
相关标签
  

闽ICP备14008679号