UILabel添加GradientLayer

时间:2013-05-11 10:57:58

标签: ios uilabel cagradientlayer

要向UILabel添加背景渐变,请使用以下代码。

在使用渐变之前,UILabel看起来像这样。

WithOut Gradient

现在,要添加渐变,请使用以下代码。

   CAGradientLayer *gradLayer=[CAGradientLayer layer];
    gradLayer.frame=self.myView.layer.bounds;
    [gradLayer setColors:[NSArray arrayWithObjects:(id)([UIColor redColor].CGColor), (id)([UIColor cyanColor].CGColor),nil]];
    gradLayer.endPoint=CGPointMake(1.0, 0.0);

    [self.myView.layer addSublayer:gradLayer];

UILabel则如下,但没有文字。

With Gradient

我也尝试在UILabel图层的底部添加图层,但没有成功。

[self.myView.layer insertSublayer:gradLayer atIndex:0];

1 个答案:

答案 0 :(得分:5)

您可能需要将标签设置为另一个UIView的顶部:

 UIView *labelBackground = [[UIView alloc] initWithFrame:self.label.frame];
 self.label.backgroundColor = [UIColor clearColor];
 self.label.frame = self.label.bounds;

 CAGradientLayer *gradLayer=[CAGradientLayer layer];
 gradLayer.frame = labelBackground.layer.bounds;
 [gradLayer setColors:[NSArray arrayWithObjects:(id)([UIColor redColor].CGColor), (id)([UIColor cyanColor].CGColor),nil]];
 gradLayer.endPoint=CGPointMake(1.0, 0.0);

 [labelBackground.layer addSublayer:gradLayer];

 [labelBackground addSubview:self.label];

 [self.view addSubview:labelBackground];