所以我一直在寻找并尝试不同的代码,我无法真正实现我想要的。我希望能找到我在这里寻找的东西。
我正在尝试制作自定义数字键盘。这是我想要的结果:
但是我得到的很接近。
第一个问题是我无法通过申请和取消按钮来设置边框。我该如何解决这个问题?
第二个问题是我想在我的数字键盘上添加+ *#按钮。我怎么能这样做?
这是我正在使用的代码:
self.numberToolbar = [[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 50)];
self.numberToolbar.barStyle = UIBarStyleBlackTranslucent;
self.numberToolbar.items = [NSArray arrayWithObjects:
[[UIBarButtonItem alloc]initWithTitle:@"Cancel" style:UIBarButtonItemStylePlain target:self action:@selector(cancelNumberPad)],
[[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:nil action:nil],
[[UIBarButtonItem alloc]initWithTitle:@"Apply" style:UIBarButtonItemStyleDone target:self action:@selector(doneWithNumberPad)],
nil];
[self.numberToolbar sizeToFit];
self.driverNumber.inputAccessoryView = self.numberToolbar;
答案 0 :(得分:1)
第一个问题是我无法通过申请和取消按钮来设置边框。我该如何解决这个问题?
正如您所知,按钮没有边框。所以没有什么可以“修复”。如果你坚持使用边框,则必须自己绘制按钮的背景图像,使其具有看起来像边框的东西。以下是我在一个应用中使用的一些代码:
b.setBackgroundImage(imageOfSize(CGSizeMake(15,15)) {
let grad = CAGradientLayer()
grad.frame = CGRectMake(0,0,15,15)
grad.colors = [
UIColor(red: 1, green: 1, blue: 0, alpha: 0.8).CGColor,
UIColor(red: 0.7, green: 0.7, blue: 0.3, alpha: 0.8).CGColor]
let p = UIBezierPath(
roundedRect: CGRectMake(0,0,15,15), cornerRadius: 8)
p.addClip()
grad.renderInContext(UIGraphicsGetCurrentContext())
UIColor.blackColor().setStroke()
p.lineWidth = 2
p.stroke()
}.resizableImageWithCapInsets(
UIEdgeInsetsMake(7,7,7,7), resizingMode: .Stretch),
forState: .Normal)
答案 1 :(得分:0)
在iOS 7中,默认UIButton具有透明背景且没有边框。在iOS7 +中,如果你想拥有像iOS 6这样的角落和背景,请使用自定义按钮。
UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
现在,您可以根据需要设置背景,边框和圆角半径。
button.layer.cornerRadius = 2.0f;
button.layer.borderWidth = 1.0f;
button.layer.borderColor = [UIColor whiteColor].CGColor;
button.backgroundColor = [UIColor blueColor];
button.clipsToBounds = YES;