IOS项目之弹出动画一
小区宝首页导航栏左边有一个物业按钮,点击时会出现一个视图动画,之前用的是一个POP第三方,想着几个POP动画就要引用一堆的第三方有点麻烦,就试着自己写了一下,功能实现了,下一步就是优化将其封装一下。下面我用DatePicker做的主要是想着再做出点击弹出按钮在底部出现DatePicker选择器。
#import "ViewController.h" #import "PageViewController.h" #import "myView.h" @interface ViewController () @property(nonatomic,strong) myView *myview; @property(nonatomic,strong) UIDatePicker *dataPicker; @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // self.navigationItem.rightBarButtonItem=[[UIBarButtonItem alloc]initWithTitle:@"预览" style:UIBarButtonItemStyleDone target:self action:@selector(rightClick)]; self.navigationItem.leftBarButtonItem=[[UIBarButtonItem alloc]initWithTitle:@"弹出" style:UIBarButtonItemStyleDone target:self action:@selector(leftClick)]; //遮罩层 _myview=[[myView alloc]initWithFrame:CGRectMake(,-self.view.bounds.size.height, self.view.bounds.size.width, self.view.bounds.size.height)]; _myview.backgroundColor = [UIColor colorWithWhite:0.5 alpha:0.1f]; //为遮罩层添加手势识别 可以点击遮罩层空白处隐藏视图 UIGestureRecognizer *tapgesture=[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tapclick)]; _myview.userInteractionEnabled=YES; [_myview addGestureRecognizer:tapgesture]; //设置DatePicker _dataPicker=[[UIDatePicker alloc]init]; _dataPicker.frame=CGRectMake(, , , ); // datepicker.backgroundColor=[UIColor grayColor]; [_myview addSubview:_dataPicker]; //设置DatePicker上面的视图 UIView *view=[[UIView alloc]initWithFrame:CGRectMake(, , self.view.bounds.size.width, )]; view.backgroundColor=[UIColor blueColor]; UIButton *btnright=[UIButton buttonWithType:UIButtonTypeSystem]; [btnright setTitle:@"确定" forState:UIControlStateNormal]; [btnright addTarget:self action:@selector(btnrightClick:) forControlEvents:UIControlEventTouchUpInside]; btnright.frame=CGRectMake(self.view.bounds.size.width-, , , ); [view addSubview:btnright]; [_myview addSubview:view]; [self.view addSubview:_myview]; } -(void)leftClick { //下落动画 时间短一些 [UIView beginAnimations:@"text" context:nil]; [UIView setAnimationDelay:]; [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut]; [UIView setAnimationDuration:0.3]; _myview.frame=CGRectMake(,, self.view.bounds.size.width, self.view.bounds.size.height); [UIView commitAnimations]; //恢复动画 时间长一些 [UIView beginAnimations:@"text" context:nil]; [UIView setAnimationDelay:]; [UIView setAnimationCurve:UIViewAnimationCurveEaseIn]; [UIView setAnimationDuration:0.5]; _myview.frame=CGRectMake(,, self.view.bounds.size.width, self.view.bounds.size.height); [UIView commitAnimations]; } -(void)tapclick { [UIView beginAnimations:@"text" context:nil]; [UIView setAnimationDelay:]; [UIView setAnimationCurve:UIViewAnimationCurveEaseOut]; [UIView setAnimationDuration:0.3]; _myview.frame=CGRectMake(, -self.view.bounds.size.height, self.view.bounds.size.width, self.view.bounds.size.height); [UIView commitAnimations]; } -(void)btnrightClick:(id)sender { NSLog(@"%@",_dataPicker.date); [self tapclick]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } @end
我们稍加改动就可以变成从底部弹出视图 这样就完成了闪购模块 宝贝详情中的选择规格的功能
#import "ViewController.h" #import "PageViewController.h" #import "myView.h" @interface ViewController () @property(nonatomic,strong) myView *myview; @property(nonatomic,strong) UIDatePicker *dataPicker; @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // self.navigationItem.rightBarButtonItem=[[UIBarButtonItem alloc]initWithTitle:@"预览" style:UIBarButtonItemStyleDone target:self action:@selector(rightClick)]; self.navigationItem.leftBarButtonItem=[[UIBarButtonItem alloc]initWithTitle:@"弹出" style:UIBarButtonItemStyleDone target:self action:@selector(leftClick)]; //遮罩层 _myview=[[myView alloc]initWithFrame:CGRectMake(,self.view.bounds.size.height, self.view.bounds.size.width, self.view.bounds.size.height)]; _myview.backgroundColor = [UIColor colorWithWhite:0.5 alpha:0.1f]; //为遮罩层添加手势识别 可以点击遮罩层空白处隐藏视图 UIGestureRecognizer *tapgesture=[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tapclick)]; _myview.userInteractionEnabled=YES; [_myview addGestureRecognizer:tapgesture]; //设置DatePicker _dataPicker=[[UIDatePicker alloc]init]; _dataPicker.frame=CGRectMake(, self.view.bounds.size.height-, , ); // datepicker.backgroundColor=[UIColor grayColor]; [_myview addSubview:_dataPicker]; //设置DatePicker上面的视图 UIView *view=[[UIView alloc]initWithFrame:CGRectMake(, self.view.bounds.size.height-, self.view.bounds.size.width, )]; view.backgroundColor=[UIColor blueColor]; UIButton *btnright=[UIButton buttonWithType:UIButtonTypeSystem]; [btnright setTitle:@"确定" forState:UIControlStateNormal]; [btnright addTarget:self action:@selector(btnrightClick:) forControlEvents:UIControlEventTouchUpInside]; btnright.frame=CGRectMake(self.view.bounds.size.width-, , , ); [view addSubview:btnright]; [_myview addSubview:view]; [self.view addSubview:_myview]; } -(void)leftClick { //下落动画 时间短一些 [UIView beginAnimations:@"text" context:nil]; [UIView setAnimationDelay:]; [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut]; [UIView setAnimationDuration:0.3]; _myview.frame=CGRectMake(,, self.view.bounds.size.width, self.view.bounds.size.height); [UIView commitAnimations]; // //恢复动画 时间长一些 // [UIView beginAnimations:@"text" context:nil]; // [UIView setAnimationDelay:0]; // [UIView setAnimationCurve:UIViewAnimationCurveEaseIn]; // [UIView setAnimationDuration:0.5]; // _myview.frame=CGRectMake(0,0, self.view.bounds.size.width, self.view.bounds.size.height); // [UIView commitAnimations]; } -(void)tapclick { [UIView beginAnimations:@"text" context:nil]; [UIView setAnimationDelay:]; [UIView setAnimationCurve:UIViewAnimationCurveEaseOut]; [UIView setAnimationDuration:0.3]; _myview.frame=CGRectMake(, self.view.bounds.size.height, self.view.bounds.size.width, self.view.bounds.size.height); [UIView commitAnimations]; } -(void)btnrightClick:(id)sender { NSLog(@"%@",_dataPicker.date); [self tapclick]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } @end
上面的导航控制器并未被遮罩 ,这样添加时才能使导航控制器遮罩[[UIApplication sharedApplication].keyWindow addSubview:_myview];
// // ViewController.m // PhotoBrower // // Created by City--Online on 15/6/16. // Copyright (c) 2015年 City--Online. All rights reserved. // #define WIDTH self.view.bounds.size.width #define HEIGHT self.view.bounds.size.height #define SCREENWIDTH [UIScreen mainScreen].bounds.size.width #define SCREENHEIGHT [UIScreen mainScreen].bounds.size.height #import "ViewController.h" #import "PageViewController.h" #import "ImageViewController.h" #import "myView.h" @interface ViewController () @property(nonatomic,strong) myView *myview; @property(nonatomic,strong) UIDatePicker *dataPicker; @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // self.navigationItem.rightBarButtonItem=[[UIBarButtonItem alloc]initWithTitle:@"预览" style:UIBarButtonItemStyleDone target:self action:@selector(rightClick)]; self.navigationItem.leftBarButtonItem=[[UIBarButtonItem alloc]initWithTitle:@"弹出" style:UIBarButtonItemStyleDone target:self action:@selector(leftClick)]; //遮罩层 _myview=[[myView alloc]initWithFrame:CGRectMake(,SCREENHEIGHT, WIDTH, SCREENHEIGHT)]; _myview.backgroundColor = [UIColor colorWithWhite:0.5 alpha:0.1f]; //为遮罩层添加手势识别 可以点击遮罩层空白处隐藏视图 UIGestureRecognizer *tapgesture=[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tapclick)]; _myview.userInteractionEnabled=YES; [_myview addGestureRecognizer:tapgesture]; //设置DatePicker _dataPicker=[[UIDatePicker alloc]init]; _dataPicker.frame=CGRectMake(, SCREENHEIGHT-, , ); // datepicker.backgroundColor=[UIColor grayColor]; [_myview addSubview:_dataPicker]; //设置DatePicker上面的视图 UIView *view=[[UIView alloc]initWithFrame:CGRectMake(, SCREENHEIGHT-, WIDTH, )]; view.backgroundColor=[UIColor blueColor]; UIButton *btnright=[UIButton buttonWithType:UIButtonTypeSystem]; [btnright setTitle:@"确定" forState:UIControlStateNormal]; [btnright addTarget:self action:@selector(btnrightClick:) forControlEvents:UIControlEventTouchUpInside]; btnright.frame=CGRectMake(self.view.bounds.size.width-, , , ); [view addSubview:btnright]; [_myview addSubview:view]; [[UIApplication sharedApplication].keyWindow addSubview:_myview]; // [self.view addSubview:_myview]; // [[UIApplication sharedApplication].delegate.window addSubview:_myview]; } -(void)leftClick { //下落动画 时间短一些 [UIView beginAnimations:@"text" context:nil]; [UIView setAnimationDelay:]; [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut]; [UIView setAnimationDuration:0.3]; _myview.frame=CGRectMake(,, self.view.bounds.size.width, SCREENHEIGHT); [UIView commitAnimations]; //恢复动画 时间长一些 // [UIView beginAnimations:@"text" context:nil]; // [UIView setAnimationDelay:0]; // [UIView setAnimationCurve:UIViewAnimationCurveEaseIn]; // [UIView setAnimationDuration:0.5]; // _myview.frame=CGRectMake(0,0, self.view.bounds.size.width, self.view.bounds.size.height); // [UIView commitAnimations]; // PageViewController *pageVc=[[PageViewController alloc]init]; // pageVc.hidesBottomBarWhenPushed=YES; //// [self presentViewController:pageVc animated:YES completion:nil]; // [self.navigationController pushViewController:pageVc animated:YES]; } -(void)tapclick { [UIView beginAnimations:@"text" context:nil]; [UIView setAnimationDelay:]; [UIView setAnimationCurve:UIViewAnimationCurveEaseOut]; [UIView setAnimationDuration:0.3]; _myview.frame=CGRectMake(, SCREENHEIGHT, self.view.bounds.size.width, SCREENHEIGHT); [UIView commitAnimations]; } -(void)btnrightClick:(id)sender { NSLog(@"%@",_dataPicker.date); [self tapclick]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } @end
IOS项目之弹出动画一的更多相关文章
- IOS项目之弹出动画终结篇
在之前写过IOS项目之弹出动画一.IOS项目之弹出动画二.IOS项目之弹出动画三,今天来一个终极封装已经上传到Github上弹出动画总结篇UIPopoverTableView. UIPopoverTa ...
- IOS项目之弹出动画二
在IOS项目之弹出动画一中只是实现也功能,并没有体现面向对象的思想 ,今天就试着把它封装了一下,弹出视图的内容可以根据自定义,此处只是用UIDatePicker来演示 我把它传到了GitHub上 ...
- IOS项目之弹出动画三
前面写了弹出动画两个,今天做商城时又用到了,看着这个用着蛮普遍的,所以记了下来 // // mallMoreView.h // XQB // // Created by City--Online on ...
- ios等待ualertview弹出动画完成后再跳转至其他页面
[self performSelector:@selector(popView:) withObject:nil afterDelay:2.0];
- 阶段一:为View设置阴影和弹出动画(天气应用)
“阶段一”是指我第一次系统地学习Android开发.这主要是对我的学习过程作个记录. 上一篇阶段一:通过网络请求,获得并解析JSON数据(天气应用)完成了应用的核心功能,接下来就要对它进行优化.今天我 ...
- mac关闭渐隐和弹出动画效果
苹果系统应用程序的窗口和对话框每次使用的时候都有华丽的特效,但是如果你感觉这种特效显得有点慢(MacGG闲的蛋疼),那该如何取消掉他呢? 方法很简单,打开"终端"(Finder-& ...
- 清除ios系统alert弹出框的域名
清除ios系统alert弹出框的域名 <script> window.alert = function(name) { var iframe = document.createElemen ...
- iOS 15 无法弹出授权弹框之解决方案---Your app uses the AppTrackingTransparency framework, but we are unable to locate the App Tracking Transparency permission request when reviewed on iOS 15.0
2021年9月30日下午:我正愉快的期盼着即将到来的国庆假期,时不时刷新下appstoreconnect的网址,28号就提上去的包,今天还在审核中....由于这个版本刚升级的xcode系统和新出的iO ...
- WPF制作子窗体的弹出动画效果
创建一个WPF应用程序WpfApplication1,新建个窗体DialogWin <Windowx:Class="WpfApplication1.DialogWin" xm ...
随机推荐
- Postgresql 锁查看
之前版本 PostgreSQL 的 pg_stat_activity 视图的 waiting 字段判断会话是否等待锁资源(通俗地讲, waiting 值为true表示申请不到锁资源处于等待状态),但是 ...
- WebRequest请求被中止: 未能创建 SSL/TLS 安全通道
使用System.Net.WebRequest.Create(url)抓取某网站信息时 ,出现“未能创建 SSL/TLS 安全通道”此条异常信息 解决方案 引用:using System.Net; 在 ...
- ruby,gem,rails之间的关系
Q:ruby,gem,rails之间的关系? 简单点说:Ruby是一种脚本语言,Gem是基于Ruby的一些开发工具包,Rails也算是一组Gem,专门用来做网站的.不同的Gem可能会依赖不同的Ruby ...
- eclipse的使用和断点调试
断点: 快捷键 f5: step into f6: step over 跳过,跳到下一行 f7:step return 从某个方法里跳回 跳出 drop to frame: 跳到当前方法的第一行 re ...
- 数据库的完整性约束(ForeignKey ,Unique)
文字转自于 海燕.博客 一.介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性主要分为: PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录 ...
- POST与GET请求的区别
https://www.cnblogs.com/logsharing/p/8448446.html 返回主页 在途中# 博客园首页新随笔联系订阅管理 随笔 - 33 文章 - 5 评论 - 40 GE ...
- 程序媛计划——python初级class5~13
列表和元组都是可迭代对象(可以用于for in) 列表 [] #添加列表元素: list.append(argu) #修改列表: list[2] = 2017 #删除列表元素 Del list[2] ...
- SpringBoot入门之事件监听
spring boot在启动过程中增加事件监听机制,为用户功能拓展提供极大的便利,sptingboot支持的事件类型有以下五种: ApplicationStartingEvent Applicatio ...
- webpack快速入门——实战技巧:优雅打包第三方类库
下面说两种方法: 一. 1.引入jQuery,首先安装: cnpm install --save jquery 2.安装好后,在我们的entry.js中引入: import $ from 'jquer ...
- QT for Android记录
1.<Qt on Android核心编程> blog: http://blog.csdn.net/foruok/article/details/38510195