文档章节

键盘弹出和消失View的上下移动效果

YunHe_Lee
 YunHe_Lee
发布于 2015/06/17 11:45
字数 301
阅读 2
收藏 0

#pragma mark 设置textView并在设置view随键盘的移动而移动

-(void)setTextView

{

    [self.myTextView.layer setCornerRadius:5.0];

    //监听键盘弹出

    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidShow:) name:UIKeyboardWillShowNotification object:nil];

    //监听键盘消失

    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidHidden:) name:UIKeyboardWillHideNotification object:nil];

    UIToolbar * topView = [[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 45)];

    [topView setBarStyle:UIBarStyleBlackTranslucent];

    //定义两个flexibleSpacebutton,放在toolBar上,这样完成按钮就会在最右边

    UIBarButtonItem * button1 =[[UIBarButtonItem  alloc]initWithBarButtonSystemItem:                                        UIBarButtonSystemItemFlexibleSpace target:self action:nil];

    

    UIBarButtonItem * button2 = [[UIBarButtonItem  alloc]initWithBarButtonSystemItem:                                        UIBarButtonSystemItemFlexibleSpace target:self action:nil];

    //定义完成按钮

    UIBarButtonItem * doneButton = [[UIBarButtonItem alloc]initWithTitle:@"完成" style:UIBarButtonItemStyleDone  target:self action:@selector(resignKeyboard)];

    //toolBar上加上这些按钮

    NSArray * buttonsArray = [NSArray arrayWithObjects:button1,button2,doneButton,nil];

    [topView setItems:buttonsArray];

    [self.myTextView setInputAccessoryView:topView];

}




#pragma mark 隐藏键盘

-(void)resignKeyboard

{   //取消键盘为第一相应者

    [self.myTextView resignFirstResponder];

}

#pragma mark 键盘弹出View向上移动

-(void)keyboardDidShow:(NSNotification *)notification

{

    

    NSDictionary *userInfo = [notification userInfo];

    NSValue *aValue = [userInfo objectForKey:UIKeyboardFrameEndUserInfoKey];

    CGRect keyboardRect = [aValue CGRectValue];

    int height = keyboardRect.size.height; //获取键盘高度

    

    CGContextRef context = UIGraphicsGetCurrentContext();

    //开始播放动画

    [UIView beginAnimations:nil context:context];

    [UIView setAnimationCurve:UIViewAnimationCurveEaseOut];

    [UIView setAnimationDuration:0.3];

    [self.myView setFrame:CGRectMake(0,-height, 320, 480)];

    

    [UIView commitAnimations];

    

}



#pragma mark 键盘消失View向下移动

-(void)keyboardDidHidden:(NSNotification *)notification

{

    

    CGContextRef context = UIGraphicsGetCurrentContext();

    //开始播放动画

    [UIView beginAnimations:nil context:context];

    [UIView setAnimationCurve:UIViewAnimationCurveEaseOut];

    [UIView setAnimationDuration:0.3];

    [self.myView setFrame:CGRectMake(0,0, 320, 480)];

    

    [UIView commitAnimations];

    

    

}

© 著作权归作者所有

共有 人打赏支持
YunHe_Lee
粉丝 0
博文 8
码字总数 4263
作品 0
朝阳
私信 提问
iOS学习4:UITextView的用法及技巧(ios7下光标bug解决方案)

一、新建一个textView //初始化UITextView *textView = [[[UITextView alloc] init] autorelease]; //设置代理 需在interface中声明UITextViewDelegatetextView.delegate = self; //字体大小......

芳仔小脚丫
2013/06/24
0
11
问题:键盘缩回动画和UIAlertView弹出动画冲突

问题描述: 键盘弹出,光标在输入框中输入,没有结束页面的输入状况时,点击按钮,弹出提示框,键盘会在弹出提示框之前消失,但是点击"取消"或者"确定"之后,提示框消失,键盘再次弹出.虽然我在提示框...

刘学良
2016/11/21
22
0
IOS博客项目搭建-15-发微博-自定义键盘上的Toolbar

自定义发布微博界面的工具栏,下图红框中的Toolbar。 工具条是一个整体,可以封装一个类文件,来进行处理相关的操作。 一、先创建一个工具条view继承UIView IWComposeToolbar.m 然后在发微博...

Corwien
2016/05/15
122
0
系统API:UIView阻尼动画

Spring Animation 是一种特殊的动画曲线,自从 iOS 7 开始被广泛应用在系统动画中。 下图中演示的系统自带的动画效果,都使用了 Spring Animation: 事实上,从 iOS 7 起几乎所有的系统动画都...

sea_god
2016/03/03
80
0
Android关于QQ登陆页的两个问题

我想做一个类似于这样的登陆页。已经做出来了,但是又两个bug 先说一下QQ的登陆页的效果 如图1、2、3 1为默认页情况 2为点击“下三角” 显示 用户列表时的情况 3为点击用户名或密码框时弹出软...

wokenshin
2014/09/24
317
0

没有更多内容

加载失败,请刷新页面

加载更多

Web安全之XSS攻击与防御小结

Web安全之XSS攻防 1. XSS的定义 跨站脚本攻击(Cross Site Scripting),缩写为XSS。恶意攻击者往Web页面里插入恶意Script代码,当用户浏览该页之时,嵌入其中Web里面的Script代码会被执行,从...

前端小攻略
19分钟前
1
0
JavaScript中的继承及实现代码

JS虽然不像是JAVA那种强类型的语言,但也有着与JAVA类型的继承属性,那么JS中的继承是如何实现的呢? 一、构造函数继承 在构造函数中,同样属于两个新创建的函数,也是不相等的 function Fn...

peakedness丶
22分钟前
1
0
记一次面试最常见的10个Redis"刁难"问题

导读:在程序员面试过程中Redis相关的知识是常被问到的话题。作为一名在互联网技术行业打击过成百上千名的资深技术面试官,本文作者总结了面试过程中经常问到的问题。十分值得一读。 Redis在...

小刀爱编程
35分钟前
13
0
TiDB Lab 诞生记 | TiDB Hackathon 优秀项目分享

本文由红凤凰粉凤凰粉红凤凰队的成员主笔,他们的项目 TiDB Lab 在本届 TiDB Hackathon 2018 中获得了二等奖。TiDB Lab 为 TiDB 培训体系增加了一个可以动态观测 TiDB / TiKV / PD 细节的动画...

TiDB
48分钟前
4
0
当区块链遇到零知识证明

本文由云+社区发表 当区块链遇到零知识证明 什么是零知识证明 零知识证明的官方定义是能够在不向验证者任何有用的信息的情况下,使验证者相信某个论断是正确的。这个定义有点抽象,下面笔者举...

腾讯云加社区
57分钟前
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部