如何更换 App icon
每逢重大节日,App icon 就要跟一波“潮流”做一次更换,节日过后再换回普通。如何保证这两次切换流程丝滑顺畅呢?
应用内需要更换的 icon 包括两处,一个是 App 主 icon,默认放在 xcassets 里面,另一个就是 App 内部页面所使用的 icon。
App 主 icon 更换
苹果这边需要的 icon 实在太多了,如果像我们 App 一样支持 iPad 那么大大小小的 icon 就需要 18 张,就算让设计师同学给到所有需要的尺寸我们自己在 .xcassets 一一对应起来也是超级麻烦,如果我们只需要提供一张高清图(1024x1024 pixel)剩下的能通过工具自动对应起来该多好啊!
研究xcassets结构后发现,AppIcon 类型的图片是一个后缀名为 appiconset 的文件夹,该文件夹里面除了有 APP 需要的各种尺寸的 png 图片外,还有一个 Contents.json 文件,形如:
{
"images" : [
{
"size" : "20x20",
"idiom" : "iphone",
"filename" : "IOS_40-2.png",
"scale" : "2x"
},
{
"size" : "83.5x83.5",
"idiom" : "ipad",
"filename" : "IOS_167.png",
"scale" : "2x"
},
{
"size" : "1024x1024",
"idiom" : "ios-marketing",
"filename" : "IOS_1024.png",
"scale" : "1x"
}
],
"info" : {
"version" : 1,
"author" : "xcode"
}
}
描述了了各种尺寸的图片如何与文件夹中的 png 图片对应,我们按照此规律便可以写一个更换 AppIcon 的工具。
之前确实听说过有自动生成这种 icon 的工具 App 但我没有使用过,要为如此一个小功能下载一个 App 我觉得太不环保了。还是自己写一个脚本实现比较低碳。下面是 python 程序和注释
# !/usr/local/bin/python3
# _*_ coding:utf-8 _*_
__doc__="""
输入:一个 1024*1024 的 png 图片
输出: AppIconxxxxx.appiconset 目录,包含 iPhone 和 iPad 所需的 App Icons
"""
import os,sys
import imghdr
import json
import random,shutil
from PIL import Image,ImageFile
class FileSet:
def __init__(self,filename,scale):
self.filename = filename
self.scale = scale
@classmethod
def fileset(cls,scale,size,prefix):
filename = "{}.{}.{}.png".format(size,scale,prefix)
file_set = FileSet(filename,scale)
return file_set
class ImageSet:
def __init__(self,size,idiom,filesets):
self.size = size # 单边
self.idiom = idiom
self.filesets = filesets # 数组,包含文件名,一个 size 可能有多个 scale,所有会有多个文件 set
def json_desc(self):
descs = []
for fileset in self.filesets:
json_dict = {"size":"{}x{}".format(self.size,self.size),
"idiom":self.idiom,
"filename":fileset.filename,
"scale":"{}x".format(fileset.scale)}
descs.append(json_dict)
return descs
@classmethod
def iPhone_set(cls,size,filesets):
return ImageSet(size,'iphone',filesets)
@classmethod
def iPad_set(cls,size,filesets):
return ImageSet(size,'ipad',filesets)
@classmethod
def market_set(cls,file_prefix=''):
size = 1024
return ImageSet(size,idiom='ios-marketing',filesets=[FileSet.fileset(1,size,file_prefix)])
def get_img_sets(iPad=False,iPhone=False,file_prefix=''):
img_sets = []
if iPad:
for size in [20,29,40,76]:
file_sets = [FileSet.fileset(2,size,file_prefix),FileSet.fileset(1,size,file_prefix)]
one_set = ImageSet.iPad_set(size,file_sets)
img_sets.append(one_set)
img_sets.append(ImageSet.iPad_set(83.5,[FileSet.fileset(2,83.5,file_prefix)]))
if iPhone:
for size in [20,29,40,60]:
file_sets = [FileSet.fileset(2,size,file_prefix),FileSet.fileset(3,size,file_prefix)]
one_set = ImageSet.iPhone_set(size,file_sets)
img_sets.append(one_set)
img_sets.append(ImageSet.market_set(file_prefix))
return img_sets
def create_appicon_set(imgobj,t_path='',iPad=False,iPhone=True):
rand_str = str(random.randint(20000,2147483648))
t_folder_path = os.path.join(t_path,"AppIcon"+ rand_str +".appiconset")
os.makedirs(t_folder_path)
img_sets = get_img_sets(iPad=iPad,iPhone=iPhone,file_prefix=rand_str)
contents = {"info":{"version":1,"author":"xcode"}}
images = []
for single_set in img_sets:
for fileset in single_set.filesets:
scale_size = (int(single_set.size * fileset.scale), int(single_set.size * fileset.scale))
img_obj = imgobj.resize(scale_size,Image.ANTIALIAS)
real_path = os.path.join(t_folder_path,fileset.filename)
img_obj.save(real_path)
print("保存文件{},\t路径:{}".format(scale_size,real_path))
images += single_set.json_desc()
contents["images"] = images
with open(os.path.join(t_folder_path,"Contents.json"),"w") as wf:
wf.write(json.dumps(contents,indent=4))
if __name__ == '__main__':
argvs = sys.argv[1:] if len(sys.argv) == 3 else None
if not argvs:
print("Fatal: 要求两个参数,第一个是图片路径,第二个是目标目录")
sys.exit(-1)
o_img_path,t_path = argvs
if not os.path.isfile(o_img_path) or not imghdr.what(o_img_path) in ['png']:
print("Fatal: 图片路径不存在或者非 png 格式图片")
sys.exit(-1)
if not os.path.isdir(t_path):
print("Fatal: 目标路径不存在或者非目录")
sys.exit(-1)
o_img = Image.open(o_img_path)
if (1024,1024) != o_img.size :
print("Fatal: 图片非 1024x1024 pixel 尺寸")
sys.exit(-1)
"""
碰到设计师犯糊,将肉眼看不见但确实带有 Alpha 通道的图片提供给我们,直到我们在提交 App Store 的那一刻苹果报错说带有 Alpha 通道,然后我们又要重新走一遍流程
如何更换 App icon的更多相关文章
- 【转】【iOS】动态更换App图标
原文网址:http://www.cocoachina.com/ios/20170619/19557.html 前言 动态更换App图标这件事,在用户里总是存在需求的:有些用户喜欢“美化”自己的手机.至 ...
- 在设置app icon时的问题
APP 运行时遇到 the app icon set named appicon did not have any applicable content 是应该考虑是icon可能偏大
- [摘抄]iOS App icon、启动页、图标规范
以下内容都是我在做App时通过自己的经验和精品的分析得来的,希望会帮助到你.但是有时个别情况也要个别分析,要活学活用. 一. App Icon 在设计iOS App Icon时,设计师不需要切圆角, ...
- [iOS]The app icon set named "AppIcon" did not have any applicable content.
Develop Tools: xCode 5.1 I write a demo for app settings feature. The tutorial url is here. When I a ...
- App Icon生成工具(转载)
原地址:http://www.cocoachina.com/bbs/read.php?tid=290247 下载软件:在AppStore搜索App Icon Gear 打开软件 决定制作启动图或图标, ...
- 【初级为题,大神绕道】The app icon set named "AppIcon" did not have any applicable content 错误#解决方案#
The app icon set named "AppIcon" did not have any applicable content 错误,怎样解决 按照您的错误提示您应该 ...
- mac app icon 设置
mac app icon 设置 1:目前 mac app 所需要的icon 图标尺寸 icon_16x16.png 16px icon_16x16@2x.png 32px icon_32x32.png ...
- iOS App Icon图标 尺寸规范
Commit to AppStore:1024*1024 //for App IconIcon-60@3x.png:180*180 //iPhone 6 Plus (@3x)Icon-60@2x.pn ...
- The app icon set named "AppIcon" did not have any applicable content.
Develop Tools: xCode 5.1 I write a demo for app settings feature. The tutorial url is here. When I a ...
随机推荐
- NLP自然语言处理入门-- 文本预处理Pre-processing
引言 自然语言处理NLP(nature language processing),顾名思义,就是使用计算机对语言文字进行处理的相关技术以及应用.在对文本做数据分析时,我们一大半的时间都会花在文本预处理 ...
- Mac 下 Docker 运行较慢的原因分析及个人见解
在mac 使用 docker 的时候,我总感觉程序在 docker 下运行速度很慢,接下来我一一分析我遇到的问题,希望大家能进行合理的讨论和建议. 问题: valet 下打开 laravel 首页耗时 ...
- 使用AtomicStampedReference<T>的大坑
//在初始化的时候会把引用和时间戳存到pair中 AtomicStampedReference<Integer> integerAtomicStampedReference = new A ...
- 程序员过关斩将-- 喷一喷坑爹的面向UI编程
摒弃面向UI编程 为何喷起此次话题,因为前不久和我们首席架构师沟通,谈起程序设计问题,一不小心把UI扯进来,更把那些按照UI来编程的后台工程师也扯了进来.今天特意百度了一下(其实程序员应该去googl ...
- JVM笔记-运行时内存区域划分
1. 概述 Java 虚拟机在执行 Java 程序的过程中会把它管理的内存划分为若干个不同的数据区域.它们各有用途,有些随着虚拟机进程的启动一直存在(堆.方法区),有些则随着用户线程的启动和结束而建立 ...
- 5.创建app、创建user表、配置media、数据迁移
目录 user模块User表 创建user模块 创建User表对应的model:user/models.py 注册user模块,配置User表:dev.py 配置media 数据库迁移 user模块U ...
- 页面高度自适应方法(PC、移动端都适用)
有个项目移动端的首页需要自适应. 宽度已经自适应了 , 高度也要自适应 ,先总结一下方法,PC端也适用. $(function(){ var h = window.innerHeight; $(&qu ...
- 金三银四,还在为spring源码发愁吗?bean生命周期,看了这篇就够了
第一,这绝对是一个面试高频题. 比第一还重要的第二,这绝对是一个让人爱恨交加的面试题.为什么这么说?我觉得可以从三个方面来说: 先说会不会.看过源码的人,这个不难:没看过源码的人,无论是学.硬背.还是 ...
- 嵌入式LCD闪烁--emWin使用内存设备避免闪烁
0.引子 近日在论坛看到有人说屏幕闪烁,问道怎么解决.在嵌入式gui使用方面,屏幕闪烁一般多出现在多个窗口层叠.多图层层叠.更新图层时.受限于接口速度,即使屏幕有很高的刷新率,也做不到无闪烁,所以要从 ...
- 插了带蠕虫的U盘后,文件不见了怎么快速恢复
朋友插了别人U盘,电脑中毒,找到我,在网上找了一些教程,好多都是用杀软的,懒的下,亲测本教程简单有效 首先,我们创建了一个reg文件(注册表文件),如下, 利用REG文件我们可以直接对注册表进行任何修 ...