Retina支持自定义UITabBarController,如UIImage突出显示?

时间:2012-02-12 19:40:27

标签: objective-c ios core-graphics quartz-graphics retina-display

我在我的应用中使用BCTabBarController,我正在尝试自定义它,以便它使用Core Graphics自动突出显示图像,这样我就不需要每个图像的四个副本。 (Retina,Retina-selected,Legacy,Legacy-selected)

用户Ephraim已为此posted a great starting point,但它会返回传统尺寸的图片。我玩过一些设置,但我对Core Graphics不太熟悉,所以我在黑暗中拍摄。

以法莲的守则:

- (UIImage *) imageWithBackgroundColor:(UIColor *)bgColor 
                       shadeAlpha1:(CGFloat)alpha1 
                       shadeAlpha2:(CGFloat)alpha2
                       shadeAlpha3:(CGFloat)alpha3 
                       shadowColor:(UIColor *)shadowColor 
                      shadowOffset:(CGSize)shadowOffset 
                        shadowBlur:(CGFloat)shadowBlur { 

UIImage *image = self;

CGColorRef cgColor = [bgColor CGColor];
CGColorRef cgShadowColor = [shadowColor CGColor];

CGFloat components[16] = {1,1,1,alpha1,1,1,1,alpha1,1,1,1,alpha2,1,1,1,alpha3};
CGFloat locations[4] = {0,0.5,0.6,1};

CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();  

CGGradientRef colorGradient = CGGradientCreateWithColorComponents(colorSpace, components, locations, (size_t)4);

CGRect contextRect;
contextRect.origin.x = 0.0f;
contextRect.origin.y = 0.0f;
contextRect.size = [image size];
//contextRect.size = CGSizeMake([image size].width+5,[image size].height+5);  
// Retrieve source image and begin image context
UIImage *itemImage = image;
CGSize itemImageSize = [itemImage size];
CGPoint itemImagePosition; 
itemImagePosition.x = ceilf((contextRect.size.width - itemImageSize.width) / 2);
itemImagePosition.y = ceilf((contextRect.size.height - itemImageSize.height) / 2);
UIGraphicsBeginImageContext(contextRect.size);
CGContextRef c = UIGraphicsGetCurrentContext();
// Setup shadow
CGContextSetShadowWithColor(c, shadowOffset, shadowBlur, cgShadowColor);
// Setup transparency layer and clip to mask
CGContextBeginTransparencyLayer(c, NULL);
CGContextScaleCTM(c, 1.0, -1.0);
CGContextClipToMask(c, CGRectMake(itemImagePosition.x, -itemImagePosition.y, itemImageSize.width, -itemImageSize.height), [itemImage CGImage]);
// Fill and end the transparency layer
CGContextSetFillColorWithColor(c, cgColor);     
contextRect.size.height = -contextRect.size.height;
CGContextFillRect(c, contextRect);
CGContextDrawLinearGradient(c, colorGradient,CGPointZero,CGPointMake(contextRect.size.width*1.0/4.0,contextRect.size.height),0);
CGContextEndTransparencyLayer(c);
//CGPointMake(contextRect.size.width*3.0/4.0, 0)
// Set selected image and end context
UIImage *resultImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();

CGColorSpaceRelease(colorSpace);
CGGradientRelease(colorGradient);

return resultImage;

}

为了实现这段代码,我在项目中为UIImage添加了一个类别,然后对BCTab.h进行了以下更改:

- (id)initWithIconImageName:(NSString *)imageName {
if (self = [super init]) {
    self.adjustsImageWhenHighlighted = NO;
    self.background = [UIImage imageNamed:@"BCTabBarController.bundle/tab-background.png"];
    self.rightBorder = [UIImage imageNamed:@"BCTabBarController.bundle/tab-right-border.png"];
    self.backgroundColor = [UIColor clearColor];

//      NSString *selectedName = [NSString stringWithFormat:@"%@-selected.%@",
//                                 [imageName stringByDeletingPathExtension],
//                                 [imageName pathExtension]];


    UIImage  *defImage = [UIImage imageNamed:imageName];

    [self setImage:[defImage imageWithBackgroundColor:[UIColor lightGrayColor] shadeAlpha1:0.4 shadeAlpha2:0.0 shadeAlpha3:0.6 shadowColor:[UIColor blackColor] shadowOffset:CGSizeMake(0.0, -1.0f) shadowBlur:3.0] forState:UIControlStateNormal];
    [self setImage:[defImage imageWithBackgroundColor:[UIColor redColor] shadeAlpha1:0.4 shadeAlpha2:0.0 shadeAlpha3:0.6 shadowColor:[UIColor blackColor] shadowOffset:CGSizeMake(0.0, -1.0f) shadowBlur:3.0]  forState:UIControlStateSelected];

}
return self;
}

如何使用Ephraim's代码与Retina显示器正常工作?

1 个答案:

答案 0 :(得分:0)

在互联网上挖掘后,a Google search将我带回StackOverflow。我found this answerthis question讨论了一个不同的方法,该方法在初始化时应该用来设置UIImageGraphicsContext的比例因子。

UIGraphicsBeginImageContext(contextRect.size);需要更改为UIGraphicsBeginImageContextWithOptions(contextRect.size, NO, scale);,其中“scale”为  您要使用的比例的值。我从[[UIScreen mainScreen] scale]抓住了它。