iOS APP圖標(biāo)版本化

一花墩、需求背景

在我們的項(xiàng)目開(kāi)發(fā)過(guò)程中澄步,需要頻繁打包給測(cè)試人員去測(cè)試村缸,有時(shí)候我們都不知道測(cè)試機(jī)上安裝的版本是否是最新的王凑,這樣會(huì)造成很多不必要的麻煩和成本聋丝。因此我們需要將buildNumber以水印的方式打在A(yíng)PPIcon上弱睦,可以很直觀(guān)的知道當(dāng)前是哪一個(gè)版本。

二垒拢、需求分析

1求类、如何動(dòng)態(tài)更新圖標(biāo)

Xcode在build過(guò)程中可以執(zhí)行Script腳本屹耐,我們可以利用Script在程序運(yùn)行之前做很多我們想做的事情尸疆。

2、如何打水印

ImageMagick 免費(fèi)的圖片處理插件惶岭,同時(shí)支持多種語(yǔ)言寿弱。
github
官網(wǎng)

三、實(shí)現(xiàn)

1按灶、ImageMagick安裝

有兩種安裝方式症革,具體可以看這里 ,推薦大家使用第一種鸯旁,因?yàn)槲以跍y(cè)試第二種安裝的時(shí)候碰到了很多坑噪矛,需要自己安裝依賴(lài),不然很多方法使用不了摩疑。

安裝
brew install imagemagick

檢查是否安裝成功

是否安裝成功
identify -version

2危融、Xcode項(xiàng)目配置

2.1 AppIcon配置


這里我使用的是唔哩頭條的icon,并新建一個(gè)AppIcon-Debug 用于存放Debug的圖標(biāo)雷袋,后面我們打水印生成的圖標(biāo)會(huì)存放到這里吉殃。


設(shè)置Debug模式下圖標(biāo)為剛才新建的圖標(biāo)組

2.2 腳本配置

我們?cè)陧?xiàng)目路徑下新建一個(gè)腳本文件并執(zhí)行

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

需要賦予可執(zhí)行權(quán)限

$ chmod +x JCIconVersion.sh

再次執(zhí)行

$ ./JCIconVersion.sh
hellow world

腳本創(chuàng)建完了并賦予了可執(zhí)行權(quán)限,我們現(xiàn)在將他配置到Xcode中楷怒。
先將他添加到項(xiàng)目中蛋勺,然后在Build Phases中添加Run Script。
注意填寫(xiě)正確的腳本路徑


然后我們build一下項(xiàng)目




在這里能看到我們每次Build狀態(tài)鸠删,以及腳本運(yùn)行情況抱完。
下面就進(jìn)入腳本代碼的編寫(xiě)。

3刃泡、Shell腳本編寫(xiě)

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環(huán)境的appIcon文件名
DEBUG_APPICON_NAME="${APPICON_NAME}-Debug"

# 獲取app版本號(hào)
APP_VERSION=$(/usr/libexec/PlistBuddy -c 'Print CFBundleShortVersionString' "${INFOPLIST_FILE}")

# 獲取build號(hào)
APP_BUILD_NUM=$(/usr/libexec/PlistBuddy -c 'Print CFBundleVersion' "${INFOPLIST_FILE}")

# Icon上顯示的文字內(nèi)容, 你可以在這里修改標(biāo)題格式
CAPTION="$APP_VERSION\n($APP_BUILD_NUM)"

3.3 復(fù)制AppIcon到AppIcon-Debug

######################################################
# 3. 復(fù)制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

# 復(fù)制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"

總結(jié)


效果如上圖禁添,水印效果還不太完善,imagemagick里面還有很多強(qiáng)大的api桨踪,能實(shí)現(xiàn)更加炫酷的效果老翘,感興趣的同學(xué)可以看看這里,有時(shí)間我也會(huì)完善一下锻离。

最后附上Demo下載地址:Demo下載

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末铺峭,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子汽纠,更是在濱河造成了極大的恐慌卫键,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件虱朵,死亡現(xiàn)場(chǎng)離奇詭異永罚,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)卧秘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)呢袱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人翅敌,你說(shuō)我怎么就攤上這事羞福。” “怎么了蚯涮?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵治专,是天一觀(guān)的道長(zhǎng)卖陵。 經(jīng)常有香客問(wèn)我,道長(zhǎng)张峰,這世上最難降的妖魔是什么泪蔫? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮喘批,結(jié)果婚禮上撩荣,老公的妹妹穿的比我還像新娘。我一直安慰自己饶深,他們只是感情好餐曹,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著敌厘,像睡著了一般台猴。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上俱两,一...
    開(kāi)封第一講書(shū)人閱讀 52,475評(píng)論 1 312
  • 那天饱狂,我揣著相機(jī)與錄音,去河邊找鬼宪彩。 笑死休讳,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的毯焕。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼磺樱,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼纳猫!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起竹捉,我...
    開(kāi)封第一講書(shū)人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤芜辕,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后块差,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體侵续,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年憨闰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了状蜗。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡鹉动,死狀恐怖轧坎,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情泽示,我是刑警寧澤缸血,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布蜜氨,位于F島的核電站,受9級(jí)特大地震影響捎泻,放射性物質(zhì)發(fā)生泄漏飒炎。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一笆豁、第九天 我趴在偏房一處隱蔽的房頂上張望郎汪。 院中可真熱鬧,春花似錦渔呵、人聲如沸怒竿。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)耕驰。三九已至,卻和暖如春录豺,著一層夾襖步出監(jiān)牢的瞬間朦肘,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工双饥, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留媒抠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓咏花,卻偏偏與公主長(zhǎng)得像趴生,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子昏翰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容