亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Swift操作Quartz 2D進行簡單的繪圖與坐標變換的教程

 更新時間:2016年04月18日 14:15:51   作者:老初  
這篇文章主要介紹了Swift操作Quartz 2D進行簡單的繪圖與坐標變換的教程,Quartz 2D是Core Graphics框架中的一個重要組件,經(jīng)常被Mac OS或和iOS開發(fā)者用來繪圖,需要的朋友可以參考下

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

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

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

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

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

復制代碼 代碼如下:

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

運行效果:

2016418140921390.jpg (635×1178)

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

復制代碼 代碼如下:

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

運行效果:

2016418141013117.jpg (644×1178)

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

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

復制代碼 代碼如下:

override func drawRect(rect: CGRect) {
    //繪制圖片和文字
    //這種方式添加圖片需要把圖片放到根目錄下,而不是Assets.xcassets下
    let imagePath = NSBundle.mainBundle().pathForResource("頭像004", ofType: "jpg")
    let image = UIImage(contentsOfFile: imagePath!)
    //具體位置根據(jù)你的圖片來調(diào)整
    image?.drawInRect(CGRectMake(100,100, 200, 200))
    let title = "頭像"
    let font = UIFont.systemFontOfSize(44)
    let attr = [NSFontAttributeName:font]
    title.drawAtPoint(CGPointMake(100, 20), withAttributes: attr)
}

運行效果:

2016418141032549.jpg (642×1185)


Quartz 2D中的坐標變換
注意:坐標變換操作必須要在添加圖形之前,如果設置在添加圖形之后的話會無效。

我們先畫一個正方形做完參考:

復制代碼 代碼如下:

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)
}

2016418141110905.png (299×299)

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

復制代碼 代碼如下:

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)
}

2016418141132007.png (599×297)

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

復制代碼 代碼如下:

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)
}

2016418141152595.png (598×297)

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

復制代碼 代碼如下:

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)
}

2016418141215224.png (598×299)

注意:旋轉的時候,是整個 layer 都旋轉了,所以 layer 看起來應該是這樣的:

2016418141233334.png (456×380)

這個時候若想移動 view ,就應該按照這個旋轉過的坐標系來移動:

復制代碼 代碼如下:

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) // 在新坐標系中向上移動100點,視圖上看起來像是向右向上都移動了
    let rectangle = CGRectMake(125, 50, 50, 50)
    CGContextAddRect(context, rectangle)
    CGContextStrokePath(context)
}

2016418141250529.png (597×298)

相關文章

  • Swift超詳細講解指針

    Swift超詳細講解指針

    從傳統(tǒng)的C代碼和與之無縫配合的Objective-C代碼遷移到Swift并非小工程,我們的代碼庫肯定會時不時出現(xiàn)一些和C協(xié)作的地方,如果想要繼續(xù)使用那些C?API的話,了解一些基本的Swift指針操作和使用的知識會很有幫助。下面通過這篇文章一起來學習下吧。
    2022-08-08
  • swift?cell自定義左滑手勢處理方法

    swift?cell自定義左滑手勢處理方法

    這篇文章主要介紹了swift?cell自定義左滑手勢處理,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • Swift實現(xiàn)表格視圖單元格多選

    Swift實現(xiàn)表格視圖單元格多選

    這篇文章主要為大家詳細介紹了Swift實現(xiàn)表格視圖單元格多選,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • Swift 編程語言入門教程

    Swift 編程語言入門教程

    今天在網(wǎng)上看到一篇非常好的Swift 編程語言入門教程,分享給大家
    2014-08-08
  • 如何快速用上Swift靜態(tài)庫詳解

    如何快速用上Swift靜態(tài)庫詳解

    這篇文章主要給大家介紹了關于如何快速用上Swift靜態(tài)庫的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2018-03-03
  • 簡單分析Swift語言的一些基本特征

    簡單分析Swift語言的一些基本特征

    這篇文章主要介紹了Swift語言的一些基本特征,本文從各語言最基礎的類與對象等方面來講,需要的朋友可以參考下
    2015-07-07
  • Swift 3.0基礎學習之擴展

    Swift 3.0基礎學習之擴展

    擴展是向一個已有的類、結構體或枚舉類型添加新的功能(在swift中擴展沒有名字)。相當于Objective-C中Category(OC中可以有名字的,而且只能擴展類)。這篇文章主要介紹了Swift 3.0基礎學習之擴展的相關資料,需要的朋友可以參考下。
    2017-03-03
  • SwiftUI智能家居開關燈頁面搭建示例

    SwiftUI智能家居開關燈頁面搭建示例

    這篇文章主要為大家介紹了SwiftUI智能家居開關燈頁面搭建示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • Swift教程之字符串和字符詳解

    Swift教程之字符串和字符詳解

    這篇文章主要介紹了Swift教程之字符串和字符詳解,本文講解了字符串常量、初始化一個空串、變長字符串、字符串不是指針,而是實際的值、字符等內(nèi)容,需要的朋友可以參考下
    2015-01-01
  • RxSwift學習之Observable的新建、訂閱及取消訂閱

    RxSwift學習之Observable的新建、訂閱及取消訂閱

    這篇文章主要給大家介紹了關于RxSwift學習教程之Observable的相關資料,文中詳細的給大家介紹了關于新建Observable、訂閱Observable和取消訂閱并消除內(nèi)存泄漏等相關的內(nèi)容,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-09-09

最新評論