[iOS imageView]headImage 异形图片的画法(小技巧记录)

先看成品

这里写图片描述
头像上既不是圆形,也不是方形,好像iOS的控件里也没有这样的异形控件

这样的效果其实是这样做的,
首先
问设计要这样两张图
图一
这里写图片描述

图二
这里写图片描述

关键步骤一
将图二添加到图一中 (小图上添加了一个大图)


    UIImageView *imageV = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"sidebar_icon_tx_kb"]];
    UIImageView *imageMaskV = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"sidebar_icon_txwk1"]];

为了看的更清楚明白,我self.view的背景色调整一下
于是 会有这种效果
这里写图片描述
继续调整
把图二的center配置到图一的center

 [imageMaskV mas_makeConstraints:^(MASConstraintMaker *make) {
        make.center.equalTo(imageV);
    }];

于是
这里写图片描述
填上图片看看效果
这里写图片描述
继续调整
把图一的内边距和图二对齐

[imageMaskV mas_makeConstraints:^(MASConstraintMaker *make) {
        make.edges.equalTo(imageV).insets(UIEdgeInsetsZero);
    }];

这里写图片描述
然后去掉背景色 添加上我们的图 看看效果

这里写图片描述

完整代码


#import "ViewController.h"
#import "Masonry.h"
@interface ViewController ()
{

}
@property (nonatomic,strong)UIImageView *imageHeadView;

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
//    self.view.backgroundColor = [UIColor orangeColor];

    self.imageHeadView.frame = CGRectMake(30, 30, 60, 60);

    self.imageHeadView.image  = [UIImage imageNamed:@"22"];
    [self.view addSubview:self.imageHeadView];


}


-(UIImageView*)imageHeadView{

    if (!_imageHeadView) {
        _imageHeadView = [self headImage];
    }
    return _imageHeadView;
}


-(UIImageView*)headImage{

    UIImageView *imageV = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"sidebar_icon_tx_kb"]];
    UIImageView *imageMaskV = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"sidebar_icon_txwk1"]];
       [imageV addSubview:imageMaskV];
    [imageMaskV mas_makeConstraints:^(MASConstraintMaker *make) {
        make.center.equalTo(imageV);
    }];



    [imageMaskV mas_makeConstraints:^(MASConstraintMaker *make) {
        make.edges.equalTo(imageV).insets(UIEdgeInsetsZero);
    }];

    return imageV;

}




- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

@end
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值