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

首頁(yè) > 編程 > Swift > 正文

Swift操作Quartz 2D進(jìn)行簡(jiǎn)單的繪圖與坐標(biāo)變換的教程

2020-03-09 17:48:49
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
這篇文章主要介紹了Swift操作Quartz 2D進(jìn)行簡(jiǎn)單的繪圖與坐標(biāo)變換的教程,Quartz 2D是Core Graphics框架中的一個(gè)重要組件,經(jīng)常被Mac OS或和iOS開發(fā)者用來(lái)繪圖,需要的朋友可以參考下
 

Quartz 2D簡(jiǎn)介
Quartz 2D是蘋果公司開發(fā)的一個(gè)二維圖形繪制引擎,同時(shí)支持iOS和Mac系統(tǒng)。

它是一套基于C的API框架,提供了低級(jí)別、輕量級(jí)、高保真度的2D渲染。它能完成的工作有:

  • 繪制圖形 : 線條/三角形/矩形/圓/弧等
  • 繪制文字
  • 繪制/生成圖片(圖像)
  • 讀取/生成PDF
  • 截圖/裁剪圖片
  • 自定義UI控件

Quartz 2D進(jìn)行繪圖
iOS繪圖技術(shù)主要有UIKit,Quartz 2D,Core Animation和OpenGL ES。我們平常對(duì)UIKit應(yīng)該不陌生,而Quartz 2D與UIKit的一個(gè)區(qū)別是:
Quartz 2D的坐標(biāo)原點(diǎn)在左下角,而UIKit的坐標(biāo)原點(diǎn)在左上角。
在開始前作下準(zhǔn)備工作:創(chuàng)建一個(gè)新的Cocoa Touch Class,繼承自UIView,然后去StoryBoard把view視圖關(guān)聯(lián)下新創(chuàng)建的類。

1.填充和描邊
重寫繪圖方法drawRect(),添加代碼:

復(fù)制代碼代碼如下:

 override func drawRect(rect: CGRect) {
     //填充背景
     UIColor.brownColor().setFill()
     //填充矩形
     UIRectFill(rect)
     UIColor.whiteColor().setStroke()
     //矩形描邊
     let frame = CGRectMake(10, 24, 100, 300)
     UIRectFrame(frame)
}

運(yùn)行效果:

 

Swift,Quartz 2D

 

2.繪制三角形
確定三個(gè)點(diǎn)就能繪制出三角形,當(dāng)然其他的圖形(如矩形)也是類似。
在drawRect()里添加代碼:

復(fù)制代碼代碼如下:

override func drawRect(rect: CGRect) {
    let context = UIGraphicsGetCurrentContext()
    //繪制起始點(diǎn)
    CGContextMoveToPoint(context, 120, 104)
    //從起始點(diǎn)到這一點(diǎn)
    CGContextAddLineToPoint(context, 150, 204)
    CGContextAddLineToPoint(context, 200, 104)
    //閉合路徑
    CGContextClosePath(context)
    UIColor.blackColor().setStroke()
    UIColor.greenColor().setFill()
    //繪制路徑
    CGContextDrawPath(context, CGPathDrawingMode.FillStroke)
}

運(yùn)行效果:

 

Swift,Quartz 2D

依此類推,大家可以試試怎么去畫長(zhǎng)方形,正方形和不規(guī)則多邊形。

3.繪制圖片和文字
首先準(zhǔn)備一張圖片放入工程中,注意不要放在Assets.xcassets文件夾下,因?yàn)檫@里尋找的路徑是在工程文件夾。而如果把圖片放在Assets.xcassets文件夾下,就要使用另外的一種方法。
在drawRect()里添加代碼:

復(fù)制代碼代碼如下:

override func drawRect(rect: CGRect) {
    //繪制圖片和文字
    //這種方式添加圖片需要把圖片放到根目錄下,而不是Assets.xcassets下
    let imagePath = NSBundle.mainBundle().pathForResource("頭像004", ofType: "jpg")
    let image = UIImage(contentsOfFile: imagePath!)
    //具體位置根據(jù)你的圖片來(lái)調(diào)整
    image?.drawInRect(CGRectMake(100,100, 200, 200))
    let src="/uploads/allimg/160425/1A64G546-2.jpg?2016318141042" style="border: 1px solid rgb(204, 204, 204); border-image-source: none; vertical-align: bottom; padding: 1px; overflow: hidden; max-width: 650px;" />

 


Quartz 2D中的坐標(biāo)變換
注意:坐標(biāo)變換操作必須要在添加圖形之前,如果設(shè)置在添加圖形之后的話會(huì)無(wú)效。

我們先畫一個(gè)正方形做完參考:

復(fù)制代碼代碼如下:

override func drawRect(rect: CGRect) {
    let context = UIGraphicsGetCurrentContext()
    CGContextSetLineWidth(context, 2.0)
    CGContextSetStrokeColorWithColor(context, UIColor.redColor().CGColor)
    let rectangle = CGRectMake(125, 50, 50, 50)
    CGContextAddRect(context, rectangle)
    CGContextStrokePath(context)
}

 

Swift,Quartz 2D

 

1、平移
func CGContextTranslateCTM(c: CGContext?, _ tx: CGFloat, _ ty: CGFloat)
該方法相當(dāng)于把原來(lái)位于 (0, 0) 位置的坐標(biāo)原點(diǎn)平移到 (tx, ty) 點(diǎn)。在平移后的坐標(biāo)系統(tǒng)上繪制圖形時(shí),所有坐標(biāo)點(diǎn)的 X 坐標(biāo)都相當(dāng)于增加了 tx,所有點(diǎn)的 Y 坐標(biāo)都相當(dāng)于增加了 ty。

復(fù)制代碼代碼如下:

override func drawRect(rect: CGRect) {
    let context = UIGraphicsGetCurrentContext()
    CGContextSetLineWidth(context, 2.0)
    CGContextSetStrokeColorWithColor(context, UIColor.redColor().CGColor)
    CGContextTranslateCTM(context, -50, 25) // 向左向下平移
    let rectangle = CGRectMake(125, 50, 50, 50) 
    CGContextAddRect(context, rectangle)
    CGContextStrokePath(context)
}

 

Swift,Quartz 2D

 

2、縮放
func CGContextScaleCTM(c: CGContext?, _ sx: CGFloat, _ sy: CGFloat)
該方法控制坐標(biāo)系統(tǒng)在水平方向和垂直方向上進(jìn)行縮放。在縮放后的坐標(biāo)系統(tǒng)上繪制圖形時(shí),所有點(diǎn)的 X 坐標(biāo)都相當(dāng)于乘以 sx 因子,所有點(diǎn)的 Y 坐標(biāo)都相當(dāng)于乘以 sy 因子。

復(fù)制代碼代碼如下:

override func drawRect(rect: CGRect) {
    let context = UIGraphicsGetCurrentContext()
    CGContextSetLineWidth(context, 2.0)
    CGContextSetStrokeColorWithColor(context, UIColor.redColor().CGColor)    
    CGContextScaleCTM(context, 0.5, 1)
    let rectangle = CGRectMake(125, 50, 50, 50)
    CGContextAddRect(context, rectangle)
    CGContextStrokePath(context)
}

 

Swift,Quartz 2D

 

3、旋轉(zhuǎn)
func CGContextRotateCTM(c: CGContext?, _ angle: CGFloat)
該方法控制坐標(biāo)系統(tǒng)旋轉(zhuǎn) angle 弧度。在縮放后的坐標(biāo)系統(tǒng)上繪制圖形時(shí),所有坐標(biāo)點(diǎn)的 X、Y 坐標(biāo)都相當(dāng)于旋轉(zhuǎn)了 angle弧度之后的坐標(biāo)。

復(fù)制代碼代碼如下:

override func drawRect(rect: CGRect) {
    let context = UIGraphicsGetCurrentContext()
    CGContextSetLineWidth(context, 2.0)
    CGContextSetStrokeColorWithColor(context, UIColor.redColor().CGColor)
    CGContextRotateCTM(context, CGFloat(M_PI_4))
    let rectangle = CGRectMake(125, 50, 50, 50)
    CGContextAddRect(context, rectangle)
    CGContextStrokePath(context)
}

 

Swift,Quartz 2D

注意:旋轉(zhuǎn)的時(shí)候,是整個(gè) layer 都旋轉(zhuǎn)了,所以 layer 看起來(lái)應(yīng)該是這樣的:

Swift,Quartz 2D

這個(gè)時(shí)候若想移動(dòng) view ,就應(yīng)該按照這個(gè)旋轉(zhuǎn)過(guò)的坐標(biāo)系來(lái)移動(dòng):

復(fù)制代碼代碼如下:

override func drawRect(rect: CGRect) {
    let context = UIGraphicsGetCurrentContext()
    CGContextSetLineWidth(context, 2.0)
    CGContextSetStrokeColorWithColor(context, UIColor.redColor().CGColor)
    CGContextRotateCTM(context, CGFloat(M_PI_4))
    CGContextTranslateCTM(context, 0, -100) // 在新坐標(biāo)系中向上移動(dòng)100點(diǎn),視圖上看起來(lái)像是向右向上都移動(dòng)了
    let rectangle = CGRectMake(125, 50, 50, 50)
    CGContextAddRect(context, rectangle)
    CGContextStrokePath(context)
}

 

Swift,Quartz 2D



注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到swift教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
韩国福利在线| 一区二区成人在线观看| 国产精品成人一区二区| 国产一卡二卡3卡4卡四卡在线| 粉嫩虎白女毛片人体| 人体私拍套图hdxxxx| 亚洲女人天堂成人av在线| 日本三级电影在线看| 久久嫩草精品久久久久| 久久人人爽人人爽人人片av免费| 不卡一卡二卡三乱码免费网站| 狠狠狠狠狠狠操| 日韩精品中文字幕一区| 亚洲人成啪啪网站| 免费观看黄色一级视频| 色综合久久九月婷婷色综合| 天堂va久久久噜噜噜久久va| 亚洲国产综合色| 年轻的保姆91精品| 精品人在线二区三区| 国产99在线播放| 午夜精品在线| 免费观看黄色大片| 免费av一区二区三区| 欧美黄色大片网站| 中文字幕一区二区三区四区在线视频| 亚洲精品成人免费| 亚洲日韩第一页| 国产精品亚洲二区在线观看| 无码免费一区二区三区免费播放| 丝袜亚洲精品中文字幕一区| 免费白白视频| 黄a免费视频| 日本1区2区3区中文字幕| 影音先锋人妻啪啪av资源网站| 写真片福利在线播放| a级大胆欧美人体大胆666| 欧美国产乱子伦| 久久se这里有精品| 日韩av一区二区在线| 91成人入口| 欧美视频一区二区在线观看| 婷婷综合久久一区二区三区| 国产精品视频网站在线观看| 成人在线免费电影网站| 成年网站在线看| 亚洲精品一区久久久久久| 91欧美日韩麻豆精品| 久久午夜老司机| 最新国产热播激情视频| 亚洲一二三四区| 四虎成人精品永久免费av九九| 精品在线视频一区二区| 欧美日本一道本| 黄色片网站免费在线观看| 日本最黄视频| 天天舔天天干天天操| 亚洲精品美女久久久| 91视频免费观看网站| 亚洲国产精品精华素| 五月激情综合网| 在线观看特色大片免费视频| 亚洲天堂在线播放| 中文字幕精品三区| canopen超线视频网线的应用| 日本不卡免费在线视频| 在线一级成人| 超碰在线最新网址| 97精品一区二区| 韩剧1988在线观看免费完整版| 激情伊人五月天久久综合| 欧美知名女优| 国产精品视频在线观看| 日本大片免费看| 四虎成人免费视频| 中文字幕不卡三区视频| 天天爽夜夜爽一区二区三区| 精品一区二区三区视频日产| 欧美性猛交xxxx富婆| 久久久噜噜噜久噜久久| 国产精品一码二码三码在线| 亚洲mv在线观看| 免费看的www视频网站视频| aa级大片欧美三级| 97久精品国产片一区二区三区| 亚洲第一区中文99精品| 成人app下载| 综合操久久久| 日本天堂在线视频| 国产一线二线三线在线观看| 日韩av在线播放中文字幕| 久久精品中文字幕一区| 黑丝美女久久久| 国产成人精品免费看视频| 国产高清大尺度一区二区不卡| 久久国产视频一区| 亚洲欧美99| 日韩黄色三级在线观看| 国产区在线视频| xfplay每日更新av资源在线| 强伦人妻一区二区三区| 麻豆91在线播放| 欧美黑人狂野猛交老妇| 亚洲天堂精品在线| 91午夜视频在线观看| 美日韩一二三区| 日韩黄色片在线| 国产欧美视频在线观看| 亚洲第一页在线播放| 国产精品8888| 欧洲精品一区二区三区| 亚洲欧洲在线视频| 波多野结衣免费观看| 国产欧美综合精品一区二区| 免费观看a视频| 人妻中文字幕一区二区三区| www.日本xxxx| 91丨九色丨国产| 91网站在线免费观看| 国产精品日韩欧美| 日韩国产精品视频| 四虎国产精品永久免费观看视频| 久久a级毛片毛片免费观看| 国产69精品久久久久9999apgf| 日韩精品一二三四| 日韩第一页在线| 国产69精品久久久久9| 精品福利在线视频| 911国产网站尤物在线观看| 黄网址在线看| 在线成人av网站| 国产一精品一aⅴ一免费| 一本大道av一区二区在线播放| 国内精品伊人| 欧美精品一区二区三区久久久| 免费观看国产视频在线| 三区视频在线观看| 国产日韩精品久久久| 精品国产_亚洲人成在线| 久久久久免费视频| 色老头一区二区三区| 亚洲精品国产精品久久清纯直播| 欧美一级播放| 在线观看精品视频一区二区三区| 国产成人无码精品久久二区三| 国产成人免费观看视频| 在线观看欧美亚洲| 久久精品国产亚洲av麻豆蜜芽| 自拍偷拍第八页| 日本黄色片一级片| 色哟哟国产精品色哟哟| 国产精品久久久久999| 国产性生活大片| 精品视频免费在线| 欧美性videosxxxxx| 日韩污视频在线观看| 亚洲av无码一区二区三区网址| 久久福利视频网| 91麻豆精品久久毛片一级| 亚洲 另类 春色 国产| 久草视频免费在线观看| 成人在线观看黄色| 亚洲精品菠萝久久久久久久| 国产伦精品一区二区三区妓女| 欧美日韩亚洲精品内裤| 欧美一区二区三区视频免费| 欧美黄色片免费观看| 福利av在线| 岛国av一区二区三区| 成人午夜影院| 欧美寡妇偷汉性猛交| 日本久久久久久久久| 一区二区三区免费| 久久国产露脸精品国产| 亚洲午夜精品久久久中文影院av| 性欧美高清视频| 亚洲av片不卡无码久久| 欧美福利网站| 97蝌蚪自拍自窝| 国产精品欧美日韩| 91九色单男在线观看| 51精品国产人成在线观看| 三级特黄视频| 91视频论坛| 欧美精品粉嫩高潮一区二区| 99久久久国产精品美女| 亚洲精品视频中文字幕| 国模精品一区| 免费黄网站在线播放| 91精品国产高久久久久久五月天| 影音先锋亚洲精品| 欧洲一区在线| 亚洲va男人天堂| 影音先锋一区二区资源站| 2019中文字幕在线观看| 日韩电影免费观看在线观看| 日韩主播视频在线| 国产69精品久久久久久久| 久久精品日韩欧美| 校园春色综合| 久久发布国产伦子伦精品| 久久久久国产精品免费免费搜索| 高清av电影| 亚洲精品无码久久久久久| 亚洲国产激情| 香港日本韩国三级网站| 视频在线观看免费高清| 国产精品男女| 亚洲大胆人体大胆做受1| 久久精品亚洲94久久精品| 来吧亚洲综合网| 一区二区三区在线高清| av官网在线播放| 国产精品19p| 午夜久久久久| 国产天堂在线播放| 国产精品一区在线观看乱码| 亚洲欧美在线视频观看| 久久丁香综合五月国产三级网站| 精品一区二区不卡| 亚洲国产精品午夜在线观看| 亚洲国产精彩中文乱码av| 精品视频全国免费看| 久久婷婷中文字幕| 国内精品久久久久| 成人免费看片98| 超碰97成人| 国精产品一区一区三区有限在线| 成人精品国产一区二区4080| 97超碰在线资源| 欧美日韩亚洲综合| 久久影院在线观看| 一级黄色片在线| 国内视频一区二区| 国产一区美女| 99re8这里有精品热视频免费| 韩国三级午夜理伦三级三| 国内自拍中文字幕| 色菇凉天天综合网| 成人少妇影院yyyy| 影音先锋男人在线| 青青草免费观看视频| 加勒比精品视频| 欧美6699在线视频免费| 日日噜噜噜夜夜爽爽| 国产suv精品一区二区四区视频| 日本熟妇乱子伦xxxx| 成人在线app| 亚洲一区三区电影在线观看| 国产精品美女久久久久久久| 在线视频不卡国产| 福利片一区二区| 亚洲午夜久久久久久久久电影院| 亚洲欧美日韩国产一区二区| 久久久久亚洲精品一区二区三区| 国产伦精品一区二区三区四区免费| 91精品国产欧美一区二区18| 一区二区三区鲁丝不卡| 中文字幕免费在线观看| 国产麻豆精品久久| 久久综合色视频| 成人听书哪个软件好| 国产成人亚洲综合| 亚洲天堂导航| 五月天婷亚洲天综合网鲁鲁鲁| 国产视频亚洲精品| 免费亚色电影在线观看| 久久一区二区三区国产精品| 欧美优质美女网站| 欧美成人免费在线观看| 7777精品伊人久久久大香线蕉超级流畅| 国产乱人伦精品一区二区在线观看| 国产又爽又黄又嫩又猛又粗| 可以免费看毛片的网站| 国产青草视频在线观看| 欧美大片aaaa| 一区二区三区久久精品| 国产精品入口麻豆| 国产偷v国产偷v亚洲高清| 久久福利视频导航| 香蕉视频免费在线| 日韩国产欧美一区二区三区| 午夜欧美视频| 久久精品女人天堂| 国产手机av在线| 舐め犯し波多野结衣在线观看| 国产日韩欧美高清在线| 国产激情久久久久久熟女老人av| 夜色77av精品影院| 日韩一区av在线| 国产精品久久久久久户外露出| 91综合久久一区二区| 99热在线免费观看| 色婷婷综合久久久久中文字幕1| 欧产日产国产精品98| 午夜精品在线看| 日本女人高潮视频| 五十路亲子中出中文字幕| 2017亚洲男人天堂| 色老头久久综合| 永久免费的av网站| 一二三区在线视频| 国产亚洲欧美精品久久久www| 精品粉嫩aⅴ一区二区三区四区| 日本a在线免费观看| 精品国产午夜肉伦伦影院| 在线视频日韩精品| 成人亚洲精品777777ww| 亚洲精品在线视频观看| 亚洲精品第三页| 日韩午夜电影av| 免费av网址在线| 久草视频手机在线观看| 在线观看视频免费一区二区三区| 欧美高清电影在线看| 国产激情一区| 禁网站在线观看免费视频| 国产福利电影一区二区三区| 桃乃木香奈和黑人aⅴ在线播放| 日本不卡一二区| 又污又黄的网站| 国产成人精品亚洲男人的天堂| 国产人成精品一区二区三| 亚洲色图在线看| 91精品少妇一区二区三区蜜桃臀| 91麻豆蜜桃一区二区三区| 久久久久毛片| 久久精品国产av一区二区三区|