只使用Quartzcore / layer为UIView添加顶部边框?

时间:2013-07-12 06:46:33

标签: ios uiview layer

是否可以在UIView之上添加边框,如果是这样,请问怎么样?

8 个答案:

答案 0 :(得分:96)

我只是测试Bellow的几行代码并且它非常好用,只需测试它到您的项目中。希望您能轻松获得解决方案。

为什么要创建新视图并将其添加到现有视图中?对于此任务,只需创建一个 CALayer 并将其添加到现有的UIView的图层中,如下所示: -

#import <QuartzCore/QuartzCore.h>
- (void)viewDidLoad
{
    CALayer *TopBorder = [CALayer layer];
    TopBorder.frame = CGRectMake(0.0f, 0.0f, myview.frame.size.width, 3.0f);
    TopBorder.backgroundColor = [UIColor redColor].CGColor;
    [myview.layer addSublayer:TopBorder];

  [super viewDidLoad];

}

和它的输出是: -

enter image description here

答案 1 :(得分:18)

我找到了解决方案,这里有一些技巧:

CGSize mainViewSize = self.view.bounds.size;
CGFloat borderWidth = 1;
UIColor *borderColor = [UIColor colorWithRed:37.0/255 green:38.0/255 blue:39.0/255 alpha:1.0];
UIView *topView = [[UIView alloc] initWithFrame:CGRectMake(0.0, 0.0, mainViewSize.width, borderWidth)];
topView.opaque = YES;
topView.backgroundColor = borderColor;
topView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleBottomMargin;        
[self.view addSubview:topView];

答案 2 :(得分:8)

GilbertOOI在Swift 2中的回答:

let topBorder: CALayer = CALayer()
topBorder.frame = CGRectMake(0.0, 0.0, myView.frame.size.width, 3.0)
topBorder.backgroundColor = UIColor.redColor().CGColor
myView.layer.addSublayer(topBorder)

答案 3 :(得分:6)

这是一个UIView类别,可让您在UIView的任何一侧添加一个后退或视图支持的边框:UIView+Borders

答案 4 :(得分:2)

我创建了这个简单的UIView子类,以便它在Interface Builder中工作并使用约束: https://github.com/natrosoft/NAUIViewWithBorders

这是关于它的博文: http://natrosoft.com/?p=55

- 基本上只需在Interface Builder中放入UIView并将其类类型更改为NAUIViewWithBorders。
- 然后在VC的viewDidLoad中执行以下操作:

/* For a top border only ———————————————- */
self.myBorderView.borderColorTop = [UIColor redColor];
self.myBorderView..borderWidthsAll = 1.0f;

/* For borders with different colors and widths ————————— */
self.myBorderView.borderWidths = UIEdgeInsetsMake(2.0, 4.0, 6.0, 8.0);
self.myBorderView.borderColorTop = [UIColor blueColor];
self.myBorderView.borderColorRight = [UIColor redColor];
self.myBorderView.borderColorBottom = [UIColor greenColor];
self.myBorderView.borderColorLeft = [UIColor darkGrayColor];

这是指向.m文件的直接链接,因此您可以看到实施:NAUIViewWithBorders.m
还有一个演示项目。

答案 5 :(得分:2)

瑞摩斯&#39;在Obj-C中回答:

 CALayer *topBorder = [CALayer new];
 topBorder.frame = CGRectMake(0.0, 0.0, self.frame.size.width, 3.0);
 topBorder.backgroundColor = [UIColor redColor].CGColor;
 [myView.layer addSublayer:topBorder];

答案 6 :(得分:2)

Swift 4中的

GilbertOOI's answer

let topBorder: CALayer = CALayer()
topBorder.frame = CGRect(x: 0, y: 0, width: myView.frame.size.width, height: 1)
topBorder.backgroundColor = UIColor.purple.cgColor
myView.layer.addSublayer(topBorder)

答案 7 :(得分:0)

Swift5:

我们将编写一个单独的方法来向此视图添加边框。要向该视图添加边框,我们将创建具有所需厚度的两层。我们将这两层的框架设置为视图的顶部和底部。我们将在这些图层上设置所需的边框背景颜色,并将这些图层作为子图层添加到视图中。

func addTopBorders() {
   let thickness: CGFloat = 1.0
   let topBorder = CALayer()
   topBorder.frame = CGRect(x: 0.0, y: 0.0, width: 
   self.down_view_outlet.frame.size.width, height: thickness)
   topBorder.backgroundColor = UIColor.white.cgColor
   down_view_outlet.layer.addSublayer(topBorder)
}