iOS UINavigation“后退”按钮Bezier Path

时间:2013-07-17 00:21:54

标签: ios uibarbuttonitem uibezierpath

在我的应用程序中,我使用自定义渐变来设置UIBarButtonItem的所有实例,通过创建渐变,使用圆角矩形Bezier路径剪切渐变,然后创建可调整大小的UIImage,如下所示:

CGRect rect = CGRectMake(0, 0, 44, 44);
CGSize size = rect.size;
CGColorSpaceRef colorspace = CGColorSpaceCreateDeviceRGB();
size_t gradientNumberOfLocations = 2;

UIGraphicsBeginImageContextWithOptions(size, NO, 0);
CGContextRef btncontext = UIGraphicsGetCurrentContext();

CGFloat btngradientLocations[2] = { 0.2, 1.0 };
CGFloat btngradientComponents[8] = { 0.10, 0.10, 0.10, 1.0, 0.05, 0.05, 0.05, 1.0 };

CGGradientRef btngradient = CGGradientCreateWithColorComponents (colorspace, btngradientComponents, btngradientLocations, gradientNumberOfLocations);

UIBezierPath * path = [UIBezierPath bezierPathWithRoundedRect:rect cornerRadius:4.0f];
[path addClip];

CGContextDrawLinearGradient(btncontext, btngradient, CGPointMake(0, 0), CGPointMake(0, size.height), 0);

UIImage *btnimage = UIGraphicsGetImageFromCurrentImageContext();

CGGradientRelease(btngradient);
UIGraphicsEndImageContext();

CGColorSpaceRelease(colorspace);

UIImage *navButton = [btnimage resizableImageWithCapInsets:UIEdgeInsetsMake(22.0, 8.0, 22.0, 8.0)];

[[UIBarButtonItem appearance] setBackgroundImage:navButton forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];

这很好用,我正在开发一种类似的方法来通过-setBackButtonBackgroundImage来设置后退按钮的样式,但我有一个问题:

我想知道是否有人知道创建表示后退按钮轮廓的UIBezierPath对象的正确方法,这样我就可以创建渐变并以编程方式将渐变剪切为后退按钮形状(就像在示例中一样),而不必使用PNG或某些此类资源。

感谢任何帮助,谢谢。

0 个答案:

没有答案