ios 自頂一個view

來源:互聯網
上載者:User

標籤:

////  YKPopView.m//  DrawAnSample////  Created by 高順生 on 15/9/6.//  Copyright (c) 2015年 yinyakun. All rights reserved.//#import "YKPopView.h"#define MENUGAP 7@implementation YKPopView-(instancetype)initWithFrame:(CGRect)frame {    self = [super initWithFrame:frame];    if (self) {        self.backgroundColor = [UIColor clearColor];    }    return self;}// Only override drawRect: if you perform custom drawing.// An empty implementation adversely affects performance during animation.- (void)drawRect:(CGRect)rect {    // Drawing code    CGFloat width = rect.size.width;    CGFloat height = rect.size.height;    CGFloat radius = 3;        // 擷取CGContext,注意UIKit裡用的是一個專門的函數    CGContextRef context = UIGraphicsGetCurrentContext();    // 移動到初始點    CGContextMoveToPoint(context, radius, MENUGAP);        // 繪製第1條線和第1個1/4圓弧    CGContextAddLineToPoint(context, width * 5/6 - 6,MENUGAP);    CGContextAddLineToPoint(context, width * 5/6,0);    CGContextAddLineToPoint(context, width  * 5/6 + 6,MENUGAP);    CGContextAddLineToPoint(context, width - radius, MENUGAP);    CGContextAddArc(context, width - radius, radius + MENUGAP, radius, -0.5 * M_PI, 0.0, 0);        // 繪製第2條線和第2個1/4圓弧    CGContextAddLineToPoint(context, width, height - radius - MENUGAP);    CGContextAddArc(context, width - radius, height - radius - MENUGAP, radius, 0.0, 0.5 * M_PI, 0);        // 繪製第3條線和第3個1/4圓弧    CGContextAddLineToPoint(context, radius, height - MENUGAP);    CGContextAddArc(context, radius, height - radius - MENUGAP, radius, 0.5 * M_PI, M_PI, 0);        // 繪製第4條線和第4個1/4圓弧    CGContextAddLineToPoint(context, 0, radius + MENUGAP);    CGContextAddArc(context, radius, radius + MENUGAP, radius, M_PI, 1.5 * M_PI, 0);        // 閉合路徑    CGContextClosePath(context);        [[UIColor redColor] setFill];    CGContextDrawPath(context, kCGPathFill);}

  自訂一個view.

ios 自頂一個view

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.