2013-10-16 45 views
-1

我正在使用自定义选项卡栏buttons.I已在自定义选项卡栏的顶部position.I已成功做到了。但我希望标签栏位置在中心为两个视图控制器>我该怎么做。是否有可能? 这是我的代码在2选项卡视图中更改自定义选项卡栏位置控制器

这是我的自定义选项卡bar.m文件

-(void)addCustomElements 
{ 
    btn1 = [UIButton buttonWithType:UIButtonTypeCustom]; //Setup the button 
btn1.frame = CGRectMake(0, 264, 65, 40); // Set the frame (size and position) of the button) 
[btn1 setBackgroundColor:[UIColor darkGrayColor]]; 
[btn1.titleLabel setFont:[UIFont fontWithName:@"Helvetica Neue" size:16.0]]; 
[btn1 setTitle:@"Info" forState:UIControlStateNormal]; 
[btn1 setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; 
[btn1 setTag:0]; // Assign the button a "tag" so when our "click" event is called we know which button was pressed. 
[btn1 setSelected:true]; // Set this button as selected (we will select the others to false as we only want Tab 1 to be selected initially 

// Now we repeat the process for the other buttons 

btn2 = [UIButton buttonWithType:UIButtonTypeCustom]; //Setup the button 
btn2.frame = CGRectMake(64, 264, 65, 40); // Set the frame (size and position) of the button) 
[btn2 setBackgroundColor:[UIColor darkGrayColor]]; 
[btn2.titleLabel setFont:[UIFont fontWithName:@"Helvetica Neue" size:16.0]]; 
[btn2 setTitle:@"Book" forState:UIControlStateNormal]; 
[btn2 setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; 
[btn2 setTag:1]; // Assign the button a "tag" so when our "click" event is called we know which button was pressed. 
[btn2 setSelected:true]; 


btn3 = [UIButton buttonWithType:UIButtonTypeCustom]; //Setup the button 
btn3.frame = CGRectMake(128, 264, 65, 40); // Set the frame (size and position) of the button) 
[btn3 setBackgroundColor:[UIColor darkGrayColor]]; 
[btn3.titleLabel setFont:[UIFont fontWithName:@"Helvetica Neue" size:16.0]]; 
[btn3 setTitle:@"Menu" forState:UIControlStateNormal]; 
[btn3 setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; 
[btn3 setTag:2]; // Assign the button a "tag" so when our "click" event is called we know which button was pressed. 
[btn3 setSelected:true]; 

btn4 = [UIButton buttonWithType:UIButtonTypeCustom]; //Setup the button 
btn4.frame = CGRectMake(193, 264, 65, 40); // Set the frame (size and position) of the button) 
[btn4.titleLabel setFont:[UIFont fontWithName:@"Helvetica Neue" size:16.0]]; 
[btn4 setBackgroundColor:[UIColor darkGrayColor]]; 
[btn4 setTitle:@"Reviews" forState:UIControlStateNormal]; 
[btn4 setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; 
[btn4 setTag:3]; // Assign the button a "tag" so when our "click" event is called we know which button was pressed. 
[btn4 setSelected:true]; 

btn5 = [UIButton buttonWithType:UIButtonTypeCustom]; //Setup the button 
btn5.frame = CGRectMake(258, 264, 65, 40); // Set the frame (size and position) of the button) 
[btn5.titleLabel setFont:[UIFont fontWithName:@"Helvetica Neue" size:16.0]]; 
[btn5 setBackgroundColor:[UIColor darkGrayColor]]; 
[btn5 setTitle:@"Map" forState:UIControlStateNormal]; 
[btn5 setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; 
[btn5 setTag:4]; // Assign the button a "tag" so when our "click" event is called we know which button was pressed. 
[btn5 setSelected:true]; 


// Add my new buttons to the view 
[self.view addSubview:btn1]; 
[self.view addSubview:btn2]; 
[self.view addSubview:btn3]; 
[self.view addSubview:btn4]; 
[self.view addSubview:btn5]; 

// Setup event handlers so that the buttonClicked method will respond to the touch up inside event. 
[btn1 addTarget:self action:@selector(buttonClicked:) forControlEvents:UIControlEventTouchUpInside]; 
[btn2 addTarget:self action:@selector(buttonClicked:) forControlEvents:UIControlEventTouchUpInside]; 
[btn3 addTarget:self action:@selector(buttonClicked:) forControlEvents:UIControlEventTouchUpInside]; 
[btn4 addTarget:self action:@selector(buttonClicked:) forControlEvents:UIControlEventTouchUpInside]; 
[btn5 addTarget:self action:@selector(buttonClicked:) forControlEvents:UIControlEventTouchUpInside]; 
} 
    - (void)buttonClicked:(id)sender 
    { 
int tagNum = [sender tag]; 
[self selectTab:tagNum]; 
} 

-(void)selectTab:(int)tabID 
{ 
switch(tabID) 
{ 
    case 0: 
     [btn1 setSelected:true]; 
     [btn2 setSelected:false]; 
     [btn3 setSelected:false]; 
     [btn4 setSelected:false]; 
     [btn5 setSelected:false]; 
     break; 
    case 1: 
     [btn1 setSelected:false]; 
     [btn2 setSelected:true]; 
     [btn3 setSelected:false]; 
     [btn4 setSelected:false]; 
     [btn5 setSelected:false]; 
     break; 
    case 2: 
     [btn1 setSelected:false]; 
     [btn2 setSelected:false]; 
     [btn3 setSelected:true]; 
     [btn4 setSelected:false]; 
     [btn5 setSelected:false]; 
     break; 
    case 3: 
     [btn1 setSelected:false]; 
     [btn2 setSelected:false]; 
     [btn3 setSelected:false]; 
     [btn4 setSelected:true]; 
     [btn5 setSelected:false]; 
     break; 
    case 4: 
     [btn1 setSelected:false]; 
     [btn2 setSelected:false]; 
     [btn3 setSelected:false]; 
     [btn4 setSelected:false]; 
     [btn5 setSelected:true]; 
     break; 
} 

    if (self.selectedIndex == tabID) { 
    UINavigationController *navController = (UINavigationController *)[self selectedViewController]; 
    [navController popToRootViewControllerAnimated:YES]; 
} else { 
    self.selectedIndex = tabID; 
} 


} 
- (void)viewDidLoad 
{ 
[super viewDidLoad]; 

[self hideExistingTabBar]; 
[self addCustomElements]; 

// Do any additional setup after loading the view. 

}

请Help.Thanks在前进!

+0

你在这里有很多重复的代码。重构方法的时机已经成熟。 – Abizern

+0

我已经使用5个按钮作为选项卡。这就是为什么我已经使用框架,并为他们分配每个按钮 – Harry

回答

-2

你可以试试这个方法,这里是链接和源代码,在此您可以更改标签

https://github.com/hollance/MHTabBarController

希望的位置,这可以帮助你。

+0

我希望一个视图控制器的顶部标签栏和第二个视图控制器使用自定义标签栏中心相同的标签栏 – Harry

相关问题