UIButton上奇怪的CAGradientLayer错误

时间:2013-04-15 20:27:33

标签: ios uibutton quartz-core cagradientlayer

我正在尝试对我的ios应用中的所有按钮应用一个小渐变。我为UIButton创建了一个类别,我添加了这个函数,它基本上为按钮添加了字幕,边框和渐变图层。

在视图中调用函数:

- (void)viewDidLoad
{
  [super viewDidLoad];
  [_myButton buttonWithSubtitle:@"test subtitle"];

}

和类别功能

- (void)buttonWithSubtitle:(NSString*)subtitleText
{
  UILabel *subTitle = [[UILabel alloc] initWithFrame:CGRectMake(80, 20, 100, 30)];
  [subTitle setText:subtitleText];
  [subTitle setTextColor:[UIColor colorWithRed:(144.0 / 255.0) green:(144.0 / 255.0) blue:(144.0 / 255.0) alpha:1.0]];
  [subTitle setBackgroundColor:[UIColor clearColor]];
  [subTitle setFont:[UIFont fontWithName:@"American Typewriter" size:12]];
  [self.titleLabel setFrame:CGRectMake(30, 20, 100, 30)];

  [self setTitle:@"Main title" forState:UIControlStateNormal];
  [self addSubview:subTitle];

  CAGradientLayer *btnGradient = [CAGradientLayer layer];
  btnGradient.frame = self.bounds;
  btnGradient.colors = [NSArray arrayWithObjects:
                        (id)[[UIColor colorWithRed:255.0f / 255.0f green:255.0f / 255.0f blue:255.0f / 255.0f alpha:1.0f] CGColor],
                        (id)[[UIColor colorWithRed:234.0f / 255.0f green:234.0f / 255.0f blue:234.0f / 255.0f alpha:1.0f] CGColor],
                        nil];

  [self.layer setMasksToBounds:YES];
  [self.layer setCornerRadius:5.0f];
  [self.layer setBorderWidth:0.8f];
  [self.layer setBorderColor:[[UIColor colorWithRed:200.0f / 255.0f green:200.0f / 255.0f blue:200.0f / 255.0f alpha:1.0f] CGColor]];

  [self.layer insertSublayer:btnGradient atIndex:0];
}

我的问题是,当调用上述函数时,渐变清晰可见,按钮具有所需的设计。但是,我也有一个没有字幕的按钮类型,我使用下面的其他类别功能设置。

- (void)defaultButton
 {
  CAGradientLayer *btnGradient = [CAGradientLayer layer];
  btnGradient.frame = self.bounds;
  btnGradient.colors = [NSArray arrayWithObjects:
                        (id)[[UIColor colorWithRed:255.0f / 255.0f green:255.0f / 255.0f blue:255.0f / 255.0f alpha:1.0f] CGColor],
                        (id)[[UIColor colorWithRed:234.0f / 255.0f green:234.0f / 255.0f blue:234.0f / 255.0f alpha:1.0f] CGColor],
                        nil];

  [self.layer setMasksToBounds:YES];
  [self.layer setCornerRadius:5.0f];
  [self.layer setBorderWidth:0.8f];
  [self.layer setBorderColor:[[UIColor colorWithRed:200.0f / 255.0f green:200.0f / 255.0f blue:200.0f / 255.0f alpha:1.0f] CGColor]];

  [self.layer insertSublayer:btnGradient atIndex:0];
}

使用在viewdidload之前调用的此函数会产生一个根本没有渐变或背景的按钮(按钮具有清晰的背景颜色..我可以通过按钮看到我的视图控制器的视图背景)。

- (void)viewDidLoad
{
  [super viewDidLoad];
  [_myButton defaultButton];

}

我的所有按钮都设置为自定义按钮,带有图像和默认标题。谢谢你的帮助

1 个答案:

答案 0 :(得分:2)

发现问题,虽然我不知道为什么带字幕的代码有效,但问题是,启用autolayout后,你的按钮在viewDidLoad方法中还没有框架。

如果有按钮图层(例如方法

),则必须稍后应用渐变
viewDidLayoutSubviews

请参阅:Can't do custom UIButton in iOS6 with enabled storyboard autolayout