菱形开合的实现 IOS

实现的原理: 利用了自动布局和形变

核心代码块:

@implementation JHMainView

{

    UILabel *label1,*label2,*label3,*label4;

    UIButton *btn;

}

- (id)initWithFrame:(CGRect)frame

{

    self = [super initWithFrame:frame];

 

    if (self) {

        btn = [[UIButton alloc]initWithFrame:CGRectMake(100, 120, 120, 120)];

        btn.transform = CGAffineTransformRotate(btn.transform, M_PI_4);

 

        [btn addTarget:self action:@selector(btnClick:)forControlEvents:UIControlEventTouchUpInside];

        btn.autoresizesSubviews = YES;

        //btn.backgroundColor = [UIColor cyanColor];

        

        

        label1 = [[UILabel alloc]initWithFrame:CGRectMake(0, 0, 60, 60)];

        

        label1.backgroundColor = [UIColor orangeColor];

        

        label2 = [[UILabel alloc]initWithFrame:CGRectMake(btn.bounds.size.width/2, 0, 60, 60)];

        label2.autoresizingMask =  UIViewAutoresizingFlexibleLeftMargin;

        label2.backgroundColor = [UIColor blackColor];

        

        label3 = [[UILabel alloc]initWithFrame:CGRectMake(0, btn.bounds.size.height/2, 60, 60)];

        label3.backgroundColor = [UIColor blueColor];

        label3.autoresizingMask = UIViewAutoresizingFlexibleTopMargin;

        

        label4 = [[UILabel alloc]initWithFrame:CGRectMake(btn.bounds.size.width/2, btn.bounds.size.height/2, 60, 60)];

        label4.autoresizingMask = UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleLeftMargin;

        label4.backgroundColor = [UIColor purpleColor];

        

        [btn addSubview:label1];

        [btn addSubview:label2];

        [btn addSubview:label3];

        [btn addSubview:label4];

        [self addSubview:btn];

        

        

        

    }

    return self;

}

 

 

- (void)btnClick:(UIButton *)sender

{

    static int i=1 ;

    btn.center = btn.center;

    

    if(i%2)

    {

        btn.bounds = CGRectMake(0, 0, 180, 180);

    }

    else

    {

        btn.bounds = CGRectMake(0, 0, 120, 120);

    }

    

    i++;

}

 

@end

 

转载于:https://www.cnblogs.com/Ohero/p/3924317.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值