美文网首页
iOS --下拉菜单FFDropDownMenu的使用

iOS --下拉菜单FFDropDownMenu的使用

作者: 井底蛙之呱呱 | 来源:发表于2017-11-20 13:45 被阅读22次
    Untitled.gif

    创建HomeViewController并作为导航根视图

    //根视图控制器
    #import "HomeViewController.h"
    //自己创建的c
    #import "MenuViewController.h"
    //导入FF的头
    #import "FFDropDownMenuView.h"
    @interface HomeViewController ()<FFDropDownMenuViewDelegate>
    /** 下拉菜单 */
    @property (nonatomic, strong) FFDropDownMenuView *dropdownMenu;
    @end
    
    @implementation HomeViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        // Do any additional setup after loading the view.
        /** 初始化下拉菜单 */
        [self setupDropDownMenu];
        
        self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemAdd target:self action:@selector(showDropDownMenu)];
    }
    
    /** 初始化下拉菜单 */
    - (void)setupDropDownMenu {
        NSArray *modelsArray = [self getMenuModelsArray];
        
        self.dropdownMenu = [FFDropDownMenuView ff_DefaultStyleDropDownMenuWithMenuModelsArray:modelsArray menuWidth:FFDefaultFloat eachItemHeight:FFDefaultFloat menuRightMargin:FFDefaultFloat triangleRightMargin:FFDefaultFloat];
        
        //如果有需要,可以设置代理(非必须)
        self.dropdownMenu.delegate = self;
        
        self.dropdownMenu.ifShouldScroll = NO;
        
        
        [self.dropdownMenu setup];
    }
    
    
    /** 获取菜单模型数组 */
    - (NSArray *)getMenuModelsArray {
        __weak typeof(self) weakSelf = self;
        
        //菜单模型0
        FFDropDownMenuModel *menuModel0 = [FFDropDownMenuModel ff_DropDownMenuModelWithMenuItemTitle:@"QQ" menuItemIconName:@"menu2"  menuBlock:^{
            MenuViewController *vc = [MenuViewController new];
            vc.navigationItem.title = @"QQ";
            [weakSelf.navigationController pushViewController:vc animated:YES];
        }];
        
        
        //菜单模型1
        FFDropDownMenuModel *menuModel1 = [FFDropDownMenuModel ff_DropDownMenuModelWithMenuItemTitle:@"Line" menuItemIconName:@"menu1" menuBlock:^{
            MenuViewController *vc = [MenuViewController new];
            vc.navigationItem.title = @"Line";
            [weakSelf.navigationController pushViewController:vc animated:YES];
        }];
        
        //菜单模型2
        FFDropDownMenuModel *menuModel2 = [FFDropDownMenuModel ff_DropDownMenuModelWithMenuItemTitle:@"Twitter" menuItemIconName:@"menu0" menuBlock:^{
            MenuViewController *vc = [MenuViewController new];
            vc.navigationItem.title = @"Twitter";
            [weakSelf.navigationController pushViewController:vc animated:YES];
        }];
        
        //菜单模型3
        FFDropDownMenuModel *menuModel3 = [FFDropDownMenuModel ff_DropDownMenuModelWithMenuItemTitle:@"QZone" menuItemIconName:@"menu3"  menuBlock:^{
            MenuViewController *vc = [MenuViewController new];
            vc.navigationItem.title = @"QZone";
            [weakSelf.navigationController pushViewController:vc animated:YES];
        }];
        //菜单模型4
        FFDropDownMenuModel *menuModel4 = [FFDropDownMenuModel ff_DropDownMenuModelWithMenuItemTitle:@"WeChat" menuItemIconName:@"menu4"  menuBlock:^{
            MenuViewController *vc = [MenuViewController new];
            vc.navigationItem.title = @"WeChat";
            [weakSelf.navigationController pushViewController:vc animated:YES];
        }];
        //菜单模型5
        FFDropDownMenuModel *menuModel5 = [FFDropDownMenuModel ff_DropDownMenuModelWithMenuItemTitle:@"Facebook" menuItemIconName:@"menu5"  menuBlock:^{
            MenuViewController *vc = [MenuViewController new];
            vc.navigationItem.title = @"Facebook";
            [weakSelf.navigationController pushViewController:vc animated:YES];
        }];
        
        NSArray *menuModelArr = @[menuModel0, menuModel1, menuModel2, menuModel3, menuModel4, menuModel5];
        return menuModelArr;
    }
    
    /** 显示下拉菜单 */
    - (void)showDropDownMenu {
        [self.dropdownMenu showMenu];
    }
    
    
    //=================================================================
    //                      FFDropDownMenuViewDelegate
    //=================================================================
    #pragma mark - FFDropDownMenuViewDelegate
    
    /** 可以在这个代理方法中稍微小修改cell的样式,比如是否需要下划线之类的 */
    /** you can modify menu cell style, Such as if should show underline */
    - (void)ffDropDownMenuView:(FFDropDownMenuView *)menuView WillAppearMenuCell:(FFDropDownMenuBasedCell *)menuCell index:(NSInteger)index {
        
        //若果自定义cell的样式,则在这里将  menuCell 转换成你自定义的cell
        FFDropDownMenuCell *cell = (FFDropDownMenuCell *)menuCell;
        
        //如果自定义cell,你可以在这里进行一些小修改,比如是否需要下划线之类的
        //最后一个菜单选项去掉下划线(FFDropDownMenuCell 内部已经做好处理,最后一个是没有下划线的,以下代码只是举个例子)
        if (menuView.menuModelsArray.count - 1 == index) {
            cell.separaterView.hidden = YES;
        }
        
        else {
            cell.separaterView.hidden = NO;
        }
        
    }
    
    @end
    
    

    相关文章

      网友评论

          本文标题:iOS --下拉菜单FFDropDownMenu的使用

          本文链接:https://www.haomeiwen.com/subject/tyrvvxtx.html