iOS 导航栏下拉菜单框

具体叫什么名称来着给忘了,在这里使用的是第三方的。应为我是用来做导航栏右侧按钮的下拉菜单按钮,多以就这么叫了。
先看一下效果图:
这里写图片描述

既然是第三方,首先是要导入库

pod 'YCXMenu', '~> 0.0.3'

关联头文件

#import "YCXMenuItem.h"
#import "YCXMenu.h"

设置一下导航栏右侧按钮,然后设置响应方法。

-(void)addMenuBtn
{
    self.navigationItem.rightBarButtonItem= [self createRightBarBtnItem:@"icon_menu.png" hightedImage:@"icon_menu_h.png" action:@selector(clickMenu:)];

}

在button的方法中设置响应事件。
菜单栏两个按钮的名称,前边的图片

- (void)showMenu:(UIButton *)btn
{
    WS(ws)
    [YCXMenu showMenuInView:self.view fromRect:CGRectMake(btn.frame.origin.x,_isNavgationBarHidden ? 34:-30, btn.frame.size.width, btn.frame.size.height) menuItems:_menuArray selected:^(NSInteger index, YCXMenuItem *item) {
        switch (index) {
            case 0:
            {
                //
                [ws jumpToNotification];
            }
                break;

            case 1:
            {
                NewSearchViewController * searchVC = [[NewSearchViewController alloc] init];
                searchVC.hidesBottomBarWhenPushed = YES;
                //              searchVC.searchStr = self.searchString;
                [self.navigationController pushViewController:searchVC animated:YES];

            }
                break;
            default:
                break;
        }
    }];
}

-(void)clickMenu:(id)sender
{
    UIButton *btn = (UIButton *)sender;
    //set title
    if (_menuArray) {
        if ([YCXMenu isShow]) {
            [YCXMenu dismissMenu];
        }else{
            [self showMenu:btn];
        }
    }else{
        _menuArray= @[[YCXMenuItem menuItem:@"消息"
                                      image:GetImage(@"icon_top_message")
                                        tag:100
                                   userInfo:nil],
                      [YCXMenuItem menuItem:@"搜索"
                                      image:GetImage(@"icon_top_search")
                                        tag:102
                                   userInfo:nil],
                      ];
        [self showMenu:btn];
    }
}

默认情况下背景色是黑色、字体是白色,如果想修改默认的话在第三方库的
YCXMen.h 文件中
第19行是默认背景色的宏,20行是选中时背景色的宏。
第470行是设置字体颜色的。
第300行是修改透明度的。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值