大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍IOS中MenuViewController如何实现弹出菜单效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
10年积累的成都网站制作、网站建设经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有秀洲免费网站建设让你可以放心的选择与我们合作。
效果图:
实现方式:将self.view当前页面缩小,在当前页的上面添加一个菜单的view,即在self.view.superview添加。
//显示 - (void) show:(UIView*)parent { parentView = parent; //先隐藏backView,table backView.alpha = 0; _table.alpha = 0; //移动table [_table setTransform:CGAffineTransformMakeTranslation(0, _table.frame.size.height)]; //父窗口添加本view,---这个会调用viewDidLoad [parentView.superview addSubview:self.view]; //添加动画,添加到父窗口中,使之从下移动上 [UIView animateWithDuration:0.3 animations:^{ //父窗口缩小 CGAffineTransform t = CGAffineTransformMakeScale(0.9, 0.9); [parentView setTransform:t]; //显示backview,table backView.alpha = 1; _table.alpha = 1; //移动table,CGAffineTransformIdentity还原原始坐标 [_table setTransform:CGAffineTransformIdentity]; } completion:^(BOOL finished) { }]; } //隐藏 - (void) hide { //添加动画,添加到父窗口中,使之从下移动上 [UIView animateWithDuration:0.3 animations:^{ //父窗口还原 CGAffineTransform t = CGAffineTransformIdentity; [parentView setTransform:t]; //显示backview,table backView.alpha = 0; _table.alpha = 0; //移动table [_table setTransform:CGAffineTransformMakeTranslation(0, _table.frame.size.height)]; } completion:^(BOOL finished) { [self.view removeFromSuperview]; }]; } - (void)viewDidLoad { [super viewDidLoad]; self.view.backgroundColor = [UIColor clearColor]; //背影黑罩 backView = [[UIView alloc]initWithFrame:self.view.bounds]; backView.backgroundColor = [UIColor colorWithRed:0 green:0 blue:0 alpha:0.3]; [self.view addSubview:backView]; //算出table的CGRect CGRect rect = self.view.bounds; int height = _titleArray.count * 44; rect.origin.y = rect.size.height - height; rect.size.height = height; _table = [[UITableView alloc]initWithFrame:rect]; _table.delegate = self; _table.dataSource = self; [self.view addSubview:_table]; }
这个菜单你可以任意自定义,我这里是一个tableView,你可以写一些有图和文字的添加上去。只需要把源代码稍改,就ok!
以上是“IOS中MenuViewController如何实现弹出菜单效果”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!