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 ...
随机推荐
- LeetCode148:Sort List
题目: Sort a linked list in O(n log n) time using constant space complexity. 解题思路: 根据题目要求,可知只能用归并排序,其他 ...
- Index--过滤索引和参数化
--============================================ 领导指点我去给某台数据库调优下,结果屁颠屁颠地干完,还自我感觉良好,刚刚别人博客时,才发现自己踩坑了!! ...
- LinkServer--在Job中使用Linkserver注意事项
如果要使用job来调用link server的话,不能使用作业步骤属性高级选项中”作为以下用户运行“来以本地登录用户模拟远程用户访问远程服务器.会报”无法建立安全上下文“的错误. 将Job中代码封装到 ...
- C#在dataGridView中遍历,寻找相同的数据并定位
1. C#在dataGridView中遍历,寻找相同的数据并定位 [c-sharp] view plain copy int row = dataGridView1.Rows.Count;// ...
- 如何使用socket进行java网络编程(二)
通过在如何使用socket进行java网络编程(一)中程序的编写,可以总结出一些常用的java socket编程的范例来. ServerSocket server = new ServerSocket ...
- Spring 开发第一步(四)Spring与JDBC事务
Spring使用各种不同的TransactionManager来管理各种不同数据源事务底层(比如jdbc数据源.hibernate数据源.JPA数据源等等).在此基础上使用各种对应的Template来 ...
- git生成Key操作保存到GITHUB中
https://blog.csdn.net/sinat_23880167/article/details/78502528 1. 在git中通过命令: $ ssh-keygen Generating ...
- [USACO06DEC] 牛奶模式Milk Patterns
题目链接:戳我 我们知道后缀数组的h数组记录的是后缀i和后缀i-1的最长公共前缀长度,后缀的前缀其实就是子串. 因为是可以重复出现的子串,所以我们只要计算哪些h数组的长度大于等于x即可.这一步操作我们 ...
- 字符串(tjoi2016,heoi2016,bzoj4556)(sam(后缀自动机)+线段树合并+倍增+二分答案)
佳媛姐姐过生日的时候,她的小伙伴从某东上买了一个生日礼物.生日礼物放在一个神奇的箱子中.箱子外边写了 一个长为\(n\)的字符串\(s\),和\(m\)个问题.佳媛姐姐必须正确回答这\(m\)个问题, ...
- *p++与(*p)++与*(p++)------自增运算符常见误区
自增运算符(++) 自增\自减运算符分为前缀形(++a)和后缀形(a++),这里重点分析自增 大部分人对前缀和后缀的理解一般是,前缀形式是先++再使用(先变后用),后缀形式是先使用再++(先用后变) ...