Day18 - 界面动态布局

在项目中可能存在很多的地方需要用户输入信息,这个时候一个屏幕显示不完,或者当键盘弹起的时候就会造成不好的用户体验,比如我自己都不知道我输入了什么……
本实例最终效果:

键盘弹起效果

1、UI布局

其他的布局都比较简单,这里我们只需要说一下底部的ToolBar布局

  • 1.1 拖入一个toolBarView


    第一步

    <br />

  • 1.2设置约束


    设置约束

    <br />

  • 1.3 添加bar button


    添加bar button
重复上面 1.3步骤,知道添加五个button

<br />

  • 1.4 设置第四个和第五个的距离


    设置距离

<br />

  • 1.5 点击第一个Item

设置图片

重复上面的步骤设置好每个item

<br />

2、代码实现

实现原理:监听一下键盘弹出和消失,得到键盘的高度,同时改变约束NSLayoutConstraint或者transform,我们这里改变的是约束,
这里我们还需要注意的就是如果使用约束动画,那么一定要写对象点layoutIfNeeded(),强制刷新界面

2.1 监听通知:键盘通知包括

/*
        UIKeyboardWillHideNotification          将要隐藏
        UIKeyboardWillShowNotification          将要显示
        UIKeyboardDidChangeFrameNotification    已经修改frame
        UIKeyboardWillChangeFrameNotification   将要修改frame
        UIKeyboardDidHideNotification           已经隐藏
        UIKeyboardDidShowNotification           已经显示
         */
        
        /*
         UIKeyboardFrameBeginUserInfoKey        Rect
         UIKeyboardFrameEndUserInfoKey          Rect
         UIKeyboardAnimationDurationUserInfoKey 动画时长
         UIKeyboardAnimationCurveUserInfoKey    动画Options
         UIKeyboardIsLocalUserInfoKey           NSNumber of BOOL
         */

其余代码:

//
//  ViewController.swift
//  ListenKeyboard
//
//  Created by ios on 16/9/24.
//  Copyright © 2016年 ios. All rights reserved.
//

import UIKit

class ViewController: UIViewController,UITextViewDelegate {

    @IBOutlet weak var toolBarConstraints: NSLayoutConstraint!
    
    @IBOutlet weak var toobar: UIToolbar!
    @IBOutlet weak var textView: UITextView!
    @IBOutlet weak var textCount: UIBarButtonItem!
    override func viewDidLoad() {
        super.viewDidLoad()
        /*
        UIKeyboardWillHideNotification          将要隐藏
        UIKeyboardWillShowNotification          将要显示
        UIKeyboardDidChangeFrameNotification    已经修改frame
        UIKeyboardWillChangeFrameNotification   将要修改frame
        UIKeyboardDidHideNotification           已经隐藏
        UIKeyboardDidShowNotification           已经显示
         */
        
        /*
         UIKeyboardFrameBeginUserInfoKey        Rect
         UIKeyboardFrameEndUserInfoKey          Rect
         UIKeyboardAnimationDurationUserInfoKey 动画时长
         UIKeyboardAnimationCurveUserInfoKey    动画Options
         UIKeyboardIsLocalUserInfoKey           NSNumber of BOOL
         */
        
        /**
         监听键盘将要出现通知
         */
        NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(ViewController.keyboardWillShow(_:)), name:UIKeyboardWillShowNotification , object: nil)
        /**
         监听键盘将要隐藏通知
         */
        NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(ViewController.keyboardWillHide(_:)), name:UIKeyboardWillHideNotification , object: nil)
        
        /**
         设置textView的背景颜色
         
         - parameter white: 白色 0表示黑色 1表示白色
         - parameter alpha: 透明度
         */
        textView.backgroundColor = UIColor(white: 0, alpha: 0.3)
        /**
         代理
         */
        textView.delegate = self
    }
    
    /**
     点击取消
     
     - parameter sender: 取消
     */
    @IBAction func cancel(sender: AnyObject) {
        dismissViewControllerAnimated(true, completion: nil)
    }
    /**
     点击其他的地方取消键盘编辑
     
     - parameter touches:
     - parameter event:
     */
    override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {
        view.endEditing(true)
    }

    /**
     键盘将要显示
     
     - parameter note: 通知
     */
    @objc private func keyboardWillShow(note:NSNotification){
        //获取信息
        let userInfo = note.userInfo
        //得到rect
        let endRect = (userInfo![UIKeyboardFrameEndUserInfoKey] as! NSValue).CGRectValue()
        //得到动画时长
        let duration = (userInfo![UIKeyboardAnimationDurationUserInfoKey] as! NSNumber).doubleValue
        //开始动画
        UIView.animateWithDuration(duration, delay: 0, options: UIViewAnimationOptions(rawValue: UInt((userInfo![UIKeyboardAnimationCurveUserInfoKey] as! NSNumber).integerValue << 16)), animations: { 
            self.toolBarConstraints.constant = endRect.height
            self.toobar.layoutIfNeeded()
            }, completion: nil)
    }
    /**
     键盘将要隐藏
     
     - parameter note: 通知
     */
    @objc private func keyboardWillHide(note:NSNotification){
        let userInfo = note.userInfo
        let duration = (userInfo![UIKeyboardAnimationDurationUserInfoKey] as! NSNumber).doubleValue
        UIView.animateWithDuration(duration, delay: 0, options: [], animations: {
            self.toolBarConstraints.constant = 0
            self.toobar.layoutIfNeeded()
            }, completion: nil)
    }
}

//***********************     textView代理      *****************
extension ViewController{
    func textView(textView: UITextView, shouldChangeTextInRange range: NSRange, replacementText text: String) -> Bool{
        let text = textView.text as NSString
        if text.length >= 140 {
            textView.text = text.substringToIndex(140)
        }
        textCount.title = "\(140 - text.length)"
        //如果这里返回false,textView就不能编辑啦!
        return true
    }
}


<br />
<br />
<br />
demo地址,包括了1-18

Demo - ListenKeyboard

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,391评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 姓名:庹亚军 公司:宁波贞观电器有限公司 组别:第235期 利他一组 【日精进打卡第98天】 【知~学习】 看《经...
    tyj小电工阅读 126评论 0 0
  • 随着秋招开始,很多大四的学生积极得参加招聘会,这就像是马是骡子出去溜一圈就知道了,果然如此,积极进取得同学很容易找...
    星海如梦阅读 196评论 0 0
  • 该文章属于刘小壮原创,转载请注明:刘小壮[https://www.jianshu.com/u/2de707c93d...
    刘小壮阅读 46,331评论 45 151