Quartz 2D繪制路徑實(shí)例

一.繪制進(jìn)度條

在研究了Quartz 2D繪制路徑吱晒、文字之后,我們需要實(shí)例運(yùn)用一下沦童。首先我們制作一個如下的效果仑濒,拖動slider的時候,扇形的進(jìn)度條也隨之加載偷遗。

進(jìn)度條效果圖

思路:

  1. 需要一個slider墩瞳、一個view來繪制扇形;
  2. 當(dāng)slider拖動的時候氏豌,把slider滑動到的value值給view來繪制扇形喉酌;
  3. 扇形最小弧度是0,最大弧度是360度(M_PI * 2);扇形的起點(diǎn)是-M_PI_2泪电,終點(diǎn)是slider滑動的value * 360度(M_PI * 2)般妙;

實(shí)現(xiàn)

我們再storyboard里面添加一個slider、一個ProgressView相速,ProgressView里面添加一個valueLabel來顯示進(jìn)度碟渺;

添加的view
viewcontroller:

#import "ViewController.h"
#import "ProgressView.h"
@interface ViewController ()
@property (weak, nonatomic) IBOutlet ProgressView *progressView;
@end

@implementation ViewController

//滾動條滾動調(diào)用的事件
- (IBAction)sliderValueChange:(UISlider *)sender {
    
    //把滾動的值傳給顯示的view
    self. progressView.value = sender.value;
    
}
@end

ProgressView:
.h
@interface ProgressView : UIView
//用于接收滾動的值
@property(nonatomic,assign)CGFloat value;

@end

.m
@implementation ProgressView
-(void)setValue:(CGFloat)value{
    
    _value = value;
    //修改lable顯示的內(nèi)容
    _valueLabel.text = [NSString stringWithFormat:@"%.2f%%",value * 100];
    //通知系統(tǒng),調(diào)用drawRect方法
    [self setNeedsDisplay];
}
/*
 當(dāng)系統(tǒng)調(diào)用drawRect方法時突诬,在drawRect內(nèi)部會自動創(chuàng)建跟view相關(guān)的上下文
 手動調(diào)用drawRect不會創(chuàng)建上下文
 */
- (void)drawRect:(CGRect)rect {

    CGPoint center = CGPointMake(rect.size.width * 0.5, rect.size.height *0.5);
    CGFloat radius = rect.size.width/2.0 - 10;
    CGFloat startA = -M_PI_2;//-90度
    CGFloat endA = startA + _value * M_PI * 2; //value * 360度

     //1.獲取上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    //2.描繪路徑
    UIBezierPath  * path = [UIBezierPath bezierPathWithArcCenter:center radius:radius startAngle:startA endAngle:endA clockwise:YES];
    [path addLineToPoint:center];
    //設(shè)置上下文狀態(tài)
    [[UIColor yellowColor] set];
    
    //3.把路徑添加到畫板上面
    CGContextAddPath(ctx, path.CGPath);
    //4.把上下文渲染到view的layer層
    
    [path fill];
}

@end
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末苫拍,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子旺隙,更是在濱河造成了極大的恐慌绒极,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件催束,死亡現(xiàn)場離奇詭異集峦,居然都是意外死亡伏社,警方通過查閱死者的電腦和手機(jī)抠刺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來摘昌,“玉大人速妖,你說我怎么就攤上這事〈侠瑁” “怎么了罕容?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長稿饰。 經(jīng)常有香客問我锦秒,道長,這世上最難降的妖魔是什么喉镰? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任旅择,我火速辦了婚禮,結(jié)果婚禮上侣姆,老公的妹妹穿的比我還像新娘生真。我一直安慰自己,他們只是感情好捺宗,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布柱蟀。 她就那樣靜靜地躺著,像睡著了一般蚜厉。 火紅的嫁衣襯著肌膚如雪长已。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天,我揣著相機(jī)與錄音术瓮,去河邊找鬼胶果。 笑死,一個胖子當(dāng)著我的面吹牛斤斧,可吹牛的內(nèi)容都是我干的早抠。 我是一名探鬼主播,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼撬讽,長吁一口氣:“原來是場噩夢啊……” “哼蕊连!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起游昼,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤甘苍,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后烘豌,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體载庭,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年廊佩,在試婚紗的時候發(fā)現(xiàn)自己被綠了囚聚。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡标锄,死狀恐怖顽铸,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情料皇,我是刑警寧澤谓松,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站践剂,受9級特大地震影響鬼譬,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜逊脯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一优质、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧男窟,春花似錦盆赤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至汗捡,卻和暖如春淑际,著一層夾襖步出監(jiān)牢的瞬間畏纲,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工春缕, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留盗胀,地道東北人。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓锄贼,卻偏偏與公主長得像票灰,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子宅荤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,876評論 2 361

推薦閱讀更多精彩內(nèi)容