How to change text color of UITabBarItem?

Possible duplicate:
Setting the text color in the selected tab element

Hello,

I am programming in Objective-C for the iPhone. I want to change the text color of a Tab Bar element when I pulsate it. Is it possible?

Many thanks.

Sincerely.

+3
source share
2 answers

Add this to the application delegate file -

 @interface UITabBar (ColorExtensions)
 - (void)recolorItemsWithColor:(UIColor *)color shadowColor:(UIColor *)shadowColor shadowOffset:(CGSize)shadowOffset shadowBlur:(CGFloat)shadowBlur;
 @end

 @interface UITabBarItem (Private)
 @property(retain, nonatomic) UIImage *selectedImage;
 - (void)_updateView;
 @end

 @implementation UITabBar (ColorExtensions)

 - (void)recolorItemsWithColor:(UIColor *)color shadowColor:(UIColor *)shadowColor shadowOffset:(CGSize)shadowOffset shadowBlur:(CGFloat)shadowBlur
 {
 CGColorRef cgColor = [color CGColor];
 CGColorRef cgShadowColor = [shadowColor CGColor];
 for (UITabBarItem *item in [self items])
 if ([item respondsToSelector:@selector(selectedImage)] &&
 [item respondsToSelector:@selector(setSelectedImage:)] &&
 [item respondsToSelector:@selector(_updateView)])
 {
 CGRect contextRect;
 contextRect.origin.x = 0.0f;
 contextRect.origin.y = 0.0f;
 contextRect.size = [[item selectedImage] size];
 // Retrieve source image and begin image context
 UIImage *itemImage = [item 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]);

 //Setup the gradient...    
 //CGFloat components[8] = {0.0,0.4,1.0,0.2,0.0,0.6,1.0,1.0};
 //CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();  
 //CGGradientRef colorGradient = CGGradientCreateWithColorComponents(colorSpace, components, NULL, 2);
 //CGContextDrawLinearGradient(c, colorGradient,CGPointZero,CGPointMake(0,contextRect.size.height),0);


 // Fill and end the transparency layer
 CGContextSetFillColorWithColor(c, cgColor);
 contextRect.size.height = -contextRect.size.height;
 CGContextFillRect(c, contextRect);
 CGContextEndTransparencyLayer(c);



 // Set selected image and end context
 [item setSelectedImage:UIGraphicsGetImageFromCurrentImageContext()];
 UIGraphicsEndImageContext();
 // Update the view
 [item _updateView];



 }

 }

and then you can specify the color on the tab bar in the application that completed the launch using this code -

[[tabbarcontroller tabBar] recolorItemsWithColor:[UIColor colorWithRed:0.6640 green:0.1992 blue:0.1992 alpha:1.0] shadowColor:[UIColor clearColor] shadowOffset:CGSizeMake(0.0f, -1.0f) shadowBlur:3.0f];
+3
source

, UITabBarController, , . iOS- iOS, , , / Apple.

0

All Articles