swift项目第五天:swift中storyBoard Reference搭建主界面

一:StoryBoard Reference的介绍

  • StoryBoard Reference是Xcode7,iOS9出现的新功能
  • 目的是让我们可以更好的使用storyboard来开发项目
    • 在之前的开发中,如果使用一个storyboard开发,那么非常容易造成代码冲突
    • 可以通过使用storyboard创建控制器的方式解决.
    • 官方目前推出了StoryBoard Reference的方式
  • 优点:
    • 允许你从 segue 中引用其他 storyboard 中的 viewController
    • 可以将不同模块放到不同Storyboard中
    • 阅读性好
    • 齐头并进, 加快开发效率
    • 不容易出现SVN/GIT错误

如何使用StoryBoard Reference

  • 方式一:

    • 1.选中需要的控制器
    • 2.点击导航条Editor
    • 3.选择下拉菜单Refactor to storyboard
  • 方式二:
    • 1.在控件库中拖入Storyboard References
    • 2.新建一个Storyboard
    • 3.关联新建的storyboard到Storyboard References

纯代码和Storyboard如何选择

  • Storyboard前期开发速度快
  • Storyboard容易重复造轮子
  • 纯代码维护方便

二:StoryBoard Reference搭建界面的效果如图

三:StoryBoard Reference具体使用:

1:先设置启动Main StoryBoard

2:再打开Main StoryBoard,删除其控制器,拖入一个UItabBarViewController,删掉其自带的两个item,在左侧直接选中删除:并

设置启动控制器:

3:1:在拖入五个导航控制器,导航控制器自带根控制器,且根控制器默认为UITableViewController,可以删除UITableViewController里显示的cell,cell由自己来创建。再拖线设置UItabBarViewController的根控制器为每个导航控制器(选中拖入UItabBarViewController并右击,选择ViewController拖向每一个拖入的 导航控制器,这样就设置了UItabBarViewController的根控制器) 2:设置tabBarItem标题图片 与导航栏标题:在如图处选中导航控制器,来到右侧,可设置导航栏标题,选中与未选中图片

4: 设置StoryBoard Reference如图2:1:先选中导航控制器和其根视图控制器 2:eidtor -- 选中图中最后一个 3:关联类:如图1,

将相应的storyBoard关联类,如图所示

三:在控制器中设置tabbarItem的选中图片与增减中间按钮(设置选中图片可以在storyBoard中去设置)

import UIKit

/*
 总结:1:lazy用于懒加载,只能用var来对变量进行懒加载,有两种方式:1:lazy var first = NSArray(objects: "1","2")  2:闭包形式:
 lazy var second:String = {
    return "second"
 }()
 例子:
   lazy var imageArr = ["tabbar_home_highlighted","tabbar_message_center_highlighted","tabbar_discover_highlighted","tabbar_profile_highlighted"]

 lazy var imageArr = {

 return ["tabbar_home_highlighted","tabbar_message_center_highlighted","tabbar_discover_highlighted","tabbar_profile_highlighted"]
 }();

     2:1:设置tabbaritem的代码都必须放在viewWillAppear里,若是在viewDidLoad里,则设置好的item又会在viewWillAppear方法里被系统调整回来 2:for循环遍历,1:要是想获得下标值就用区间遍历 for i in 0..<tabBar.items!.count {}(tabBar.items是一个可选类型,能保证其一定有值,所以可以进行!强制解包,根据i值可以从懒加载的数组中取出对应元素)2:若是不想获得下标值,只想获得懒加载数组中的元素值,可以直接遍历,for item in tabBar.items!{} 2:swift中的布尔值用Bool来表示,有true 和 false两种,设置按钮不可点击,btn.isEnabled =  false,与for循环常用的有continue,跳过本次循环,不执行下面的代码,立即执行下一个循环,break立即终止循环,return,也是立即返回,不执行return下面的代码。
     3:要想类中定义的属性不希望外界来访问,就定义为private,或是fileprivate,private修饰的属性方法,只能在当前类中访问,在同一个文件中定义不同的类就不能在访问另一个类中private修饰的方法或是属性,但是属性或是方法用fileprivate可以在当前文件任何类中进行访问

 */
class RHTabBarViewController: UITabBarController {

//    lazy var imageArr = ["tabbar_home_highlighted","tabbar_message_center_highlighted","tabbar_discover_highlighted","tabbar_profile_highlighted"]

    ///1:懒加载图片数组
    fileprivate  lazy var imageArr = {
    return ["tabbar_home_highlighted","tabbar_message_center_highlighted","","tabbar_discover_highlighted","tabbar_profile_highlighted"]
    }();

    ///2:懒加载中间按钮
    fileprivate lazy var centerButton = UIButton()

    override func viewDidLoad() {
        super.viewDidLoad()

         //MARK:-2:添加中间按钮
          setupCenterButton()

    }

    override func viewWillAppear(_ animated: Bool) {

        super.viewWillAppear(animated)

        //MARK:-1:设置tabbarItem的高亮图片
         setupTabbarItems()

    }
}

/**

 总结:1:extension表示扩展,在定义的类中:RHTabBarViewController,设置该类的扩展,extension RHTabBarViewController {},若是该类有遵守协议关系的时候,继承的协议就在RHTabBarViewController后面加:后面写遵守的协议 2:一般extension扩展用于在某个类中封装方法,在viewDidLoad方法中抽方法封装调用,将封装的方法写在extension的扩展类中,在viewDidLoad直接调用

     2:一般在声明的类class中定义属性:1:private,或是filePrivate来修饰,并且一般采用懒加载(1:直接初始化 2:闭包懒加载,{return:一个值}()),若不是懒加载,定义属性变量的时候,必须定义初始化有值,要不定义成可选类型,在后面进行赋值,否则会被报错。 2:在viewDidload中抽方法封装调用,将封装的方法写在extension的扩展类中,在定义方法的时候,也是private,fileprivate来选择修饰,定义有返回值或是无返回值的函数。2:定义的函数中涉及到外部参数与内部参数:在swift中第一个参数默认为内部参数,_+空格+参数名组成,默认从第二个参数开始,既是外部参数又是内部参数,若是想让某个参数成为内部参数,就直接在函数中用_+空格+参数名修饰就可以 3:函数的默认参数,在封装的函数中,也可以给参数设定默认参数,则此时,外部调用就不会显示默认参数,而在参数内部自己可以拿到默认参数的值:如定义的全局打印:fileName:String = #file

 func DLog<T> (message: T,fileName:String = #file,funcName:String = #function,lineNum:Int = #line) {

 #if DEBUG

 let file = (fileName as NSString).lastPathComponent;

 print("\(file):\(funcName):\(lineNum):\("打印内容"):\(message)")

 #endif

 }

    3:设置tabbar上的高亮图片:1:tabBar.items为一个可选类型的数组,但是能保证其一定有值,所以可以进行强制解包,若是可选类型的变量能确定一定有值的话就对其进行强制解包 2:创建UIImage的对象:item.selectedImage = UIImage(named: imageArr[i])

    4:添加中间的加号按钮:1:懒加载完控件后,首先在方法中将控件添加到父控件中,在同一个类中属于该类的方法可以不去调用self,tabBar.addSubview(centerButton) 2:设置按钮的背景图片centerButton.setBackgroundImage, centerButton.setImage,第二个参数为一个枚举值,枚举值调用就用点语法调用枚举类型,.normal,.highlighted 3:设置按钮的frame:centerButton.sizeToFit()
        让按钮的大小等于按钮内容的大小。设置center的时候,设置的是tabbar的centerx,中心点y值为tabba高度的一半
 */
extension RHTabBarViewController {

   ///1:添加中间的加号按钮
  fileprivate  func setupCenterButton() {

    //1:添加按钮
    tabBar.addSubview(centerButton)

    //2:设置图片
    centerButton.setBackgroundImage(UIImage(named: "tabbar_compose_button"), for: .normal)
    centerButton.setBackgroundImage(UIImage(named:"tabbar_compose_button_highlighted"), for: .highlighted)
    centerButton.setImage(UIImage(named:"tabbar_compose_icon_add"), for: .normal)
    centerButton.setImage(UIImage(named:"tabbar_compose_icon_add_highlighted"), for: .highlighted)

    //3:设置frame
    centerButton.sizeToFit()
    centerButton.center = CGPoint(x: tabBar.center.x, y: tabBar.bounds.size.height * 0.5)

    }

    ///2:设置的是tabbar上的高亮图片
    fileprivate func setupTabbarItems() {

        for i in 0..<tabBar.items!.count {

            let item = tabBar.items![i]
            if i == 2 {

                item.isEnabled = false
                continue
            }

            item.selectedImage = UIImage(named: imageArr[i])

        }

    }

}
时间: 2024-08-10 23:28:29

swift项目第五天:swift中storyBoard Reference搭建主界面的相关文章

在 Swift 项目中实现侧滑菜单-利用 SWRevealViewController

你可以完全自己手动写一个侧滑菜单,但是现在在 GitHub 上面已经有很多免费的开源库了,如果不是有很特别的需求,大可不必新建一个轮子. 在这里我使用的这个第三方库名字叫做 SWRevealViewController,作者是 John Lluch.这个免费的类库提供了很方便快捷的方法去把侧滑菜单加入到你的 App 里面,而且它还提供了很多个性化的设置项.它是用 Objective-C 来写的,但是我们也可以很方便的在 Swift 项目中去使用它.你分分钟便可学会如何使用. 首先来看一下我们的

Swift 项目中常用的第三方框架

Swift 项目中可能用到的第三方框架 字数1004 阅读4091 评论17 喜欢93 这里记录下swift开发中可能用的框架 , 最近浏览了不少,积累在这里,以后用的时候方便查阅.顺便推荐给大家! 这里的框架都是纯swift的 , 感谢开源 ,感谢大神们 . 下拉刷新 BreakOutToRefresh 一个下拉刷新打砖块的swift库 SDRefreshView 简单易用的上拉和下拉刷新 ZLSwiftRefresh - 下拉刷新/上拉加载更多,支持自定义动画,集成简单 GearRefres

swift项目中使用OC/C的方法

假如有个OC类OCViewController : UIViewController类里有两个方法 //swift调用oc或c的混编是比较常用的,反过来的调用很少.这里只写了swift调用oc和c的方式.//OC函数声明- (void)testOC;//C函数声明void testc(); 实现:void testc(){  printf("testc.....................");} -(void)testOC{  NSLog(@"\ntestOC.....

Swift项目中调用Objective-C的库

这是来自stack overflow上的一个回答,更多回答请查看: http://stackoverflow.com/questions/24002369/how-to-call-objective-c-code-from-swift Using Objective-C Classes in Swift * If you have an existing class that you'd like to use, perform Step 2 and then skip to Step 5. (

Swift项目兼容Objective-C问题汇总

本文是投稿文章,作者:一叶(博客)欢迎将原创文章或者译文投给我们,投稿方式:[email protected]或者在首页点击“投稿爆料” 一.解决问题 Swift 项目需要使用封装好的Objective-c组件.第三方类库,苹果提供的解决方案能够处理日常大部分需求,但还不能称之为完美,混编过程中会遇到很多问 题.本文将Swift兼容Objective-c的问题汇总,以帮助大家更好的使用Swift,内容列表如下: 1. Swift调用Objective-c代码 2. Objective-c调用Sw

25.怎样创建一个Swift项目?

经历前面三部分的学习之后,我们对于Swift的有了基本的了解,知道它的基础语法,也知道了类.结构体.枚举.协议.扩展等等内容.但知道上面这些内容,并不代表我们就能很好的进行实际的项目开发了,本部分内容将手把手的教你进行Swift的项目开发. 1.新建Swift项目 打开XCode,选择[File] --> [New] --> [Project](也可以同时按住command+shift+N快捷创建),如下图所示: 单击[Project]之后,将弹出选择项目模板的界面,这里我们可以选择[Sing

Swift入门(五)——数组(Array)

集合 集合的定义 Swift中提供了两种数据结构用于存放数据的集合,分别是数组(Array)和字典(Dictionary).他们的主要区别在于数组中的元素由下标确定,而字典中的数据的值由数据的键(Key)决定.以下我们认为集合就是数组或字典. 集合的可变性 我们可以定义一个集合常量或者集合变量.一旦定义为常量,就意味着集合的长度.内容和顺序都不能再修改了.比如,定义为常量的数组,不能再向其中添加新的元素. 数组的创建 由于swift中变量的创建遵循" var 变量名:变量类型 "的语法

在项目里交叉使用Swift和OC

Swift and Objective-C in the Same Project 在项目里交叉使用Swift和OC Swift与OC的兼容性使得你可以在项目里使用Swift+OC的方式编写应用程序,称为混合+匹配(mix and match),用这种方式可以一边使用享受新语言的快速特性,一边无缝的接合你已有的OC代码(原文听起来好NB的样子,其实也就那么回事),不管项目最初是用OC编写的还是新建的Swift项目,都可以在这个项目里用OC和Swift混合继续开发 Importing Object

Swift语言指南(五)--数字字面量和数字类型转换

数字字面量 整数字面量写法如下: · 十进制数,无前缀 · 二进制数,以 0b 为前缀 · 八进制数,以 0o 为前缀 · 十六进制数,以 0x 为前缀 下面所有整数的十进制值为 17 : 1 let decimalInteger = 17 2 let binaryInteger = 0b10001 // 17 二进制标识 3 let octalInteger = 0o21 // 17 八进制标识 4 let hexadecimalInteger = 0x11 // 17 十六进制标识 浮点数字