ios 画带有箭头的线_ios 在地图上画一个带箭头半透明的气泡框

先上一个效果图

2986906-5ba5a85f708afb54.png

- (instancetype)initWithFrame:(CGRect)frame{

if (self = [super initWithFrame:frame]) {

self.backgroundColor = [UIColor clearColor];

//这里可以设置你要在气泡view上显示的内容

}

return self;

}

//通过drawRect 画一个 带箭头的气泡框

- (void)drawRect:(CGRect)rect {

[self drawInContext:UIGraphicsGetCurrentContext()];

self.layer.shadowColor = [[UIColor clearColor] CGColor];

self.layer.shadowOpacity = 1.0;

self.layer.shadowOffset = CGSizeMake(0.0f, 0.0f);

}

-(void)drawInContext:(CGContextRef)context{

CGContextSetLineWidth(context, 2.0);

CGContextSetFillColorWithColor(context, [UIColor colorWithRed:0 green:0 blue:0 alpha:0.5].CGColor);

[self getDrawPath:context];

CGContextFillPath(context);

}

-(void)getDrawPath:(CGContextRef)context{

CGRect rrect = self.bounds;

CGFloat radius = 20.0;

CGFloat minx = CGRectGetMinX(rrect),

midx = CGRectGetMidX(rrect),

maxx = CGRectGetMaxX(rrect);

CGFloat miny = CGRectGetMinY(rrect),

maxy = CGRectGetMaxY(rrect)-10;

CGContextMoveToPoint(context, midx+10, maxy);

CGContextAddLineToPoint(context, midx, maxy+10);

CGContextAddLineToPoint(context, midx-10, maxy);

CGContextAddArcToPoint(context, minx, maxy, minx, miny, radius);

CGContextAddArcToPoint(context, minx, miny, maxx, miny, radius);

CGContextAddArcToPoint(context, maxx, miny, maxx, maxy, radius);

CGContextAddArcToPoint(context, maxx, maxy, midx, maxy, radius);

CGContextClosePath(context);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值