首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >UIPickerView - iOS 8中的梯度破坏

UIPickerView - iOS 8中的梯度破坏
EN

Stack Overflow用户
提问于 2014-10-11 12:24:13
回答 1查看 722关注 0票数 1

在iOS 8之前,能够将渐变背景设置为UIPickerView,以便旋转器将显示在其顶部和后面,梯度背景如下所示:

以下是iOS 8之前的上述代码:

代码语言:javascript
复制
CAGradientLayer *gradient = [CAGradientLayer layer];
gradient.frame = pickerView.bounds;
gradient.colors = [NSArray arrayWithObjects:
                   (id)[[UIColor blackColor] CGColor],
                   (id)[[UIColor darkGrayColor] CGColor],
                   (id)[[UIColor lightGrayColor] CGColor],
                   (id)[[UIColor whiteColor] CGColor],
                   (id)[[UIColor lightGrayColor] CGColor],
                   (id)[[UIColor darkGrayColor] CGColor],
                   (id)[[UIColor blackColor] CGColor],
                   nil];

[pickerView.layer insertSublayer:gradient atIndex:0];

使用iOS 8中的上述代码,如下所示:

这两个选择器仍然可以使用,但正如您所看到的,UI是不可接受的。

有什么建议吗?提前感谢!

EN

回答 1

Stack Overflow用户

发布于 2014-10-13 12:38:03

好吧,我找到了解决办法,但还是有其他更好的选择。我的解决办法是:

  1. 使UIPickerView backgroundColor透明
  2. 在UILabel后面放置UIPickerView
  3. 创建如上所述的渐变,并将其添加到UILabel中作为subLayer :atIndex 0

下面是代码示例:

代码语言:javascript
复制
    CAGradientLayer *gradient = [CAGradientLayer layer];
gradient.frame = colorPickerBackgroundLabel.bounds;
gradient.colors = [NSArray arrayWithObjects:
                   (id)[[UIColor blackColor] CGColor],
                   (id)[[UIColor darkGrayColor] CGColor],
                   (id)[[UIColor lightGrayColor] CGColor],
                   (id)[[UIColor whiteColor] CGColor],
                   (id)[[UIColor lightGrayColor] CGColor],
                   (id)[[UIColor darkGrayColor] CGColor],
                   (id)[[UIColor blackColor] CGColor],
                   nil];
[colorPickerBackgroundLabel.layer addSublayer:gradient];

以下是完成的屏幕区域截图:

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26314636

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档