利用Python為iOS10生成圖標(biāo)和截屏
簡介
這兩天更新完Xcode8之后發(fā)現(xiàn)Xcode對圖標(biāo)的要求又有了變化,之前用的一個(gè)小應(yīng)用“IconKit”還沒趕上節(jié)奏,已經(jīng)不能滿足Xcode8的要求了。
于是就想起來用Python自己做個(gè)腳本來生成圖標(biāo)。
其實(shí)這個(gè)腳本很早就寫了,現(xiàn)在為了適應(yīng)iOS10,就修改完善下,并且放到了GitHub。
可以看看效果圖:
1.png
代碼:
#encoding=utf-8
#by 不滅的小燈燈
#create date 2016/5/22
#update 2016/9/21
#support iOS 10
#site www.winterfeel.com
import os
import sys
from PIL import Image
iosSizes = ['20@1x','20@2x','20@3x','29@1x','29@2x','29@3x','40@1x','40@2x','40@3x','60@2x','60@3x','60@3x','76@1x','76@2x','167@1x']
androidSizes = [32,48,72,96,144,192]
androidNames = ['ldpi','mdpi','hdpi','xhdpi','xxhdpi','xxxhdpi']
sizesiOS = [(640,960),(640, 1136),(750, 1334),(1242, 2208),(1536, 2048),(2048, 2732)]
foldersiOS = ['iPhone4s','iPhone5','iPhone6','iPhone6plus','iPad','iPadLarge']
sizesAndroid = [(480,800),(720,1280),(1080,1920)]
foldersAndroid = ['480x800','720x1280','1080x1920']
def processIcon(filename,platform):
icon = Image.open(filename).convert("RGBA")
if icon.size[0] != icon.size[1]:
print 'Icon file must be a rectangle!'
return
if platform == 'android':
#安卓圓角
mask = Image.open('mask.png')
r,g,b,a = mask.split()
icon.putalpha(a)
if not os.path.isdir('androidIcon'):
os.mkdir('androidIcon')
index = 0
for size in androidSizes:
im = icon.resize((size,size),Image.BILINEAR)
im.save('androidIcon/icon-'+ androidNames[index]+'.png')
index = index + 1
else:
if not os.path.isdir('iosIcon'):
os.mkdir('iosIcon')
for size in iosSizes:
originalSize = int(size.split('@')[0])#原始尺寸
multiply = int(size.split('@')[1][0:1])#倍數(shù)
im = icon.resize((originalSize*multiply,originalSize*multiply),Image.BILINEAR)
im.save('iosIcon/icon'+size+'.png')
print 'Congratulations!It\'s all done!'
def walk_dir(dir,platform):
files = os.listdir(dir)
for name in files:
if name.split('.')[-1] == 'jpg' or name.split('.')[-1] == 'png':#處理jpg和png
produceImage(name,platform)
print 'Congratulations!It\'s all done!'
def produceImage(filename,platform):
print 'Processing:' + filename
img = Image.open(filename)
index = 0
sizes = sizesiOS
folders = foldersiOS
if platform == 'android':#默認(rèn)ios,如果是安卓
sizes = sizesAndroid
folders = foldersAndroid
for size in sizes:
if not os.path.isdir(folders[index]):
os.mkdir(folders[index])
if img.size[0] > img.size[1]:#如果是橫屏,交換坐標(biāo)
im = img.resize((size[1],size[0]),Image.BILINEAR)
im.save(folders[index]+'/'+filename)
else:
im = img.resize(size,Image.BILINEAR)
im.save(folders[index]+'/'+filename)
index = index + 1
action = sys.argv[1]#action:icon or screenshot
if action == 'screenshot':
platform = sys.argv[2]#platform
if platform == 'ios':
walk_dir('./','ios')
elif platform == 'android':
walk_dir('./','android')
else:
print 'Hey,Platform can only be "ios" or "android" !'
elif action == 'icon':
filename = sys.argv[2]#image filename
platform = sys.argv[3]#platform
if not os.path.exists(filename):
print 'Hey,File Not Found!'
else:
if platform == 'ios':
processIcon(filename,'ios')
elif platform == 'android':
processIcon(filename,'android')
else:
print 'Hey,Platform can only be "ios" or "android" !'
else:
print 'Hey,action can only be "icon" or "screenshot" !'
腳本環(huán)境要求
Python 2.7
PIL or Pillow
筆者親測,也許是筆者太菜,試了各種方法安裝PIL總是出錯(cuò),最后還是用了Pillow,效果一樣的。
怎么使用腳本
在Windows的命令行或者M(jìn)ac的終端,輸入:
python tool.py [action] [filename] [platform]
action:icon 或者 screenshot
filename:圖標(biāo)文件名,截屏不需要文件名,自動(dòng)遍歷
platform:ios 或者 android
舉一些例子:
生成iOS的圖標(biāo):python tool.py icon icon.jpg ios
生成安卓的圖標(biāo):python tool.py icon icon.jpg android
生成iOS的截屏:python tool.py screenshot ios
生成安卓的截屏:python tool.py screenshot android
注意:
生成安卓圓角圖標(biāo)需要一張PNG來裁剪,尺寸512x512,70圓角,GitHub中已經(jīng)附帶。
生成截屏?xí)r會(huì)自動(dòng)遍歷所有JPG和PNG文件,自動(dòng)識(shí)別橫豎屏
結(jié)語
如果你覺得有用,歡迎在GitHub中Star一下,也歡迎改進(jìn),代碼簡單易懂加了注釋。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python使用smtp和pop簡單收發(fā)郵件完整實(shí)例
這篇文章主要介紹了Python使用smtp和pop簡單收發(fā)郵件完整實(shí)例,簡單介紹了smtp和pop,然后分享了相關(guān)實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01
Python數(shù)學(xué)符號(hào)計(jì)算庫SymPy使用方法詳解
SymPy?是一個(gè)?Python?的數(shù)學(xué)符號(hào)計(jì)算庫,提供了強(qiáng)大的工具來進(jìn)行符號(hào)數(shù)學(xué)運(yùn)算、代數(shù)操作、求解方程、微積分、矩陣運(yùn)算等,它廣泛應(yīng)用于數(shù)學(xué)教學(xué)、物理學(xué)、工程學(xué)、統(tǒng)計(jì)學(xué)和概率論等領(lǐng)域,本文將結(jié)合具體案例,詳細(xì)介紹?SymPy?的使用方法,需要的朋友可以參考下2024-08-08
pandas實(shí)戰(zhàn):分析三國志人物示例實(shí)現(xiàn)
這篇文章主要介紹了pandas實(shí)戰(zhàn):分析三國志人物示例實(shí)現(xiàn),本文章內(nèi)容詳細(xì),具有很好的參考價(jià)值,希望對大家有所幫助,需要的朋友可以參考下2023-01-01
python+pygame實(shí)現(xiàn)坦克大戰(zhàn)
這篇文章主要為大家詳細(xì)介紹了python+pygame實(shí)現(xiàn)坦克大戰(zhàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
Python2.X/Python3.X中urllib庫區(qū)別講解
本篇文章通過對比給大家詳細(xì)講解了在Python2和Python3中urllib庫區(qū)別以及用法講解,有需要的朋友跟著學(xué)習(xí)下吧。2017-12-12
Python HTTP客戶端自定義Cookie實(shí)現(xiàn)實(shí)例
這篇文章主要介紹了Python HTTP客戶端自定義Cookie實(shí)現(xiàn)實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-04-04
Python應(yīng)用開發(fā)頻繁假死的問題分析及解決
最近在開發(fā)一款自動(dòng)化的應(yīng)用,但是,在測試時(shí),卻發(fā)現(xiàn)了問題,當(dāng)我點(diǎn)擊暫停任務(wù)后,此時(shí)子線程被阻塞,如果我這個(gè)時(shí)候點(diǎn)擊停止,那么就會(huì)任務(wù)結(jié)束,之后,如果我再點(diǎn)擊開始運(yùn)行,整個(gè)應(yīng)用就會(huì)卡死,所以本文介紹了Python應(yīng)用開發(fā)頻繁假死的問題分析及解決,需要的朋友可以參考下2024-08-08

