亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS應用開發中矢量圖的使用及修改矢量圖顏色的方法

2020-07-26 03:26:45
字體:
來源:轉載
供稿:網友

20163391148793.jpg (525×497)

之前搗鼓了點東西,要適配6和Plus,自己做做切圖才發現確實有夠煩?;谑噶繄D生成PNG圖形的方法也是事后才知道,學習下,希望接下來可以實踐。下面進入譯文。

iOS應用的視覺形式通常是以圖形元素驅動的。在設計開發一款應用時,你需要不同規格的應用圖標,例如不同尺寸的Default.png圖片,同時還需要為UI的實現準備@1x和@2x圖形資源。所有這些圖形元素都會讓你的產品看上去更吸引人,但弊端也是很明顯的 - 你需要為每種規格的圖形元素單獨切圖。而隨著iPhone 6及Plus的發布,我們又多了一套@3x需要處理,事情變得越來越復雜。

幸運的是,蘋果在Xcode 6當中給我們帶來了一些很棒的工具用以管理圖形資源。更棒的是,新的工具和實現方式可以幫我們從容的應對未來的iOS設備,例如基于Storyboard為iOS 8設備生成啟動圖片,這樣你就無需再為不同的設備類型單獨制作。此外還有一個非常重要的新功能,就是在應用構建階段基于PDF圖片文件自動生成各種規格的圖形資源。本文中,我們就來一起探索一下這種能幫你節省大量時間成本的方法。

第一步:使用Illustrator生成PDF矢量圖形

首先,我們需要PDF格式的矢量圖形。你可以使用Adobe Illustrator或你所熟悉的其他矢量圖形工具來生成,@1x規格的即可。

如果你使用Illustrator:

為即將導出的圖形元素創建新文檔,使用@1x規格來設置文檔的尺寸。
將需要導出的圖形元素復制到新文檔當中。
在“File”菜單中選擇“Save”。
在保存時記得取消勾選“Preserve Illustrator Editing Capabilities”。

20163391241063.jpg (521×409)

由此導出的PDF是可拉伸的矢量圖形,可以在iOS中被完美的處理為@2x和@3x規格。下一步,我們看看怎樣在Xcode當中進行設置。

第二步:在Xcode項目文件中進行設置

要使用矢量化的圖形資源,你需要在Xcode當中通過Asset Catalog來管理圖片。不用擔心,你仍可以將標準的圖形導入方式與XCAssets混合起來使用,不會產生問題。執行以下步驟:

  • 如果還沒有XCAsset文件,那么創建一個。如果已經創建過,就在項目中打開。
  • 在“Editor”菜單中選擇“New Image Set”。
  • 在新創建的圖片集中,選擇空的圖片集,然后打開Utilities面板。
  • 選擇屬性檢查器Attributes Inspector。
  • 在類型下拉列表中,選擇“Vectors”。
  • 圖片集會變為只有一個拖放點的“All - Universal”。
  • 將你的PDF矢量圖形拖放到圖片集當中。

20163391258695.jpg (542×313)

接下來,你可以像以往一樣使用Image Catalog中的圖形資源,通過代碼或Interface Builder均可。例如在代碼中使用“imageNamed:”+圖片集名稱的字符串。

第三步:見證神奇時刻

Xcode在構建項目時會基于Asset Catalog中的PDF矢量圖形自動創建@1x、@2x和@3x三種規格的PNG文件。舉例說,你為Xcode提供了一個@1x規格的,尺寸為150px*150px的PDF文件,那么Xcode會自動創建下列PNG圖形:

@1x規格,尺寸為150px*150px
@2x規格,尺寸為300px*300px
@3x規格,尺寸為450px*450px
應用運行時,iOS會根據不同的設備類型從上面三種圖形資源中挑選出恰當的規格進行輸出。另外記得為AutoLayout設置好約束,確保圖形不會在大尺寸設備上被拉伸。Xcode所做的是基于PDF矢量圖形創建PNG文件;應用運行時所輸出的仍然是柵格化的圖片,而非可以自動伸縮的矢量圖形。

注意

  • 矢量圖形的支持只是階段性的 - 在構建階段,Xcode會基于PDF生成PNG圖片并輸出到界面當中。
  • 一旦完成矢量圖形的設置,你就無法為其指定新的輸出尺寸了。如果需要更大的規格,則需要創建新的PDF圖形,否則在使用AutoLayout時原來的圖片會失真。
  • 正如前面所說的,iOS 8只能支持基于PDF生成的PNG文件;但OS X卻可以真正完整的支持矢量圖形,你可以直接通過Auto Layout或代碼來縮放矢量圖形,不會產生任何失真。
  • 這種方式無法兼容iOS 7之前的系統,因為相關的圖形資源都是通過Asset Catalog管理的。
  • 如果你已經使用了類似的腳本或工具來自動生成多種規格的圖形資源,那么這種方式不會給你帶來太多用處。不過,如果你的應用同時擁有OS X和iOS兩種版本,并且會用到一些相同的圖形,那么這種方法將會是事半功倍的。

改變矢量圖的顏色

為啥要改變矢量圖的顏色呢,直接叫設計師切個圖不就好呢。

主要最近呢,設計師回家了,沒辦法只有一張圖,我又懶的用ps。

就給自己弄了個課題。

其實也簡單在ps中也不就是選中選區,填充顏色,然后保存。

在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);//選中選區 獲取不透明區域路徑
    CGContextSetFillColorWithColor(context, maskColor.CGColor);//設置顏色
    CGContextFillRect(context, imageRect);//繪制

    newImage = UIGraphicsGetImageFromCurrentImageContext();//提取圖片

    UIGraphicsEndImageContext();
    return newImage;
}
@end


總結:
設計師能給你切全套那是最好的,自己也省事。
不過嘛,這個是有好處滴,可以節省app大小,可以省去按鈕的高亮、選中等等圖片。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美精品在线网站| 国产精品久久久久久av福利软件| 亚洲人成电影在线观看天堂色| 国产精品精品视频| 欧美大片大片在线播放| 日本午夜人人精品| 日韩欧美在线第一页| 国产精品毛片a∨一区二区三区|国| 日本一欧美一欧美一亚洲视频| 97在线视频一区| 国产精品久久久999| 欧美中文字幕视频| www.日韩不卡电影av| 国产日韩视频在线观看| 久久久成人av| 久久成年人视频| 欧美视频专区一二在线观看| 国产va免费精品高清在线观看| 欧美精品videosex牲欧美| 一本色道久久综合狠狠躁篇怎么玩| 欧美激情一区二区三区在线视频观看| 国产性猛交xxxx免费看久久| 成人国产精品日本在线| 国产精品女主播| 欧美美女18p| 亚洲综合色激情五月| 久久久免费精品| 亚洲国产精品嫩草影院久久| 91在线视频免费| 久久久www成人免费精品张筱雨| 久久精品国产免费观看| 日韩成人在线电影网| 欧美激情videos| 亚洲图片欧美日产| 激情久久av一区av二区av三区| 岛国av一区二区在线在线观看| 国产精品自产拍在线观| 国产精品亚洲一区二区三区| 欧美日韩国产91| 亚洲成av人影院在线观看| 国产精品扒开腿做爽爽爽男男| 欧美老妇交乱视频| 久久久av电影| 午夜精品美女自拍福到在线| 日韩电影中文字幕av| 亚洲视频电影图片偷拍一区| 2019国产精品自在线拍国产不卡| 亚洲欧美一区二区三区情侣bbw| 亚洲精品一区av在线播放| 在线日韩中文字幕| 久久久久久久香蕉网| 欧美大片免费观看在线观看网站推荐| 国产女人18毛片水18精品| 久久综合伊人77777蜜臀| 国产精品女人网站| 欧美另类在线观看| 欧美日韩在线观看视频小说| 最近2019中文字幕在线高清| 久久精品91久久久久久再现| 日本一区二区三区在线播放| 日韩成人在线视频网站| 日韩美女视频免费看| 国产精品极品美女在线观看免费| 亚洲三级黄色在线观看| 欧美在线视频免费| 国产精品高精视频免费| 精品中文字幕在线观看| 亚洲国产成人久久综合一区| 青青草成人在线| 在线视频中文亚洲| 国产69精品久久久久久| 欧美激情综合色综合啪啪五月| 亚洲男人的天堂在线| 国产精品视频导航| 成人av在线天堂| 欧美最顶级丰满的aⅴ艳星| 午夜精品国产精品大乳美女| 夜夜嗨av色一区二区不卡| 久久久久久国产精品美女| 清纯唯美亚洲综合| 5566成人精品视频免费| 成人夜晚看av| 国产噜噜噜噜久久久久久久久| 欧美亚洲免费电影| 久久国产天堂福利天堂| 日韩精品高清在线| www.欧美三级电影.com| 色综合色综合网色综合| 国语自产精品视频在线看一大j8| 亚洲永久在线观看| 久久久免费在线观看| 日韩av高清不卡| 国产精品吊钟奶在线| 亚洲自拍偷拍第一页| 国产精品久久久久久久久久久不卡| 成人免费在线网址| 久久精品国产亚洲7777| 97超级碰在线看视频免费在线看| 成人福利网站在线观看11| 国产免费一区二区三区香蕉精| 日韩三级成人av网| 日韩精品极品视频| 一夜七次郎国产精品亚洲| 日本午夜在线亚洲.国产| 亚洲热线99精品视频| 日韩av网站导航| 国产99视频在线观看| 最近免费中文字幕视频2019| 欧美国产中文字幕| 久久精品影视伊人网| 久久五月情影视| 国产精品久久久久久久久久久新郎| 68精品久久久久久欧美| 亚洲欧洲美洲在线综合| 亚洲精品中文字幕av| 中文字幕一区电影| 日韩美女免费观看| 91网站在线看| 亚洲一区二区三区视频播放| 日韩最新中文字幕电影免费看| 亚洲色图第三页| 欧美中文字幕在线观看| 久久99精品久久久久久青青91| 国产精品99蜜臀久久不卡二区| 欧美成人h版在线观看| 久久精品视频中文字幕| 国产视频亚洲视频| 日韩中文综合网| 欧美日韩亚洲一区二| 亚洲亚裔videos黑人hd| 日韩天堂在线视频| 欧美精品在线第一页| 日韩有码在线观看| 尤物99国产成人精品视频| 国产日韩av在线| 日韩免费观看av| 色综合久久悠悠| 久久久www成人免费精品张筱雨| 日韩av在线免播放器| 最近2019年日本中文免费字幕| 成人a级免费视频| 亚洲女在线观看| 欧美日韩午夜视频在线观看| 亚洲va码欧洲m码| 日韩中文字幕国产| 欧美精品中文字幕一区| 91系列在线观看| 国产精品丝袜视频| 欧美在线视频免费观看| 亚洲国产精品系列| 91免费的视频在线播放| 伊人男人综合视频网| 亚洲成在人线av| 久久国产精品99国产精| 亚洲精品午夜精品| 午夜精品久久久久久久99热| 国产精品第七十二页| 亚洲欧美激情在线视频| 精品动漫一区二区三区| 国产福利视频一区二区| 中文字幕在线国产精品| 中文字幕精品—区二区| 日韩av有码在线| 亚洲国内精品在线|