任意形狀的ImageView

demo地址
運(yùn)行效果:

各個形狀的imageview

ZWImageView.h中代碼:

#import <UIKit/UIKit.h>

@interface ZWImageView : UIView
/**
 *  path:形狀
 */
@property (nonatomic, assign) CGPathRef path;
/**
 *  image:圖片
 */
@property (nonatomic, strong) UIImage *image;

- (instancetype)init;
- (instancetype)initWithFrame:(CGRect)frame;
- (instancetype)initWithFrame:(CGRect)frame path:(CGPathRef)path image:(UIImage *)image;
@end

ZWImageView.m中代碼:

#import "ZWImageView.h"

@implementation ZWImageView
{
    CAShapeLayer *maskLayer;
    CALayer *contentLayer;
}
/*
// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
- (void)drawRect:(CGRect)rect {
    // Drawing code
}
*/

- (instancetype)init{
    self = [super init];
    if (self) {
        self.backgroundColor = [UIColor clearColor];
        [self setUpLayers];
    }
    return self;
}

- (instancetype)initWithFrame:(CGRect)frame{
    self = [super initWithFrame:frame];
    if (self) {
        self.backgroundColor = [UIColor clearColor];
        [self setUpLayers];
    }
    return self;
}

- (instancetype)initWithFrame:(CGRect)frame path:(CGPathRef)path image:(UIImage *)image{
    self = [super initWithFrame:frame];
    if (self) {
        _path = path;
        _image = image;
        [self setUpLayers];
    }
    return self;
}

- (void)setUpLayers{
    maskLayer = [[CAShapeLayer alloc] init];
    maskLayer.frame = self.bounds;
    maskLayer.fillColor = [UIColor blackColor].CGColor;
    maskLayer.strokeColor = [UIColor redColor].CGColor;
    //拉伸范圍
//    maskLayer.contentsCenter = CGRectMake(0.5, 0.5, 0.1, 0.1);
    maskLayer.contentsScale = [UIScreen mainScreen].scale;
    maskLayer.path = _path;
    
    contentLayer = [CALayer layer];
    contentLayer.frame = self.bounds;
    //居中裁剪
    contentLayer.contentsGravity = kCAGravityResizeAspectFill;
    contentLayer.mask = maskLayer;
    contentLayer.contents = (__bridge id _Nullable)(_image.CGImage);
    [self.layer addSublayer:contentLayer];
}

- (void)setFrame:(CGRect)frame{
    [super setFrame:frame];
    maskLayer.frame = self.bounds;
    contentLayer.frame = self.bounds;
}

- (void)setPath:(CGPathRef)path{
    _path = path;
    maskLayer.path = path;
}

- (void)setImage:(UIImage *)image{
    _image = image;
    contentLayer.contents = (__bridge id _Nullable)(image.CGImage);
}

@end

使用方法:

//三角形
    UIBezierPath *path1 = [[UIBezierPath alloc] init];
    path1.lineCapStyle = kCGLineCapRound;
    path1.lineJoinStyle = kCGLineJoinRound;
    [path1 moveToPoint:CGPointMake(25, 0)];
    [path1 addLineToPoint:CGPointMake(0, 50)];
    [path1 addLineToPoint:CGPointMake(50, 50)];
    [path1 fill];
    
    ZWImageView *imageView1 = [[ZWImageView alloc] initWithFrame:CGRectMake(20, 100, 50, 50) path:path1.CGPath image:[UIImage imageNamed:@"示例圖"]];
    [self.view addSubview:imageView1];
    
    //波浪
    UIBezierPath *path2 = [[UIBezierPath alloc] init];
    path2.lineCapStyle = kCGLineCapRound;
    path2.lineJoinStyle = kCGLineJoinRound;
    [path2 moveToPoint:CGPointMake(0, 50)];
    [path2 addLineToPoint:CGPointMake(0, 25)];
    //    [path addArcWithCenter:CGPointMake(50, 50) radius:50 startAngle:M_PI endAngle:M_PI_2 clockwise:YES];
    [path2 addCurveToPoint:CGPointMake(50, 25) controlPoint1:CGPointMake(15, 15) controlPoint2:CGPointMake(35, 35)];
    [path2 addLineToPoint:CGPointMake(50, 50)];
    [path2 fill];
    
    ZWImageView *imageView2 = [[ZWImageView alloc] initWithFrame:CGRectMake(120, 100, 50, 50) path:path2.CGPath image:[UIImage imageNamed:@"示例圖"]];
    [self.view addSubview:imageView2];
    
    //橢圓形
    UIBezierPath *path3 = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0, 5, 50, 100)];
    [path3 fill];
    
    ZWImageView *imageView3 = [[ZWImageView alloc] initWithFrame:CGRectMake(220, 100, 50, 120) path:path3.CGPath image:[UIImage imageNamed:@"示例圖"]];
    [self.view addSubview:imageView3];
    
    
    //扇形
    UIBezierPath *path4 = [[UIBezierPath alloc] init];
    [path4 moveToPoint:CGPointMake(50, 100)];
    [path4 addLineToPoint:CGPointMake(0, 50)];
    [path4 addArcWithCenter:CGPointMake(50, 100) radius:70.7 startAngle:M_PI_4 * 5 endAngle:M_PI_4 * 7 clockwise:YES];
    [path4 fill];
    
    ZWImageView *imageView4 = [[ZWImageView alloc] initWithFrame:CGRectMake(20, 180, 100, 100) path:path4.CGPath image:[UIImage imageNamed:@"示例圖"]];
    [self.view addSubview:imageView4];
    
    //四分之三圓
    UIBezierPath *path5 = [[UIBezierPath alloc] init];
    [path5 moveToPoint:CGPointMake(0, 100)];
    [path5 addLineToPoint:CGPointMake(0, 50)];
    [path5 addArcWithCenter:CGPointMake(50, 50) radius:50 startAngle:M_PI endAngle:M_PI_2 clockwise:YES];
    [path5 fill];
    
    ZWImageView *imageView5 = [[ZWImageView alloc] initWithFrame:CGRectMake(20, 300, 100, 100) path:path5.CGPath image:[UIImage imageNamed:@"示例圖"]];
    [self.view addSubview:imageView5];

ZWImageviewpath屬性為CGPathRef類型专肪,可以傳入任意想要的形狀。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末堪侯,一起剝皮案震驚了整個濱河市嚎尤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌伍宦,老刑警劉巖芽死,帶你破解...
    沈念sama閱讀 212,029評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異雹拄,居然都是意外死亡收奔,警方通過查閱死者的電腦和手機(jī)掌呜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,395評論 3 385
  • 文/潘曉璐 我一進(jìn)店門滓玖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人质蕉,你說我怎么就攤上這事势篡◆婕。” “怎么了?”我有些...
    開封第一講書人閱讀 157,570評論 0 348
  • 文/不壞的土叔 我叫張陵禁悠,是天一觀的道長念祭。 經(jīng)常有香客問我,道長碍侦,這世上最難降的妖魔是什么粱坤? 我笑而不...
    開封第一講書人閱讀 56,535評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮瓷产,結(jié)果婚禮上站玄,老公的妹妹穿的比我還像新娘。我一直安慰自己濒旦,他們只是感情好株旷,可當(dāng)我...
    茶點故事閱讀 65,650評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著尔邓,像睡著了一般晾剖。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上梯嗽,一...
    開封第一講書人閱讀 49,850評論 1 290
  • 那天齿尽,我揣著相機(jī)與錄音,去河邊找鬼灯节。 笑死雕什,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的显晶。 我是一名探鬼主播贷岸,決...
    沈念sama閱讀 39,006評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼磷雇!你這毒婦竟也來了偿警?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,747評論 0 268
  • 序言:老撾萬榮一對情侶失蹤唯笙,失蹤者是張志新(化名)和其女友劉穎螟蒸,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體崩掘,經(jīng)...
    沈念sama閱讀 44,207評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡七嫌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,536評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了苞慢。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诵原。...
    茶點故事閱讀 38,683評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出绍赛,到底是詐尸還是另有隱情蔓纠,我是刑警寧澤,帶...
    沈念sama閱讀 34,342評論 4 330
  • 正文 年R本政府宣布吗蚌,位于F島的核電站腿倚,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏蚯妇。R本人自食惡果不足惜敷燎,卻給世界環(huán)境...
    茶點故事閱讀 39,964評論 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望箩言。 院中可真熱鬧懈叹,春花似錦、人聲如沸分扎。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,772評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽畏吓。三九已至墨状,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間菲饼,已是汗流浹背肾砂。 一陣腳步聲響...
    開封第一講書人閱讀 32,004評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留宏悦,地道東北人镐确。 一個月前我還...
    沈念sama閱讀 46,401評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像饼煞,于是被迫代替她去往敵國和親源葫。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,566評論 2 349

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

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,799評論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理砖瞧,服務(wù)發(fā)現(xiàn)息堂,斷路器,智...
    卡卡羅2017閱讀 134,633評論 18 139
  • 前言 本文只要描述了iOS中的Core Animation(核心動畫:隱式動畫块促、顯示動畫)荣堰、貝塞爾曲線、UIVie...
    GitHubPorter閱讀 3,607評論 7 11
  • 在很長一段時間里竭翠,我對冬天的印象都是祖奶奶的小暖爐振坚。那個暖爐是竹編的,形狀像極了古時候的食盒斋扰,不同之處在于暖爐頂部...
    阿青mmmmmay閱讀 277評論 0 0