iOS應(yīng)用開(kāi)發(fā)中矢量圖的使用及修改矢量圖顏色的方法
之前搗鼓了點(diǎn)東西,要適配6和Plus,自己做做切圖才發(fā)現(xiàn)確實(shí)有夠煩?;谑噶繄D生成PNG圖形的方法也是事后才知道,學(xué)習(xí)下,希望接下來(lái)可以實(shí)踐。下面進(jìn)入譯文。
iOS應(yīng)用的視覺(jué)形式通常是以圖形元素驅(qū)動(dòng)的。在設(shè)計(jì)開(kāi)發(fā)一款應(yīng)用時(shí),你需要不同規(guī)格的應(yīng)用圖標(biāo),例如不同尺寸的Default.png圖片,同時(shí)還需要為UI的實(shí)現(xiàn)準(zhǔn)備@1x和@2x圖形資源。所有這些圖形元素都會(huì)讓你的產(chǎn)品看上去更吸引人,但弊端也是很明顯的 - 你需要為每種規(guī)格的圖形元素單獨(dú)切圖。而隨著iPhone 6及Plus的發(fā)布,我們又多了一套@3x需要處理,事情變得越來(lái)越復(fù)雜。
幸運(yùn)的是,蘋(píng)果在Xcode 6當(dāng)中給我們帶來(lái)了一些很棒的工具用以管理圖形資源。更棒的是,新的工具和實(shí)現(xiàn)方式可以幫我們從容的應(yīng)對(duì)未來(lái)的iOS設(shè)備,例如基于Storyboard為iOS 8設(shè)備生成啟動(dòng)圖片,這樣你就無(wú)需再為不同的設(shè)備類(lèi)型單獨(dú)制作。此外還有一個(gè)非常重要的新功能,就是在應(yīng)用構(gòu)建階段基于PDF圖片文件自動(dòng)生成各種規(guī)格的圖形資源。本文中,我們就來(lái)一起探索一下這種能幫你節(jié)省大量時(shí)間成本的方法。
第一步:使用Illustrator生成PDF矢量圖形
首先,我們需要PDF格式的矢量圖形。你可以使用Adobe Illustrator或你所熟悉的其他矢量圖形工具來(lái)生成,@1x規(guī)格的即可。
如果你使用Illustrator:
為即將導(dǎo)出的圖形元素創(chuàng)建新文檔,使用@1x規(guī)格來(lái)設(shè)置文檔的尺寸。
將需要導(dǎo)出的圖形元素復(fù)制到新文檔當(dāng)中。
在“File”菜單中選擇“Save”。
在保存時(shí)記得取消勾選“Preserve Illustrator Editing Capabilities”。
由此導(dǎo)出的PDF是可拉伸的矢量圖形,可以在iOS中被完美的處理為@2x和@3x規(guī)格。下一步,我們看看怎樣在Xcode當(dāng)中進(jìn)行設(shè)置。
第二步:在Xcode項(xiàng)目文件中進(jìn)行設(shè)置
要使用矢量化的圖形資源,你需要在Xcode當(dāng)中通過(guò)Asset Catalog來(lái)管理圖片。不用擔(dān)心,你仍可以將標(biāo)準(zhǔn)的圖形導(dǎo)入方式與XCAssets混合起來(lái)使用,不會(huì)產(chǎn)生問(wèn)題。執(zhí)行以下步驟:
- 如果還沒(méi)有XCAsset文件,那么創(chuàng)建一個(gè)。如果已經(jīng)創(chuàng)建過(guò),就在項(xiàng)目中打開(kāi)。
- 在“Editor”菜單中選擇“New Image Set”。
- 在新創(chuàng)建的圖片集中,選擇空的圖片集,然后打開(kāi)Utilities面板。
- 選擇屬性檢查器Attributes Inspector。
- 在類(lèi)型下拉列表中,選擇“Vectors”。
- 圖片集會(huì)變?yōu)橹挥幸粋€(gè)拖放點(diǎn)的“All - Universal”。
- 將你的PDF矢量圖形拖放到圖片集當(dāng)中。
接下來(lái),你可以像以往一樣使用Image Catalog中的圖形資源,通過(guò)代碼或Interface Builder均可。例如在代碼中使用“imageNamed:”+圖片集名稱(chēng)的字符串。
第三步:見(jiàn)證神奇時(shí)刻
Xcode在構(gòu)建項(xiàng)目時(shí)會(huì)基于Asset Catalog中的PDF矢量圖形自動(dòng)創(chuàng)建@1x、@2x和@3x三種規(guī)格的PNG文件。舉例說(shuō),你為Xcode提供了一個(gè)@1x規(guī)格的,尺寸為150px*150px的PDF文件,那么Xcode會(huì)自動(dòng)創(chuàng)建下列PNG圖形:
@1x規(guī)格,尺寸為150px*150px
@2x規(guī)格,尺寸為300px*300px
@3x規(guī)格,尺寸為450px*450px
應(yīng)用運(yùn)行時(shí),iOS會(huì)根據(jù)不同的設(shè)備類(lèi)型從上面三種圖形資源中挑選出恰當(dāng)?shù)囊?guī)格進(jìn)行輸出。另外記得為AutoLayout設(shè)置好約束,確保圖形不會(huì)在大尺寸設(shè)備上被拉伸。Xcode所做的是基于PDF矢量圖形創(chuàng)建PNG文件;應(yīng)用運(yùn)行時(shí)所輸出的仍然是柵格化的圖片,而非可以自動(dòng)伸縮的矢量圖形。
注意
- 矢量圖形的支持只是階段性的 - 在構(gòu)建階段,Xcode會(huì)基于PDF生成PNG圖片并輸出到界面當(dāng)中。
- 一旦完成矢量圖形的設(shè)置,你就無(wú)法為其指定新的輸出尺寸了。如果需要更大的規(guī)格,則需要?jiǎng)?chuàng)建新的PDF圖形,否則在使用AutoLayout時(shí)原來(lái)的圖片會(huì)失真。
- 正如前面所說(shuō)的,iOS 8只能支持基于PDF生成的PNG文件;但OS X卻可以真正完整的支持矢量圖形,你可以直接通過(guò)Auto Layout或代碼來(lái)縮放矢量圖形,不會(huì)產(chǎn)生任何失真。
- 這種方式無(wú)法兼容iOS 7之前的系統(tǒng),因?yàn)橄嚓P(guān)的圖形資源都是通過(guò)Asset Catalog管理的。
- 如果你已經(jīng)使用了類(lèi)似的腳本或工具來(lái)自動(dòng)生成多種規(guī)格的圖形資源,那么這種方式不會(huì)給你帶來(lái)太多用處。不過(guò),如果你的應(yīng)用同時(shí)擁有OS X和iOS兩種版本,并且會(huì)用到一些相同的圖形,那么這種方法將會(huì)是事半功倍的。
改變矢量圖的顏色
為啥要改變矢量圖的顏色呢,直接叫設(shè)計(jì)師切個(gè)圖不就好呢。
主要最近呢,設(shè)計(jì)師回家了,沒(méi)辦法只有一張圖,我又懶的用ps。
就給自己弄了個(gè)課題。
其實(shí)也簡(jiǎn)單在ps中也不就是選中選區(qū),填充顏色,然后保存。
在iOS也是差不多的。
在iOS也是差不多的。
//UIImage+ImageColor.h
#import <UIKit/UIKit.h>
@interface UIImage (ImageColor)
/**
* 修改矢量圖顏色
*
* @param maskColor 修改顏色
* @return
*/
- (UIImage *)imageMaskWithColor:(UIColor *)maskColor;
@end
//UIImage+ImageColor.m
#import "UIImage+ImageColor.h"
@implementation UIImage (ImageColor)
- (UIImage *)imageMaskWithColor:(UIColor *)maskColor {
if (!maskColor) {
return nil;
}
UIImage *newImage = nil;
CGRect imageRect = (CGRect){CGPointZero,self.size};
UIGraphicsBeginImageContextWithOptions(imageRect.size, NO, self.scale);
CGContextRef context = UIGraphicsGetCurrentContext();
CGContextScaleCTM(context, 1.0, -1.0);
CGContextTranslateCTM(context, 0.0, -(imageRect.size.height));
CGContextClipToMask(context, imageRect, self.CGImage);//選中選區(qū) 獲取不透明區(qū)域路徑
CGContextSetFillColorWithColor(context, maskColor.CGColor);//設(shè)置顏色
CGContextFillRect(context, imageRect);//繪制
newImage = UIGraphicsGetImageFromCurrentImageContext();//提取圖片
UIGraphicsEndImageContext();
return newImage;
}
@end
總結(jié):
設(shè)計(jì)師能給你切全套那是最好的,自己也省事。
不過(guò)嘛,這個(gè)是有好處滴,可以節(jié)省app大小,可以省去按鈕的高亮、選中等等圖片。
- jQuery 生成svg矢量二維碼
- Android矢量圖之VectorDrawable類(lèi)自由填充色彩
- 如何玩轉(zhuǎn)Android矢量圖VectorDrawable
- Python計(jì)算三維矢量幅度的方法
- 百度地圖api應(yīng)用標(biāo)注地理位置信息(js版)
- android實(shí)現(xiàn)百度地圖自定義彈出窗口功能
- 通過(guò)JS獲取用戶(hù)本地圖片路徑并顯示的代碼
- 谷歌地圖打不開(kāi)的解決辦法
- js 調(diào)用百度地圖api并在地圖上進(jìn)行打點(diǎn)添加標(biāo)注
- 百度地圖API應(yīng)用之獲取用戶(hù)的具體位置
- Android下如何使用百度地圖sdk
- Android百度地圖定位后獲取周邊位置的實(shí)現(xiàn)代碼
- Android 矢量室內(nèi)地圖開(kāi)發(fā)實(shí)例
相關(guān)文章
詳解Objective-C編程中對(duì)設(shè)計(jì)模式中適的配器模式的使用
這篇文章主要介紹了Objective-C編程中對(duì)設(shè)計(jì)模式中適的配器模式的使用,適配器模式中的Adapter適配器允許接口不兼容的類(lèi)在一起工作,需要的朋友可以參考下2016-03-03iOS touch事件區(qū)分單擊雙擊響應(yīng)的方法
如果您的 iPhone 應(yīng)用里有個(gè) view,既有單擊操作又有雙擊操作。用戶(hù)雙擊 view 時(shí),總是先執(zhí)行一遍單擊的操作再執(zhí)行雙擊的操作。所以直接判斷時(shí)就會(huì)發(fā)現(xiàn)不能直接進(jìn)入雙擊操作。下面是區(qū)分 touch 事件是單擊還是雙擊的方法,需要的朋友可以參考下2016-10-10IOS開(kāi)發(fā)用戶(hù)登錄注冊(cè)模塊所遇到的問(wèn)題
最近和另外一位同事負(fù)責(zé)公司登錄和用戶(hù)中心模塊的開(kāi)發(fā)工作。通過(guò)本文給大家分享IOS開(kāi)發(fā)用戶(hù)登錄注冊(cè)模塊所遇到的問(wèn)題,感興趣的朋友一起學(xué)習(xí)吧2016-01-01iOS實(shí)現(xiàn)實(shí)時(shí)檢測(cè)網(wǎng)絡(luò)狀態(tài)的示例代碼
網(wǎng)絡(luò)連接狀態(tài)檢測(cè)對(duì)于我們的iOS開(kāi)發(fā)來(lái)說(shuō)是一個(gè)非常通用的需求。下面這篇文章主要就給大家介紹了關(guān)于利用iOS實(shí)現(xiàn)實(shí)時(shí)檢測(cè)網(wǎng)絡(luò)狀態(tài)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-07-07iOS實(shí)現(xiàn)左右拖動(dòng)抽屜效果
這篇文章主要介紹了iOS實(shí)現(xiàn)左右拖動(dòng)抽屜效果,理解ios平臺(tái)類(lèi)似于QQ主頁(yè)面,利用觸摸事件滑動(dòng)touchesMoved實(shí)現(xiàn)的效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-02-02淺談Unity中IOS Build Settings選項(xiàng)的作用
下面小編就為大家分享一篇淺談Unity中IOS Build Settings選項(xiàng)的作用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01