QQ空间HD-实现自定义的选项卡切换效果

Posted 夜行过客

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了QQ空间HD-实现自定义的选项卡切换效果相关的知识,希望对你有一定的参考价值。

DJTabbarButton.m

#import "DJTabbarButton.h"

@implementation DJTabbarButton


- (instancetype)initWithFrame:(CGRect)frame {

    if (self = [super initWithFrame:frame]) {
        [self setBackgroundImage:[UIImage imageNamed:@"tabbar_separate_selected_bg"] forState:UIControlStateDisabled];
        self.imageView.contentMode = UIViewContentModeCenter;
        
        /* 设置当按钮不可用或高亮状态时不要修改图片 */
        self.adjustsImageWhenDisabled = NO;
        self.adjustsImageWhenHighlighted = NO;
//        self.backgroundColor = [UIColor greenColor];
    }
    return self;
}



- (void)layoutSubviews {

    [super layoutSubviews];
    
    if (DJLandscape) { // 横屏
        
        /* imageView */
        self.imageView.x = 0;
        self.imageView.y = 0;
        self.imageView.width = self.width * 0.4;
        self.imageView.height = self.height;
        
        /* titleLabel */
        self.titleLabel.hidden = NO;
        self.titleLabel.x = self.imageView.width;
        self.titleLabel.y = 0;
        self.titleLabel.width = self.width - self.imageView.width;
        self.titleLabel.height = self.height;
        
    } else { // 竖屏
    
        /* imageView */
        self.imageView.frame = self.bounds;
        /* titleLabel */
        self.titleLabel.hidden = YES;
    }
}



/* 设置按钮无高亮状态 */
- (void)setHighlighted:(BOOL)highlighted {


}


@end

DJHomeViewController.m

// 添加子控制器
- (void)setupChildViewControllers {

    for (int i = 0; i < 6; i++) {
        UIViewController *childVC = [[UIViewController alloc] init];
        childVC.view.backgroundColor = DJRandomColor;
        [self addChildViewController:childVC];
    }
}

- (void)replaceCurrentShowingController:(DJTabBarIndex)index {

    // 将当前显示的子控制器的View从界面上移除
    [self.showingChildVc.view removeFromSuperview];
    UIViewController *newShowingVc;
    switch (index) {
        case DJTabBarIndexAllStatus: // 全部动态
            newShowingVc = self.childViewControllers[0];
            break;
        case DJTabBarIndexWithMe: // 与我相关
             newShowingVc = self.childViewControllers[1];
            break;
        case DJTabBarIndexPhotoWall: // 照片樯
             newShowingVc = self.childViewControllers[2];
            break;
        case DJTabBarIndexPhotoFrame: // 电子相框
             newShowingVc = self.childViewControllers[3];
            break;
        case DJTabBarIndexFriend: // 好友
             newShowingVc = self.childViewControllers[4];
            break;
        case DJTabBarIndexMore: // 更多
             newShowingVc = self.childViewControllers[5];
            break;
    }
    
    newShowingVc.view.x = self.menuView.width;
    newShowingVc.view.y = 0;
    newShowingVc.view.width = self.view.width - self.menuView.width;
    newShowingVc.view.height = self.view.height;
    [self.view addSubview:newShowingVc.view];
    self.showingChildVc = newShowingVc;
    
}


- (void)updateSubViewFrameInLandscape {

    /* menuView */
    self.menuView.width = DJMenuViewLW;
    self.menuView.height = DJScreenLH;
    self.menuView.x = 0;
    self.menuView.y = 0;
    
    /* showingChildVc */
    self.showingChildVc.view.x = self.menuView.width;
    self.showingChildVc.view.y = 0;
    self.showingChildVc.view.width = DJScreenLW - self.menuView.width;
    self.showingChildVc.view.height = DJScreenLH;
    
}


- (void)updateSubViewsViewFrameInPortrait {

    /* menuView */
    self.menuView.width = DJMenuViewPW;
    self.menuView.height = DJScrrenPH;
    self.menuView.x = 0;
    self.menuView.y = 0;
    
    /* showingChildVc */
    self.showingChildVc.view.x = self.menuView.width;
    self.showingChildVc.view.y = 0;
    self.showingChildVc.view.width = DJScreenPW - self.menuView.width;
    self.showingChildVc.view.height = DJScrrenPH;
    
}
// 当屏幕方向将会发生改变时调用此方法
- (void)willRotateToInterfaceOrientation:(UIInterfaceOrientation)toInterfaceOrientation duration:(NSTimeInterval)duration {
    
    if (UIInterfaceOrientationIsLandscape(toInterfaceOrientation)) { // 横屏
        [self updateSubViewFrameInLandscape];
    } else { // 竖屏
        [self updateSubViewsViewFrameInPortrait];
    }
    

    // 设置当前子控制器的View不拉伸
    self.showingChildVc.view.autoresizingMask = UIViewAutoresizingNone;
    
}

最终效果:

 

以上是关于QQ空间HD-实现自定义的选项卡切换效果的主要内容,如果未能解决你的问题,请参考以下文章

TabTopLayout自定义顶部选项卡区域(固定宽度且居中)

用html+css+js实现选项卡切换效果

TabLayoutBottomDemoTabLayout实现底部选项卡

Android:使用选项卡在不同片段之间切换

vue实现选项卡切换效果

如何实现tabs选项卡效果