Xcode9下打包app,icon不显示问题详解

问题:

升级Xcode9之后,打包app发现icon无法显示。并且审核时会报错,说icon图标缺失。例如:

Missing required icon file. The bundle does not contain an app icon for iPhone/iPod Touch of exactly "120x120" pixels.

解决方案:

  • 1.检查icon是否缺失,项目配置是否正确。
  • 2.icon图片是否正确
  • 3.是否使用Cocoapods(关键)

1.工程icon配置

主要有2个地方:
1)项目TARGETS下:


WX20171213-142933.png

2)项目Build Settings下:


WX20171213-143054.png

2.icon图片检查

1)Xcode9需要提供1024x1024尺寸的,每个尺寸的图片都严格按照官方要求
2)所有的icon都不能有Alpha通道
3)有的人说直接将其他图片格式的后缀改为.png也会有问题,所以,建议每个icon都用软件提供的导出功能,生成png图。

3.Cocoapods在Xcode9下的问题

目前为止,Cocoapods在Xcode9下存在问题,这里是issue地址:https://github.com/CocoaPods/CocoaPods/issues/7003

提供了2种解决方案:

1)修改pods的脚本文件(不推荐)

找到../Pods/Target Support Files/Pods-[Your Project Name]/Pods-[Your Project Name]-resources.sh文件,替换最后一句命令:

  • 替换前
    printf "%s\0" "${XCASSET_FILES[@]}" | xargs -0 xcrun actool --output-format human-readable-text --notices --warnings --platform "${PLATFORM_NAME}" --minimum-deployment-target "${!DEPLOYMENT_TARGET_SETTING_NAME}" ${TARGET_DEVICE_ARGS} --compress-pngs --compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"

  • 替换后
    printf "%s\0" "${XCASSET_FILES[@]}" | xargs -0 xcrun actool --output-format human-readable-text --notices --warnings --platform "${PLATFORM_NAME}" --minimum-deployment-target "${!DEPLOYMENT_TARGET_SETTING_NAME}" ${TARGET_DEVICE_ARGS} --compress-pngs --compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" --app-icon "${ASSETCATALOG_COMPILER_APPICON_NAME}" --output-partial-info-plist "${BUILD_DIR}/assetcatalog_generated_info.plist"

2)修改podfile(推荐,并了解其原理)

在podfile文末(end之后),加上如下代码:

post_install do |installer|
  # 1
    copy_pods_resources_path = "Pods/Target Support Files/Pods-[Your Project Name]/Pods-[Your Project Name]-resources.sh"
  # 2
    string_to_replace = '--compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"'
  # 3
    assets_compile_with_app_icon_arguments = '--compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" --app-icon "${ASSETCATALOG_COMPILER_APPICON_NAME}" --output-partial-info-plist "${BUILD_DIR}/assetcatalog_generated_info.plist"'
  # 4
    text = File.read(copy_pods_resources_path)
  # 5
    new_contents = text.gsub(string_to_replace, assets_compile_with_app_icon_arguments)
  # 6
    File.open(copy_pods_resources_path, "w") {|file| file.puts new_contents }
end

解读上文内容:
#1 是脚本文件的路径,
#2#3 分别是2个字符串变量,
#4 读取了前面路径的内容,
#5#3的字符串替换#2的字符串,
#6 将改动写入文件
post_install 当我们安装完成,但是生成的工程还没有写入磁盘之时,我们可以指定要执行的操作。我们可以在这个时候对pod的配置做一些修改。这里的修改结果其实和方案一的目的是一样的,但是避免了重复pod install之后,配置被还原的问题。

为什么要这么做?

简单看下resources.sh里面改动的内容做了什么事情,我再粘贴一下这段内容,并做一点点排版。为了方便阅读,还将文件里前面的部分内容粘贴过来了

# 原本的内容
if [[ -n "${WRAPPER_EXTENSION}" ]] && [ "`xcrun --find actool`" ] && [ -n "$XCASSET_FILES" ]
then
 # Find all other xcassets (this unfortunately includes those of path pods and other targets).
 OTHER_XCASSETS=$(find "$PWD" -iname "*.xcassets" -type d)
 while read line; do
   if [[ $line != "${PODS_ROOT}*" ]]; then
     XCASSET_FILES+=("$line")
   fi
 done <<<"$OTHER_XCASSETS[]"

# 改动的内容
printf "%s\0" "${XCASSET_FILES[@]}" | xargs -0 xcrun actool 
--output-format human-readable-text 
--notices
--warnings 
--platform "${PLATFORM_NAME}" 
--minimum-deployment-target "${!DEPLOYMENT_TARGET_SETTING_NAME}" 
${TARGET_DEVICE_ARGS} 
--compress-pngs 
--compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" 
--app-icon "${ASSETCATALOG_COMPILER_APPICON_NAME}" 
--output-partial-info-plist "${BUILD_DIR}/assetcatalog_generated_info.plist

解读改动过的内容:
①printf即打印出${XCASSET_FILES}的内容,这些是项目中的资源文件
xargs -0是linux命令,即做完打印操作之后再做一些事。什么事?
xcrun 提供了一种从命令行查找或调用开发人员工具的方法,而不需要
用户修改Makefile或者采取不方便的措施来支持多个Xcode工具
链。它找到了actool,编译、打印、更新和修改asset catalogs的工具。(安装xcode之后也可在终端用man查看)
④最后就是查阅actool,看看后面的配置是做什么的。相比之前,其实就是加了--app-icon--output-partial-info-plist2个选项。
--app-icon可以和--compile组合使用,选择一个app icon,这个icon会被拷贝到--compile指定的目录下,或者拷贝到car file中,这取决于--minimum-deployment-target的值。例如:我的项目编译后,看到的--minimum-deployment-target的值是iphone,所以icon应该会被拷贝到--compile指定的目录下。但是,macOS 10.13或者 iOS 11.0 之后的版本,icon都会被拷贝到car file文件下。部分定义的image(不存放在xcassets文件中的image)还是会生成在--compile指定的目录下。官方说这种情况未来可能会被取消。最后,这个flag还会生成一份plist文件。这个plist文件的路径和名称由--output-partial-info-plist决定。这个plist在编译的期间会被merge到项目的Info.plist文件中。我截了个图,大概是下面这个样子。

assetcatalog_generated_info.png

简单的归纳一下:就是原本actool会把所有的资源文件找到,然后“输出”到2个地方,car file--compile指定的目录下(在xcassets中的资源输出到car file,零散的资源输出到app包里)。在mac OC 10.13和iOS 11.0之后的版本,icon会被拷贝到car file中(可能苹果希望这么做吧)。但是,我对比了有无--app-icon前后的包,发现icon都在app目录下,并不存在于car file中。还是没有看出有没有这个参数的区别,后续有新发现再更新吧。
Tips:查看app包中car file的方法,个人学习之提取app以及Assets.car包中的素材

最后

简单的说,用了Cocoapods后,Xcode9打包无法发布的问题,修改Podfile文件可以达到目的。
有个小Tips,脚本里面有OTHER_XCASSETS=$(find "$PWD" -iname "*.xcassets" -type d)这样一行命令,这是Cocoapods去查找.xcassets文件的。但是它是基于$PWD目录查找的,打印发现是工程的主目录。我的项目中,.xcassets存放在了别的路径下,所以一直提示找不到AppIcon。望大家注意~还是把它移到主目录下吧

说了这么多,其实离真相还是差一点的。
如果有人知道Cocoapods产生这个问题的根本原因,望指点,谢谢!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容