Twitter-esque UITabBarController?

后端 未结 5 936
抹茶落季
抹茶落季 2020-12-14 03:51

I\'d like to make an app that uses a UITabBarController that is similar to the one in the Twitter app for iPhone and iPod touch. (Blue light for unread and sliding arrow for

相关标签:
5条回答
  • 2020-12-14 04:25

    Here is how you create the arrow

    http://isagoksu.com/2009/development/iphone/fancy-uitabbar-like-tweetie/

    And follow Rafael's answer to get the blue light.

    0 讨论(0)
  • 2020-12-14 04:32

    BCTabBarController is what I based my custom twitter style tab-bar on and it works in iOS 4 and 5: http://pastebin.me/f9a876a6ad785cb0b2b7ad98b1024847

    Each tab view controller should implement the following method for the tabs image:

    - (NSString *)iconImageName {
        return @"homeTabIconImage.png";
    }
    

    (In the App delegate) you would initialize the tab bar controller like so:

    self.tabBarController = [[[JHTabBarController alloc] init] autorelease];
    self.tabBarController.delegate = self;
    self.tabBarController.viewControllers = [NSArray arrayWithObjects:
                                             [[[UINavigationController alloc] initWithRootViewController:[[[iPhoneHomeViewController alloc] init] autorelease]] autorelease],
                                             [[[UINavigationController alloc] initWithRootViewController:[[[iPhoneAboutUsViewController alloc] init] autorelease]] autorelease],
                                             [[[UINavigationController alloc] initWithRootViewController:[[[iPhoneContactInfoViewController alloc] init] autorelease]] autorelease],
                                             [[[UINavigationController alloc] initWithRootViewController:[[[iPhoneMapUsViewController alloc] init] autorelease]] autorelease],
                                             [[[UINavigationController alloc] initWithRootViewController:[[[iPhoneCreditsViewController alloc] init] autorelease]] autorelease],
                                                 nil];
    

    Optionally, you can use a custom background image for each tabs view controller with this method:

    - (UIImage *)tabBarController:(JHTabBarController *)tabBarController backgroundImageForTabAtIndex:(NSInteger)index {
        NSString *bgImagefilePath;
        switch (index) {
            case 0:
                bgImagefilePath = @"homeBG.png";
                break;
            case 1:
                bgImagefilePath = @"aboutBG.png";
                break;
            case 2:
                bgImagefilePath = @"contactBG.png";
                break;
            case 3:
                bgImagefilePath = @"mapBG.png";
                break;
            case 4:
                bgImagefilePath = @"creditsBG.png";
                break;
            default:
                bgImagefilePath = @"homeBG.png";
                break;
        }
        return [UIImage imageNamed:bgImagefilePath];
    }
    

    The arrow at the top of the tab bar slides across to the tab that is selected just like the twitter tab bar.

    Some screenshots:

    BCTabBarController BCTabBarController

    0 讨论(0)
  • 2020-12-14 04:35

    Although an ageing post, I though I would interject with a GitHub project that no one mentioned, they've recreated the Twitter styled tab bar quite well, here is the link:

    https://github.com/boctor/idev-recipes/tree/master/CustomTabBar

    The project is in the sub folder named "CustomTabBar", more information can be found here:

    http://idevrecipes.com/2011/01/04/how-does-the-twitter-iphone-app-implement-a-custom-tab-bar/

    0 讨论(0)
  • 2020-12-14 04:39

    I would create a subclass of the standard UITabBarController and add a couple of subviews for the blue light and the sliding arrow. Shouldn't be too hard to accomplish.

    Edit: Here's an idea of some of the stuff that should go in your subclass. I don't even know if this code will compile.

    - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {
        if ((self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil])) {
            super.delegate = self;
        }
        return self;
    }
    
    - (void)viewDidLoad {
        [super viewDidLoad];
    
        //Create blueLight
        UIImage* img = [UIImage imageNamed:@"blue_light.png"]
        self.blueLight = [[UIImageView alloc] initWithImage:img];
        self.blueLight.center = CGPointMake(320, 460); //I'm using arbitrary numbers here, position it correctly
        [self.view addSubview:self.blueLight];
        [self.blueLight release];
    
        //Create arrow, similar code.
    }
    
    - (void)tabBarController:(UITabBarController *)tabBarController didSelectViewController:(UIViewController *)viewController{
        //Put code here that moves (animates?) the blue light and the arrow
    
    
        //Tell your delegate, what just happened.
        if([myDelegate respondsToSelector:@selector(tabBarController:didSelectViewController:)]){
            [myDelegate tabBarController:self didSelectViewController:viewController]
        }
    }
    
    0 讨论(0)
  • 2020-12-14 04:44

    Just 2day I made one app like this one for POC, it turns out that it is easier than you can think.

    First in my applicationdidfinishlaunching: method I added the imageview holding the image of pointer or arrow with the width as 64 as the screen width is 320 and I have 5 tabs in the tab bar. you can also calculate it if you think that your project will have dynamic tabs and then just change the width of the imageview accordingly something like this.

    CGRect rect = tabBarpointerImageView.frame;
    rect.size.width = sel.window.frame.size.width / tabbarcontroller.viewControllers.count;
    tabBarpointerImageView.frame = rect;
    

    You might also want to set the content mode of that image view as uiviewcontentmodecenter
    Also I have set the frame of the imageview by some calculation like this

    CGRect rect = CGRectZero;
    rect.size.width = self.window.frame.size.width / tabbarcontroller.viewControllers.count;
    rect.size.height = 10;// as image was of 10 pixel height.
    rect.origin.y = self.window.frame.size.height - 49;// as the height of tab bar is 49
    tabBarpointerImageView.frame = rect;
    

    And then in the delegate method of tab bar controller

    - (void)tabBarController:(UITabBarController *)tabBarController didSelectViewController:(UIViewController *)viewController
    

    just use an animation block to animate the movement of pointer like this

    [uiview beginanimation:nil context:nil];
    CGRect rect = tabBarpointerImageView.frame;
    rect.origin.x = rect.size.width * tabbarcontroller.selectedIndex;
    tabBarpointerImageView.frame = rect;
    [uiview commitanimations];
    

    PS. Sorry if some spellings are not correct.

    0 讨论(0)
提交回复
热议问题