android 贝塞尔曲线 人脸,贝塞尔曲线绘制人脸框(框内全透明,框外半透明)

参考CropImage 制作截取头像框https://github.com/cokeduo/CropImage

https://www.jianshu.com/p/c883fbf52681

//贝塞尔曲线画4个弧度

UIBezierPath *path = [UIBezierPath bezierPathWithRoundedRect:CGRectMake(0, 0, kScreenWidth, kScreenHeight) cornerRadius:0];

UIBezierPath *headerPath = [UIBezierPath bezierPath];

headerPath.lineWidth = 2.0;

headerPath.lineCapStyle = kCGLineCapRound;

headerPath.lineJoinStyle = kCGLineJoinRound;

[headerPath moveToPoint:CGPointMake(kScreenWidth/2, 80+STATUS_BAR_Y)];

[headerPath addQuadCurveToPoint:CGPointMake(kScreenWidth*(1-0.75)/2+kScreenWidth*0.75, 80+STATUS_BAR_Y+kScreenWidth*0.35) controlPoint:CGPointMake(kScreenWidth*(1-0.75)/2+kScreenWidth*0.75, 80+STATUS_BAR_Y)];

[headerPath addQuadCurveToPoint:CGPointMake(kScreenWidth/2, 80+STATUS_BAR_Y+kScreenWidth) controlPoint:CGPointMake(kScreenWidth*(1-0.75)/2+kScreenWidth*0.75, 80+STATUS_BAR_Y+kScreenWidth)];

[headerPath addQuadCurveToPoint:CGPointMake(kScreenWidth*(1-0.75)/2, 80+STATUS_BAR_Y+kScreenWidth*0.35) controlPoint:CGPointMake(kScreenWidth*(1-0.75)/2, 80+STATUS_BAR_Y+kScreenWidth)];

[headerPath addQuadCurveToPoint:CGPointMake(kScreenWidth/2, 80+STATUS_BAR_Y) controlPoint:CGPointMake(kScreenWidth*(1-0.75)/2, 80+STATUS_BAR_Y)];

[headerPath stroke];

[path appendPath:headerPath];

[path setUsesEvenOddFillRule:YES];

CAShapeLayer *fillLayer = [CAShapeLayer layer];

fillLayer.path = path.CGPath;

//中间透明

fillLayer.fillRule = kCAFillRuleEvenOdd;

//半透明效果

fillLayer.fillColor = [UIColor colorWithHexString:@"0x000000" alpha:0.4].CGColor;

[self.layer addSublayer:fillLayer];

//绘制虚线边框

CAShapeLayer *vertulLineLayer = [CAShapeLayer layer];

vertulLineLayer.path = headerPath.CGPath;

vertulLineLayer.strokeColor = [UIColor whiteColor].CGColor;

vertulLineLayer.fillColor = [UIColor clearColor].CGColor;

vertulLineLayer.lineCap = kCALineCapRound;

vertulLineLayer.lineWidth = 2;

vertulLineLayer.lineDashPattern = @[@8,@8];

[self.layer addSublayer:vertulLineLayer];

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值