一、透明度变化,类京东首页

一般透明度变化都会牵扯到滚动视图(scrollView)包括UIScrollView、UITableView、UICollectionView等,可以使用通用的一些属性作响应处理。

最后实现“导航栏”透明度变化的并不是导航栏,只是实现了一种相同的效果,因为直接使用NavigationBar的过程中遇到一些问题,导致实际体验有些瑕疵,下面作简单说明。

1、最简单的方式,直接改变navigationBar透明度,有些问题

func scrollViewDidScroll(_ scrollView: UIScrollView) {
    let offset = scrollView.contentOffset.y;
    if (offset <= 0 && offset <= -90) {

       self.navigationController?.navigationBar.alpha = 0;

    }else if(offset<=300){ //取值可以根据自己的需求
       //alpha最大值为1
        self.navigationController?.navigationBar.alpha = offset/200;
    }
}

这是一种最简单的方式,只要改变navigationBar的透明度就可以了,并且效果很好。
但是这个方式的问题是,UINavigationController只有当前页面,那这是最好的选择,但如果对应还有上下层viewController,在也页面切换的过程中就会出现一些不太友好的情况。
这里改变的navigationBar并非当前viewController所独有的,而是属于NavigationController下所有viewcontrollers的,所以在改变当前页面透明度时,其他的也都会改变。

当然也尝试在对应页面重新设置navigationBar的alpha,但在返回/切换的过程中,效果并不理想,尤其是当两个页面的navigationBar的颜色不同时(一般情况下,这种情况都是首页->详情页,导航栏不同是绝对正常的情况),那个画面就更美了。

所以,虽然很想省功夫,直接在navigationBar的基础上去做更改,但实际情况却很尴尬。尝试了做一些修改,但结果都不怎么理想。

所以尝试使用偷懒的方式,就是自定义一个view“假装”navigationBar。所以如果你坚持想要使用源生navigationBar,可以继续尝试,会有办法的。现在主要目的是实现需求,达到效果就好。

2、偷懒又好用的方法,隐藏navigationBar,自定义view

为什么这么用呢?
1、一般导航栏颜色/透明度变换页面只有首页/个人中心/其他主视图页面使用,不会多。
2、可以集成三方自定义的导航栏,一般没有必要这么麻烦,因为自定义view很easy
主要代码:

func scrollViewDidScroll(_ scrollView: UIScrollView) { 
    let offset = scrollView.contentOffset.y;
    if (offset <= 0 && offset <= -90) {
        navigationBarView.backgroundColor = UIColor.red//可以忽略,想要动态改变颜色,可以保留
        navigationBarView.alpha = 0;
    }else if(offset<=300){
        navigationBarView.backgroundColor = UIColor.red//可以忽略,想要动态改变颜色,可以保留
        //alpha最大值为1
        navigationBarView.alpha = offset/255;//调整alpha值

    } else {
        navigationBarView.backgroundColor = UIColor.green //可以选择改变颜色
    }

}

navigationBarView即为自定义仿制导航栏,这个很简单,只是一个view,手动添加可以,storyboard添加也可以,这里只是调整view的透明度,标题、按钮均可自定义。

这里也提供了tableView的Cell自动布局的方式,需要在storyboard中设置对应约束关系。

tableView.rowHeight = UITableViewAutomaticDimension;

tableView.estimatedRowHeight = 100;

viewController.swift完整代码:

class ViewController: UIViewController,UITableViewDataSource,UITableViewDelegate {
    @IBOutlet var navigationBarView: UIView!
    @IBOutlet var titleLabel: UILabel!
    @IBOutlet var tableView: UITableView!
    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view,typically from a nib.

        tableView.rowHeight = UITableViewAutomaticDimension;
        tableView.estimatedRowHeight = 100;
        tableView.separatorStyle = UITableViewCellSeparatorStyle.none;

        self.navigationItem.title = "透明"

        navigationBarView.alpha = 0;
    }

    override func viewWillAppear(_ animated: Bool) {
        super .viewWillAppear(animated)

        self.navigationController?.setNavigationBarHidden(true,animated: true)
    }

    override func viewWilldisappear(_ animated: Bool) {
        super.viewWilldisappear(animated)
        self.navigationController?.setNavigationBarHidden(false,animated: true)
    }



    // MARK: UIScrollView Delegate
    func scrollViewDidScroll(_ scrollView: UIScrollView) {



        let offset = scrollView.contentOffset.y;
        if (offset <= 0 && offset <= -90) {
            navigationBarView.backgroundColor = UIColor.red
            navigationBarView.alpha = 0;
        }else if(offset<=300){
            navigationBarView.backgroundColor = UIColor.red
            //alpha最大值为1
            navigationBarView.alpha = offset/255;

        } else {
            navigationBarView.backgroundColor = UIColor.green
        }
        return;

    }


    // MARK: UITableviewDataSource
    func numberOfSections(in tableView: UITableView) -> Int {
        return 1;
    }
    func tableView(_ tableView: UITableView,numberOfRowsInSection section: Int) -> Int {
        return 20;
    }

    func tableView(_ tableView: UITableView,cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "TestCell") as! TestCell
        cell.itemImageView.image = UIImage.init(named: "bear\(indexPath.row%9+1)")
        cell.contentLbl.text = "这个内容有点多:\n\(indexPath.row*999999999) \n凑行数\n你猜猜还有多少\n应该没有了\n好吧"
        return cell
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // dispose of any resources that can be recreated.
    }


}

二、滑动隐藏/显示

有一种很简单的方式,通过判断scrollView的滚动方向来隐藏/显示navigationBar,可以满足一般需求。

// MARK: UIScrollView Delegate
    func scrollViewDidScroll(_ scrollView: UIScrollView) {


        //滚动判断 tableView的方向,确定是否隐藏navigationBar
        if scrollView.contentOffset.y > currentOffset && scrollView.contentOffset.y > 60 {
            UIView.animate(withDuration: 2,animations: {

                self.navigationController?.setNavigationBarHidden(true,animated: true)

            },completion: { (finish) in

            })
        } else {
            UIView.animate(withDuration: 2,animations: {
                self.navigationController?.setNavigationBarHidden(false,animated: true)
            },completion: { (finish) in

            })
        }
    }

    //根据手指拖动方向判断是否隐藏,
    func scrollViewWillEndDragging(_ scrollView: UIScrollView,withVeLocity veLocity: CGPoint,targetContentOffset: UnsafeMutablePointer<CGPoint>) {
        currentOffset = scrollView.contentOffset.y;//记录开始拖拽的位置,以作对比,判断方向
    }

这种方式可以满足大多数需求,只是隐藏/显示只能保留一种状态,不能停留在一半的状态,虽然这种状态并不合理,但如果有这种变态需求,该做还是要做的。就像上面说的透明度一样,可以采用自定义的view方式来做处理,这样更灵活。

完整代码

Swift*UINavigationBar动态颜色/透明度/隐藏的更多相关文章

  1. html5录音功能实战示例

    这篇文章主要介绍了html5录音功能实战示例的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  2. SnapKit更新约束-Swift3.0

    导入SnapKit修改约束建立约束

  3. 你需要的大概不是 enumerated

    enumerated()很容易被误解。然而,它的startIndex很明显是2,而不是0,但当我们调用enumerated()和first的时候,它会返回一个元组,包含了一个offset,值为0,以及它的第一个元素“c”。而且实际上你获取到的是一个offset,而不是index,使用enumerated()也会有别的问题。很多时候你也许想用enumerated(),但有别的更好的抽象可以使用。下面是一个例子:因为这里的offset是作为一个数字去使用,enumerated()就可以正常运作。

  4. Swift*UINavigationBar动态颜色/透明度/隐藏

    所以,虽然很想省功夫,直接在navigationBar的基础上去做更改,但实际情况却很尴尬。所以如果你坚持想要使用源生navigationBar,可以继续尝试,会有办法的。viewController.swift完整代码:二、滑动隐藏/显示有一种很简单的方式,通过判断scrollView的滚动方向来隐藏/显示navigationBar,可以满足一般需求。

  5. Swift中的自定义Flip Segue

    这是我的自定义Segue的代码我认为这有效但实际上只有在已经执行segue时视图才会改变.当“翻转”位于中间时,我该怎么做才能使视图发生变化?

  6. 在Android中阅读广告包

    我正在研究一种广告制造商特定数据的BLE传感器.是否有任何示例代码演示如何在Android中接收广告数据包并解析其有效负载?

  7. 前后端结合实现amazeUI分页效果

    这篇文章主要介绍了前后端结合实现amazeUI分页,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  8. php Illegal string offset 'name'问题及解决

    这篇文章主要介绍了php Illegal string offset 'name'问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  9. 三剑客:offset、client和scroll还傻傻分不清?

    这篇文章主要给大家介绍了三剑客:offset,client和scroll的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  10. 使用HTML CSS实现网页换肤效果(二)

    这篇文章主要介绍了使用HTML CSS实现网页换肤效果(二) 的相关资料,需要的朋友可以参考下

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部