前面iOS学习之UIPickerView控件的简单使用 用到的UIPickerView弹出来是通过
textField.inputView = selectPicker;   textField.inputAccessoryView = doneToolbar; 这中方法来做的。如果UIPickerView或UIDatePicker控件通过其他按钮或事件激活的时候怎么能像系统那样弹出来呢?为了实现这个需求,就要用到动画效果了。

1、新建一个Single View App项目,在.xib文件中添加控件如下:


两个button,一个UIDatePicker。

2、创建xib和ViewController的连接

按住Control键创建三个控件对于的映射。
创建后viewController.h代码如下
  1. #import <UIKit/UIKit.h>
  2. @interface ViewController : UIViewController
  3. @property (retain, nonatomic) IBOutlet UIDatePicker *pickerView;
  4. - (IBAction)popView:(id)sender;
  5. - (IBAction)inView:(id)sender;
  6. @property  (nonatomic, retain) NSString *string;
  7. @end

3、隐藏pickerView

  1. - (void)viewDidLoad
  2. {
  3. [super viewDidLoad];
  4. self.pickerView.frame = CGRectMake(0, 480, 320, 260);
  5. }

把pickerView 放到屏幕以为下面。

4、弹出和弹回pickerView

在pickerView弹出来或回去的时候,设置动画
  1. - (IBAction)popView:(id)sender {
  2. CGContextRef context = UIGraphicsGetCurrentContext();
  3. [UIView beginAnimations:nil context:context];
  4. [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];
  5. [UIView setAnimationDuration:0.6];//动画时间长度,单位秒,浮点数
  6. [self.view exchangeSubviewAtIndex:0 withSubviewAtIndex:1];
  7. self.pickerView.frame = CGRectMake(0, 245, 320, 260);
  8. [UIView setAnimationDelegate:self];
  9. // 动画完毕后调用animationFinished
  10. [UIView setAnimationDidStopSelector:@selector(animationFinished)];
  11. [UIView commitAnimations];
  12. }
  13. - (IBAction)inView:(id)sender {
  14. CGContextRef context = UIGraphicsGetCurrentContext();
  15. [UIView beginAnimations:nil context:context];
  16. [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];
  17. [UIView setAnimationDuration:0.6];//动画时间长度,单位秒,浮点数
  18. self.pickerView.frame = CGRectMake(0, 480, 320, 260);
  19. [UIView setAnimationDelegate:self];
  20. // 动画完毕后调用animationFinished
  21. [UIView setAnimationDidStopSelector:@selector(animationFinished)];
  22. [UIView commitAnimations];
  23. }
  24. -(void)animationFinished{
  25. NSLog(@"动画结束!");
  26. }

动画结束后回调动画结束的函数。

运行,弹出
  
第一个图片是弹出来到一半,第二个图片弹出全部。

4、代码块的方法做动画弹出pickerView

单独写个方法
  1. - (void)ViewAnimation:(UIView*)view willHidden:(BOOL)hidden {
  2. [UIView animateWithDuration:0.3 animations:^{
  3. if (hidden) {
  4. view.frame = CGRectMake(0, 480, 320, 260);
  5. } else {
  6. [view setHidden:hidden];
  7. view.frame = CGRectMake(0, 245, 320, 260);
  8. }
  9. } completion:^(BOOL finished) {
  10. [view setHidden:hidden];
  11. }];
  12. }

5、在Action中调用

  1. - (IBAction)popView:(id)sender {
  2. [self ViewAnimation:self.pickerView willHidden:NO];
  3. }
  4. - (IBAction)inView:(id)sender {
  5. [self ViewAnimation:self.pickerView willHidden:YES];
  6. }

这个方法更简单实用


PS:以上的方法可以用在TableViewCell点击cell时弹回pickerView等需求.

著作权声明:本文由http://blog.csdn.net/totogo2010/原创,欢迎转载分享。请尊重作者劳动,转载时保留该声明和作者博客链接,谢谢

iOS学习之自定义弹出UIPickerView或UIDatePicker(动画效果)的更多相关文章

  1. iOS开发之自定义弹出的键盘

    self.inputField.inputView = myView 按文本框弹出的键盘不再是普通文字输入键盘,而是我们设置的myView.一般把这个方法写在viewDiLoad方法中. 也可以在键盘 ...

  2. jquery 显示弹出层可利用动画效果

    1 show()方法和hide()方法 $("selector").show()  从display:none还原元素默认或已设置的display属性$("selecto ...

  3. .NET MVC 学习笔记(四)— 基于Bootstarp自定义弹出框

    .NET MVC 学习笔记(四)—— 基于Bootstarp自定义弹出框 转载自:https://www.cnblogs.com/nele/p/5327380.html (function ($) { ...

  4. iOS学习笔记-自定义过渡动画

    代码地址如下:http://www.demodashi.com/demo/11678.html 这篇笔记翻译自raywenderlick网站的过渡动画的一篇文章,原文用的swift,由于考虑到swif ...

  5. js自定义弹出框

    js自定义弹出框: 代码如下 <html> <head><title>自定义弹出对话框</title> <style type ="te ...

  6. android自定义弹出框样式实现

    前言: 做项目时,感觉Android自带的弹出框样式比较丑,很多应用都是自己做的弹出框,这里也试着自己做了一个. 废话不说先上图片: 实现机制 1.先自定义一个弹出框的样式 2.自己实现CustomD ...

  7. CSS3/jQuery自定义弹出窗口

    简单演示一下,精简了演示效果和css样式文件,更利于在项目中的实际应用 引入style.css   index.js <!DOCTYPE HTML PUBLIC "-//W3C//DT ...

  8. react native仿微信性别选择-自定义弹出框

    简述 要实现微信性别选择需要使用两部分的技术: 第一.是自定义弹出框: 第二.单选框控件使用: 效果 实现 一.配置弹出框 弹出框用的是:react-native-popup-dialog(Git地址 ...

  9. 读《深入理解Windows Phone 8.1 UI控件编程》1.4.3 框架的应用示例:自定义弹出窗口有感

    前些天买了园子里林政老师的两本 WP8.1 的书籍.毕竟想要学得深入的话,还是得弄本书跟着前辈走的. 今天读到 1.4.3 节——框架的应用示例:自定义弹出窗口这一小节.总的来说,就是弄一个像 Mes ...

随机推荐

  1. 20179223《Linux内核原理与分析》第九周学习笔记

    视频学习 进程调度与进程调度的时机分析 不同类型的进程有不同的调度需求 第一种分类: --I/O-bound:1.频繁的进行I/O:2.通常会花费很多时间等待I/O操作的完成 --CPU-bound: ...

  2. .NET 使用 XPath 来读写 XML 文件

    XPath 是 XML 路径语言(XML Path Language),用来确定XML文档中某部分位置的语言.无论是什么语言什么框架,几乎都可以使用 XPath 来高效查询 XML 文件. 本文将介绍 ...

  3. Visual studio环境中的一些快捷键

    VS的快键键 F12(转到定义),那怎么转回定义呢? 转回应该是Ctrl+Shift+8 自动排版:ctrl+E+D

  4. web 优化原则

    1. 减少http 请求   2. 使用CDN   3. 添加expires 头   4. gzip 压缩   5. 样式表放在头部   6. 脚本放底部   7. 避免css 表达式   8. 使用 ...

  5. C#机器学习插件 ---- AForge.NET

    目录 简介 主要架构 特点 学习之旅 简介 AForge.NET是一个专门为开发者和研究者基于C#框架设计的,这个框架提供了不同的类库和关于类库的资源,还有很多应用程序例子,包括计算机视觉与人工智能, ...

  6. css之选择器的认识

    css中有大量的选择器,主要用来精准的找到代码中的某一段或者某一个段落,并对其样式进行选择和改变. 首先介绍的第一个选择器是: 1,基本选择器: 直接找到标签对其进行样式修正,不论标签藏多深,或者数量 ...

  7. Eclipse的Java开发中jar导入后无法使用包内class的解决方案

    请注意, 本方法只对于自己的包有效, 如果你的类内部互相调用, 此方法会失效, 需要每个类文件都进行一次CTRL+SHIFT+O进行包的导入. 如上图的一个结构, algs4.jar和stdlib.j ...

  8. 在ubuntu下,进行php7源码安装

    作为一名php的攻城师,如果没有玩php源码安装是说不过去的.我们知道php之所以这么流行,跟它的开源文化和lamp配套有很大关系.由于PHP7废弃了很多功能,所以一些依赖这些功能的程序可能无法运行, ...

  9. Django 组件-用户认证

    用户认证 auth模块 from django.contrib import auth 1.1 .authenticate()  提供了用户认证,即验证用户名以及密码是否正确,一般需要username ...

  10. Warning: require(D:\wamp\www\glink-smart\bootstrap/../vendor/autoload.php): failed to open stream: No such file or directory in D:\wamp\www\glink-smart\bootstrap\autoload.php on line 1

    Laravel访问出错错误信息:`Warning: require(/vendor/autoload.php): failed to open stream: No such file or dire ...