iOS 利用圖層的mask製作無縫的過渡效果

來源:互聯網
上載者:User

標籤:

範例程式碼

- (void)viewDidLoad {

    [super viewDidLoad];

 

    [self creatLayer];

    [self creatText];

    [NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(change) userInfo:nil repeats:YES];

}

 

- (void)creatLayer

{

    CALayer *left = [CALayer layer];

    left.frame = CGRectMake(100, 100, 200, 50);

    left.backgroundColor = [UIColor blueColor].CGColor;

    [self.view.layer addSublayer:left];

    self.left = left;

    

    CALayer *right = [CALayer layer];

    right.frame = CGRectMake(100, 100, 200, 50);

    right.backgroundColor = [UIColor redColor].CGColor;

    [self.view.layer addSublayer:right];

    self.right = right;

}

 

- (void)creatText

{

    UILabel * leftLabel =[[UILabel alloc]initWithFrame:CGRectMake(100, 200, 200, 50)];

    leftLabel.text = @"測試一下測試一下測試";

    leftLabel.textColor = [UIColor redColor];

    leftLabel.textAlignment = NSTextAlignmentCenter;

    [self.view addSubview:leftLabel];

    self.leftLabel = leftLabel;

    

    UILabel * rightLabel =[[UILabel alloc]initWithFrame:CGRectMake(100, 200, 200, 50)];

    rightLabel.text = @"測試一下測試一下測試";

    rightLabel.textColor = [UIColor blueColor];

    rightLabel.textAlignment = NSTextAlignmentCenter;

    [self.view addSubview:rightLabel];

    self.rightLabel = rightLabel;    

}

 

- (void)change

{

    self.bili = arc4random()%100;

 

    self.left.mask = [CALayer layer];

    self.left.mask.backgroundColor = [[UIColor blackColor] CGColor];

    self.left.mask.frame = CGRectMake(0, 0, 100+self.bili, 50);

    

    self.right.mask = [CALayer layer];

    self.right.mask.backgroundColor = [[UIColor blackColor ] CGColor];

    self.right.mask.frame = CGRectMake(100+self.bili, 0, 100- self.bili, 50);

    

    self.leftLabel.layer.mask = [CALayer layer];

    self.leftLabel.layer.mask.backgroundColor = [[UIColor blackColor] CGColor];

    self.leftLabel.layer.mask.frame = CGRectMake(0, 0, 100+self.bili, 50);

    

    self.rightLabel.layer.mask = [CALayer layer];

    self.rightLabel.layer.mask.backgroundColor = [[UIColor blackColor ] CGColor];

    self.rightLabel.layer.mask.frame = CGRectMake(100+self.bili, 0, 100- self.bili, 50);

}

  

 

KVNMaskedPageControl的實現原理也是如此:

http://www.oschina.net/p/kvnmaskedpagecontrol/similar_projects?lang=0&sort=view&p=1 

iOS 利用圖層的mask製作無縫的過渡效果

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.