欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS開發(fā)中Quartz2D的基本使用方式舉例

 更新時間:2015年11月24日 09:39:58   作者:文頂頂  
這篇文章主要介紹了iOS開發(fā)中Quartz2D的基本使用方式舉例,需要的朋友可以參考下

一、畫直線

代碼:

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

//
//  YYlineview.m
//  03-畫直線
//
//  Created by apple on 14-6-9.
//  Copyright (c) 2014年 itcase. All rights reserved.
//

#import "YYlineview.h"

@implementation YYlineview


// 當(dāng)自定義view第一次顯示出來的時候就會調(diào)用drawRect方法
- (void)drawRect:(CGRect)rect
{

    // 1.取得和當(dāng)前視圖相關(guān)聯(lián)的圖形上下文(因為圖形上下文決定繪制的輸出目標(biāo))/
    // 如果是在drawRect方法中調(diào)用UIGraphicsGetCurrentContext方法獲取出來的就是Layer的上下文
    CGContextRef  ctx=UIGraphicsGetCurrentContext();//不需要*,同id
   
    // 2.繪圖(繪制直線), 保存繪圖信息
    // 設(shè)置起點
    CGContextMoveToPoint(ctx, 20, 100);
    //設(shè)置終點
    CGContextAddLineToPoint(ctx, 300, 100);
   
   
    //設(shè)置繪圖的狀態(tài)
    //設(shè)置線條的顏色為藍(lán)色
    CGContextSetRGBStrokeColor(ctx, 0, 1.0, 0, 1.0);
    //設(shè)置線條的寬度
    CGContextSetLineWidth(ctx, 15);
    //設(shè)置線條起點和終點的樣式為圓角
    CGContextSetLineCap(ctx, kCGLineCapRound);
    //設(shè)置線條的轉(zhuǎn)角的樣式為圓角
    CGContextSetLineJoin(ctx, kCGLineJoinRound);
    //3.渲染(繪制出一條空心的線)
    CGContextStrokePath(ctx);
   
//    //注意線條不能渲染為實心的
//    CGContextFillPath(ctx);
   
   
   
    //設(shè)置第二條線
    //設(shè)置第二條線的起點
    CGContextMoveToPoint(ctx, 50, 200);
    //設(shè)置第二天線的終點(自動把上一條直線的終點當(dāng)做起點)
    CGContextAddLineToPoint(ctx, 300, 60);
   
    //設(shè)置繪圖的狀態(tài)
//    CGContextSetRGBStrokeColor(ctx, 1.0, 0.7, 0.3, 1.0);
    //第二種設(shè)置顏色的方式
    [[UIColor grayColor] set];
    //設(shè)置線條的寬度
    CGContextSetLineWidth(ctx, 10);
    //設(shè)置線條的起點和終點的樣式
    CGContextSetLineCap(ctx, kCGLineCapButt);
   
    //渲染第二條線的圖形到view上
    //繪制一條空心的線
    CGContextStrokePath(ctx);
}


@end


效果:

2015112492838729.png (322×283)

二、畫三角形

代碼:

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

//
//  YYrectview.m
//  02-畫三角形
//
//  Created by 孔醫(yī)己 on 14-6-10.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import "YYrectview.h"

@implementation YYrectview


- (void)drawRect:(CGRect)rect
{
    //1.獲得圖形上下文
    CGContextRef ctx=UIGraphicsGetCurrentContext();
   
    //2.繪制三角形
    //設(shè)置起點
    CGContextMoveToPoint(ctx, 20, 100);
    //設(shè)置第二個點
    CGContextAddLineToPoint(ctx, 40, 300);
    //設(shè)置第三個點
    CGContextAddLineToPoint(ctx, 200, 200);
    //設(shè)置終點
//     CGContextAddLineToPoint(ctx, 20, 100);
    //關(guān)閉起點和終點
    CGContextClosePath(ctx);
   
    // 3.渲染圖形到layer上
    CGContextStrokePath(ctx);
   
}


@end


效果:

2015112492918030.png (282×347)

提示:關(guān)閉起點和終點  CGContextClosePath(ctx);

三、畫四邊形

代碼:

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

//
//  YYrect.m
//  03-畫四邊形
//
//  Created by 孔醫(yī)己 on 14-6-10.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import "YYrect.h"

@implementation YYrect


- (void)drawRect:(CGRect)rect
{

    //1.獲取圖形上下文
    CGContextRef ctx=UIGraphicsGetCurrentContext();
    //2.畫四邊形
    CGContextAddRect(ctx, CGRectMake(20, 20, 150, 100));
   
    // 如果要設(shè)置繪圖的狀態(tài)必須在渲染之前
    //    CGContextSetRGBStrokeColor(ctx, 1.0, 0, 0, 1.0);
    // 繪制什么類型的圖形(空心或者實心).就要通過什么類型的方法設(shè)置狀態(tài)
    //    CGContextSetRGBFillColor(ctx, 1.0, 0, 0, 1.0);
   
    // 調(diào)用OC的方法設(shè)置繪圖的顏色
    //    [[UIColor purpleColor] setFill];
    //    [[UIColor blueColor] setStroke];
    // 調(diào)用OC的方法設(shè)置繪圖顏色(同時設(shè)置了實心和空心)
    //    [[UIColor greenColor] set];
    [[UIColor colorWithRed:1.0 green:0 blue:0 alpha:1.0] set];
   
   
    //3.渲染圖形到layer上
    //空心的
    CGContextStrokePath(ctx);
    //實心的
//    CGContextFillPath(ctx);
   
}


@end


提示:如果要設(shè)置繪圖的狀態(tài)必須在渲染之前。

效果(實心和空心):

2015112493300257.png (318×250)2015112493318692.png (323×181)

四、畫圓

代碼1:

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

- (void)drawRect:(CGRect)rect
{

    // 1.獲取上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    // 畫圓
    CGContextAddArc(ctx, 100, 100, 50, 0, 2 * M_PI, 0);

    // 3.渲染 (注意, 畫線只能通過空心來畫)
//    CGContextFillPath(ctx);
    CGContextStrokePath(ctx);
   
}


效果:

2015112493344375.png (304×245)

代碼2:

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

// 畫圓
    // 1.獲取上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    // 2.畫圓
    CGContextAddEllipseInRect(ctx, CGRectMake(50, 100, 50, 50));
   
    [[UIColor greenColor] set];
   
    // 3.渲染
    //    CGContextStrokePath(ctx);
    CGContextFillPath(ctx);

效果:

2015112493434968.png (259×211)

代碼3:

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

// 畫橢圓
    // 1.獲取上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    // 2.畫圓
    CGContextAddEllipseInRect(ctx, CGRectMake(50, 100, 100, 230));
   
    [[UIColor purpleColor] set];
   
    // 3.渲染
    //    CGContextStrokePath(ctx);
    CGContextFillPath(ctx);

效果:

2015112493455286.png (237×388)

五、畫圓弧

代碼1:

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

// 畫圓弧
    // 1.獲取上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    // 2.畫圓弧
    // x/y 圓心
    // radius 半徑
    // startAngle 開始的弧度
    // endAngle 結(jié)束的弧度
    // clockwise 畫圓弧的方向 (0 順時針, 1 逆時針)
    //    CGContextAddArc(ctx, 100, 100, 50, -M_PI_2, M_PI_2, 0);
    CGContextAddArc(ctx, 100, 100, 50, M_PI_2, M_PI, 0);
    CGContextClosePath(ctx);
   
    // 3.渲染
    //     CGContextStrokePath(ctx);
    CGContextFillPath(ctx);

效果:

2015112493512249.png (280×264)

代碼2:

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

// 1.獲取上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    // 2.畫餅狀圖
    // 畫線
    CGContextMoveToPoint(ctx, 100, 100);
    CGContextAddLineToPoint(ctx, 100, 150);
    // 畫圓弧
    CGContextAddArc(ctx, 100, 100, 50, M_PI_2, M_PI, 0);
    //    CGContextAddArc(ctx, 100, 100, 50, -M_PI, M_PI_2, 1);
   
    // 關(guān)閉路徑
    CGContextClosePath(ctx);
    [[UIColor brownColor]set];
   
   
    // 3.渲染 (注意, 畫線只能通過空心來畫)
    CGContextFillPath(ctx);
    //    CGContextStrokePath(ctx);

效果:

2015112493532663.png (263×247)

六、畫文字
代碼:

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

//
//  YYtextview.m
//  04-寫文字
//
//  Created by 孔醫(yī)己 on 14-6-10.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import "YYtextview.h"

@implementation YYtextview


- (void)drawRect:(CGRect)rect
{
   
    // 畫文字
    NSString *str = @"的額搜風(fēng)搜分手了粉色發(fā)俄雙方說法offFF瓦房你F回復(fù)F入會費WFH;飛;FN返回WFH;哦發(fā)貨;F回復(fù);FHISFHSIFH我皮膚好APIFRHi分紅AWFHIOF威鋒網(wǎng)i";
   
    // 1.獲取上下文
    //    CGContextRef ctx = UIGraphicsGetCurrentContext();
    // 2.繪圖
    // 不推薦使用C語言的方法繪制文字, 因為quraz2d中的坐標(biāo)系和UIkit中的坐標(biāo)系不一致, 繪制出來的文字是顛倒的, 而且通過C語言的方法繪制文字相當(dāng)麻煩
    //    CGContextSelectFont(<#CGContextRef c#>, <#const char *name#>, <#CGFloat size#>, <#CGTextEncoding textEncoding#>)
    //    CGContextShowText(ctx, <#const char *string#>, <#size_t length#>)
   
    // 繪制矩形
    // 1.獲取上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    // 2.繪圖
    CGContextAddRect(ctx, CGRectMake(50, 50, 100, 100));
    // 3.渲染
    CGContextStrokePath(ctx);
   
   
//    NSMutableDictionary *md = [NSMutableDictionary dictionary];
//    // 設(shè)置文字顏色
//    md[NSForegroundColorAttributeName] =[UIColor redColor];
//    // 設(shè)置文字背景顏色
//    md[NSBackgroundColorAttributeName] = [UIColor greenColor];
//    // 設(shè)置文字大小
//    md[NSFontAttributeName] = [UIFont systemFontOfSize:20];
   
    //    將文字繪制到指點的位置
    //    [str drawAtPoint:CGPointMake(10, 10) withAttributes:md];
   
    //    將文字繪制到指定的范圍內(nèi), 如果一行裝不下會自動換行, 當(dāng)文字超出范圍后就不顯示
    [str drawInRect:CGRectMake(50, 50, 100, 100) withAttributes:nil];
}


@end


效果:

2015112493630437.png (289×276)

圖片

代碼1:

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

//
//  YYimage.m
//  04-寫文字
//
//  Created by 孔醫(yī)己 on 14-6-10.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import "YYimage.h"

@implementation YYimage


- (void)drawRect:(CGRect)rect
{
 
    //    1.加載圖片到內(nèi)存中
    UIImage *image = [UIImage imageNamed:@"me"];
   
   
    // 利用drawAsPatternInRec方法繪制圖片到layer, 是通過平鋪原有圖片
    [image drawAsPatternInRect:CGRectMake(0, 0, 320, 480)];
}


@end


效果(平鋪):

2015112493720482.png (640×960)

代碼2:

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

#import "YYimage.h"

@implementation YYimage


- (void)drawRect:(CGRect)rect
{
 
    //    1.加載圖片到內(nèi)存中
    UIImage *image = [UIImage imageNamed:@"me"];
   
   
    // 利用OC方法將圖片繪制到layer上
 
    // 利用drawInRect方法繪制圖片到layer, 是通過拉伸原有圖片
        [image drawInRect:CGRectMake(0, 0, 200, 200)];
   
    // 利用drawAsPatternInRec方法繪制圖片到layer, 是通過平鋪原有圖片
//    [image drawAsPatternInRect:CGRectMake(0, 0, 320, 480)];
}


@end


效果(拉伸圖片):

2015112493741876.png (284×272)

代碼3:

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

//
//  YYimage.m
//  04-寫文字
//
//  Created by 孔醫(yī)己 on 14-6-10.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import "YYimage.h"

@implementation YYimage


- (void)drawRect:(CGRect)rect
{
 
    //    1.加載圖片到內(nèi)存中
    UIImage *image = [UIImage imageNamed:@"me"];
   
   
    // 利用OC方法將圖片繪制到layer上
   
    // 將圖片繪制到指定的位置
    [image drawAtPoint:CGPointMake(100, 100)];
    }


效果(把圖片繪制到一個固定的位置):

2015112493758442.png (312×297)

相關(guān)文章

  • iOS 中weak的實現(xiàn)代碼示例

    iOS 中weak的實現(xiàn)代碼示例

    本篇文章主要介紹了iOS 中weak的實現(xiàn)代碼示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • IOS中Weex 加載 .xcassets 中的圖片資源的實例詳解

    IOS中Weex 加載 .xcassets 中的圖片資源的實例詳解

    這篇文章主要介紹了IOS中Weex 加載 .xcassets 中的圖片資源的實例詳解的相關(guān)資料,希望通過本文介紹能幫助到大家,實現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-08-08
  • iOS中id類型的理解及底層原理詳解

    iOS中id類型的理解及底層原理詳解

    這篇文章主要給大家介紹了關(guān)于iOS中id類型的理解以及底層原理的相關(guān)資料,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-07-07
  • iOS獲取某個日期后n個月的日期

    iOS獲取某個日期后n個月的日期

    這篇文章主要介紹了iOS獲取某個日期后n個月的日期的相關(guān)資料,需要的朋友可以參考下
    2017-08-08
  • 詳解IOS開發(fā)之實現(xiàn)App消息推送(最新)

    詳解IOS開發(fā)之實現(xiàn)App消息推送(最新)

    這篇文章主要介紹了詳解IOS開發(fā)之實現(xiàn)App消息推送(最新),具有一定的參考價值,有興趣的可以了解一下。
    2016-12-12
  • iOS?WKWebView秒開方案實戰(zhàn)記錄

    iOS?WKWebView秒開方案實戰(zhàn)記錄

    從iOS8開始,就引入了新的瀏覽器控件WKWebView,用于取代UIWebView,下面這篇文章主要給大家介紹了關(guān)于iOS?WKWebView秒開方案的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-12-12
  • 簡單好用的iOS導(dǎo)航欄封裝.runtime屬性控制實例代碼

    簡單好用的iOS導(dǎo)航欄封裝.runtime屬性控制實例代碼

    這篇文章主要給大家介紹了簡單好用的iOS導(dǎo)航欄封裝.runtime屬性控制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-10-10
  • iOS UISearchController的使用方法

    iOS UISearchController的使用方法

    本文主要介紹了iOS UISearchController的使用方法,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • iOS11實現(xiàn)App內(nèi)自動連接Wi-Fi的方法

    iOS11實現(xiàn)App內(nèi)自動連接Wi-Fi的方法

    這篇文章主要給大家介紹了關(guān)于iOS11實現(xiàn)App內(nèi)自動連接Wi-Fi的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-10-10
  • iOS使用音頻處理框架The Amazing Audio Engine實現(xiàn)音頻錄制播放

    iOS使用音頻處理框架The Amazing Audio Engine實現(xiàn)音頻錄制播放

    這篇文章主要為大家詳細(xì)介紹了iOS使用音頻處理框架The Amazing Audio Engine實現(xiàn)音頻錄制播放,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-04-04

最新評論