`
啸笑天
  • 浏览: 3461228 次
  • 性别: Icon_minigender_1
  • 来自: China
社区版块
存档分类
最新评论

使用Storyboards开发的10个小技巧

 
阅读更多

感谢:http://www.cocoachina.com/ios/20150727/12772.html

本文由CocoaChina翻译小组成员Lollypo(社区ID)翻译自David McGraw
原文:10 Practical Tips for iOS Developers Using Storyboards

在这里我将着重讲述10件事情,而不会去全面讲述如何使用Storyboard去创建一些事物。这些知识点没有特定的顺序,但它们也许可以帮到你在这条道路上前行。

Storyboard是我花时间钻研最多的一个领域。我非常喜欢可视化编程。只需要简单地将项目拖到画布中,更新位置信息,再设置一些描述信息,就已创建了一个用户界面而不用编写任何代码。这非常重要,因为用户界面的代码可以很快让你的代码变得一团糟。

当我参与到一个新的项目时,我首先要做的就是找到其中的Storyboard。这是概览程序整体框架的一处重要之地。

假如没有使用可视化编辑器,你就需要手动化操作才能发现工作的进展。你在代码中来回往复耗费大量时间,也只能大致了解给定的视图的情况。您可以明确参考设计文件或运行应用程序并导航到所需的区域,但我更希望避免这种情况。最后,在某些情况下,调整界面组件成为一个繁琐的过程。你不断编译并运行应用程序去验证它们是否都在正确地位置,而不是通过Storyboard快速调整。



 

看看,只是创建右边这么一个简单的界面就编写了这么多的代码,我甚至还没有编写任何自动布局代码来帮助我们定位。我知道会有顽固的代码狂人。但我还是不想这些让我的代码膨胀,这实在是让人不快。不要误会我。对于初学者来说,这样做的价值是理解如何通过代码创建一个用户界面。通过一个给定的用户界面,你有了一个大概的认识,知道它能做什么。而不是查阅文档。

列表

也许可以归为一件,不过不用在意

你不需要将整个程序搭建在一个故事板中。可以将它们分成好几个故事板。假设有管理面板,设置面板,以及主面板。当你的程序扩大后可以节省你的很多精力。在团队中工作时与故事板交互也会变得轻松,而且查找需要的故事板也会更快捷。

什么是exit segue,如何使用它

首先,我说一下什么是segue。假设你现在的故事板中有两个场景,其中第一个场景中有一个按钮。当你右击场景1的按钮,然后拖动到场景2,你这样就是创建了一个segue。



 

现在假设我们选择present modally。该模态表示这是用户优先关注的场景。这没有简单的方法来回到第一个场景,就像你可能看过的如果你推送一个场景到导航栈上。我们可以创建一个委托来通知第一个控制器我们已经完成。但这样有些乏味,我们也可以发送通知给第一个控制器,但这就是有点大材小用。这是一个机会使用exit segue,exit segue就像segue一样工作,不同的是会返回到执行UIStoryboardSegue动作的地方。这就是关键!

通过你创建的segue,exit segue可以一直后退导航,无论segue是在那创建的,都可以找到exit segue。

查看一下下方的完整地视图结构。



 

如果你只是右击按钮的exit segue指示器,你不会看到任何东西。它需要检测你在目标控制器中创建一个UIStoryboardSegue动作的方法(绿色箭头指向)。例如:

1
2
3
@IBAction func unwindToSceneA(unwindSegue: UIStoryboardSegue) {
    // be sure to give your unwind segue an identifier so you know where we're coming from     
}

例子:http://blog.csdn.net/kid_devil/article/details/23218195  demo见附件

Storyboard(故事板)跳转

你无需在故事板中绘制漂亮的segue到你想去的地方。你只需初始化故事板以及获取你想要展示的控制器。一旦你有了控制器,你可以调用必要的显示方法。

1
2
3
4
5
6
7
8
9
var storyboard: UIStoryboard = UIStoryboard(name: "Settings", bundle: nil)
var modal: UIViewController = storyboard.instantiateViewControllerWithIdentifier("settingsStoryboardId") as UIViewController
self.presentViewController(modal, animated: true, completion: nil)
  
/* If you're fetching a controller in the same storyboard you're already on, 
 * then you can skip initializing a new UIStoryboard object.
 */
var modal: UIViewController = self.storyboard?.instantiateViewControllerWithIdentifier("customStoryboardId") as UIViewController
self.presentViewController(modal, animated: true, completion: nil)

预览编辑器

如果花所有时间去构建并运行应用程序以观察用户界面是否调整到你想要的结果,是很乏味的。在处理自动布局时尤其如此。



 

现在打开预览编辑器,你可以修改视图,观察它如何变化。你也可以按下左下角助理编辑面板上的+按钮,以便在多个屏幕尺寸预览界面。

让手指休息一下

如果你有一个按钮需要连接到源代码中,你可以右键单击,然后拖一条线到源文件中为你生成一个outlet.



 

此外,对于一个给定的事件,你可以通过单击再拖到你的源文件来生成一个action。



 

以上操作的最终结果。



 

那,为什么需要做这些操作呢? 这么说吧,最明显的就是action。如果你不创建一个@IBAction函数,那么当你按下按钮的时候不会有任何事情发生。你可以假设需要添加一些代码来改变UIImageView中最初设置的的图片。为了改变这个图片我们就需要一个@IBOutlet以便我们访问它。

避免极其复杂的控制器

尽管你的控制器可以管理大量子视图,但你的风险在于一层一层的添加视图,这会使事情完全被破坏。很快你就会发现,你偏离了使用可视化编辑器的目的--提供清晰的视图层次。如果你有一个复杂的视图结构,那么是时候考虑这些设置。

你可以使用一个xib,或者你可以添加一个容器视图对象到你的场景,并隐藏它直到需要的时候。通常我使用xib,但在某些情况下则使用容器视图对象。

当你添加一个xib的同时还会添加一个源文件,你将使用它来初始化xib.例如,我们创建了ExampleView.xib以及一个漂亮的场景。为了加载这个视图我们需要创建ExampleView.swift以及初始化这个xib。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import UIKit
  
class ExampleView: UIView {
     
    // normal initialization
    override init(frame: CGRect) {
        super.init(frame: frame)
        self.addExampleViewSubview()
    }
     
    // will be loaded if we use this class in a storyboard, for example
    required init(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
        self.addExampleViewSubview()
    }
  
    func addExampleViewSubview() {
        var xib = NSBundle.mainBundle().loadNibNamed("ExampleView", owner: self, options: nil)
        var view: UIView = xib.first as UIView
        view.frame = self.frame
        self.addSubview(view)
    }
}

占位符约束

这是给那些喜欢混合使用代码与故事板操纵约束的人的。即使我个人尽可能地避免在代码中编写约束,但这对于那些不属于故事板的视图确实是很有作用的。

假如你试图在代码中创建约束,且需要与故事板中的用户界面交互,这可能会是一个非常可怕的经历。不过不要害怕,你可以很轻松地告诉Xcode这个特定约束是一个占位符。这意味着在构建和运行应用程序时它将被忽略。



 

默认的试图控制器

你可能需要更改哪个场景与故事板一起加载。在早期版本的Xcode中你也许会选择一个场景,然后选择**Is Initial View Controller**。在Xcode的最新版本变了。现在你需要搜索对象库,找到 **Storyboard Entry Point**,然后你可以拖拽到想要的场景。这其中一次只能有一个是活跃的,所以你可以可以拖拽它到你想想要的任一控制器中。

为什么你会担心入口点发生改变?就我个人而言,我使用它来测试不同的控制器,我不想创建大量的按钮才能进到控制器里去。如果你只是更新故事板的入口点,它就会立即加载。

自定义Segue转场效果

如果你选中一个segue,你可能已经注意到,它有一些预加载的转场效果,比如垂直覆盖、水平翻转、淡入淡出以及部分卷曲等。如果你想要更多的自定义效果呢?在这种情况下你需要创建一个自定义UIStoryboardSegue。

举个简单的粟子,创建一个新的Swift文件,取名为**CustomSegue**。 当我们的segue被执行的时候(上面的按钮被点击),下面这段代码也会被执行。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import UIKit
  
class CustomSegue: UIStoryboardSegue {
     
    var startingPoint: CGPoint = CGPoint(x: 0, y: 0)
     
    override func perform() {
        var source = self.sourceViewController as UIViewController
        var destination = self.destinationViewController as UIViewController
         
        // Add the destination view as a subview (temporarily)
        source.view?.addSubview(destination.view)
         
        // Set the start scale
        destination.view.transform = CGAffineTransformMakeScale(0.05, 0.05)
         
        // Original center point
        var originalCenter = destination.view.center
        destination.view.center = self.startingPoint
         
        UIView.animateWithDuration(0.225, delay: 0.0, options: UIViewAnimationOptions.CurveEaseOut, animations: { () -> Void in
            destination.view.transform = CGAffineTransformMakeScale(1.0, 1.0)
            destination.view.center = originalCenter
        }) { (finished) -> Void in
            destination.view.removeFromSuperview()
            source.presentViewController(destination, animated:false, completion:nil)
        }
    }
}

钮按时,这将从我们设置的一个起始位置展开目标视图。在这种情况下,我设置起始位置为场景1中按钮的中心位置(源场景)。

1
2
3
4
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
    let custom = segue as CustomSegue
    custom.startingPoint = self.nextImage.center
}

在故事板文件中我们选择从场景1到场景2的segue。更改Segue为Custom,然后输入Segue类来匹配我们刚刚创建的一个CustomSegue。

避免源代码管理的噩梦

对于那些在团队中的人来说,虽然他们也在逐渐变得更好,但当涉及到源代码管理时,故事板仍是一个大痛处。这也是为什么你应该将故事板拆分成若干个。如果你可以避免这个,请确保同一时刻只有一个人操作故事板。这会避免其他人提交故事板的更改到项目中产生的冲突。即使这并不那么容易去避免,但请做好准备防止这种情况出现。这也许是团队与小公司不想使用故事板最大的原因。

尽管当我与的团队共享故事板时很有可能会导致源代码控制的冲突,我仍然觉得,速度和效益的重要性大于修补因为冲突导致的恼人补丁。在大多数情况下我确保其他人避免与我同时处理。但是,它仍然一次又一次发生。

这里是我如何处理冲突的方法:

  • (第一道防线)首先主动避免它。在与故事板工作时我经常尽早的提交,并且对其他也在与这个故事板工作的人打个招呼。当与其他人一起工作时,尽量保持小任务量的工作,以及互相帮助。不要推送整体的大更新。

  • 如果我遇到了冲突,我会通过差异工具[Kaleidoscope](http://www.kaleidoscopeapp.com/)来浏览。这确实需要一些经验来理解故事板的原理。如果你还没看过,现在就是时候。右键点击 storyboard > open as > source code,观察控制器区域(包括连接信息)是如何陈列布局的。

  • (糟糕的情况)我找出了谁做的最大的更改,谁接收的这些变化信息,覆盖其了其他什么,然后我们会恢复这些改变。

我做过一些大型的项目。虽然这些合并的issues不是经常严重到diff工具不能恢复。但你可以获得更多的经验。

我不能强调第一点是足够的。积极主动很重要。知道你的团队是什么样地情况。如果你有一个令人难以置信的复杂的故事板,就将它板划分成不同的区域。

拿走不谢

故事板是非常有用的,尤其是对于那些非常直观的东西。当做原型时,也可以给你一个不错的速度优势。无需为代码烦忧,你可以快速将各种元素放在适当的地方,连接它们,然后从驱动界面的逻辑开始做起。

 

  • 大小: 61.6 KB
  • 大小: 23.8 KB
  • 大小: 6.7 KB
  • 大小: 38.3 KB
  • 大小: 51 KB
  • 大小: 59.6 KB
  • 大小: 59.2 KB
  • 大小: 155.3 KB
分享到:
评论
2 楼 啸笑天 2016-01-19  
https://developer.apple.com/library/ios/documentation/Cocoa/Conceptual/LoadingResources/CocoaNibs/CocoaNibs.html
From a practical perspective, in iOS and OS X outlets should be defined as declared properties. Outlets should generally be weak, except for those from File’s Owner to top-level objects in a nib file (or, in iOS, a storyboard scene) which should be strong. Outlets that you create should therefore typically be weak, because:

Outlets that you create to subviews of a view controller’s view or a window controller’s window, for example, are arbitrary references between objects that do not imply ownership.
The strong outlets are frequently specified by framework classes (for example, UIViewController’s view outlet, or NSWindowController’s window outlet).
1 楼 啸笑天 2016-01-19  
http://www.cocoachina.com/ios/20151026/13868.html  Xcode 7:Storyboard Reference、Strong IBOutlet以及Scene Dock

相关推荐

    Storyboards-1.zip

    总的来说,"Storyboards-1.zip"的内容可能涵盖如何有效地使用Storyboard进行iOS应用开发的各个方面,包括基础概念、最佳实践、问题解决和高级技巧。通过学习这些内容,开发者可以提升自己的iOS应用设计和开发能力。

    Silverlight 2.5D RPG游戏技巧与特效处理源代码与说明

    在Silverlight中,可以使用Storyboards和Timeline类来实现复杂的动画效果。例如,通过定义关键帧动画,我们可以模拟出魔法弹射出、爆炸、燃烧等视觉效果。同时,利用VisualStateManager可以控制状态转换,比如当角色...

    iOS5开发基础教程

    iOS开发主要使用苹果提供的Xcode集成开发环境(IDE)和Objective-C编程语言。在iOS 5中,苹果引入了许多新特性和改进,这些在教程中都有所涉及。以下是一些关键知识点的概述: 1. **Objective-C编程语言**:...

    iOS实例开发源码——maximile-Your-Story-25afe65.zip

    这个压缩包文件“iOS实例开发源码——maximile-Your-Story-25afe65.zip”显然是一个iOS应用的源代码库,名为“maximile-Your-Story”。这个项目的版本号可能是25afe65,这通常在Git等版本控制系统中表示特定的提交。...

    Beginning iOS 6 Development: Exploring the iOS SDK

    第10章介绍了Storyboards这一强大的工具,它使得开发者可以使用可视化的方式来组织界面和管理应用的流程。 第11章专注于iPad应用开发的特别考虑点,因为iPad的大屏幕提供了不同于iPhone的用户体验和设计机会。 第...

    iOS Programming: The Big Nerd Ranch Guide (4th Edition) (Big Nerd Ranch Guides)

    1. Xcode 5开发环境:Xcode是苹果公司提供的iOS应用开发集成开发环境(IDE),第四版重点介绍了Xcode 5的使用方法和技巧,比如使用Instruments进行性能分析,以及Storyboards进行界面设计。 2. iOS 7风格界面构建:...

    IOS应用源码——小球.rar

    在iOS开发中,源码是理解应用程序工作原理和学习技术的最佳途径。...对于经验丰富的开发者,这个源码可能提供了一些新的思路和优化技巧。总之,深入分析和学习这样的源码实例,对于提升iOS开发技能大有裨益。

    使用WPF功能写的俄罗斯方块游戏源代码

    总的来说,这个使用WPF和C#实现的俄罗斯方块游戏项目,不仅展示了WPF在图形渲染和用户体验上的优势,还体现了C#在游戏逻辑和数据管理方面的强大能力。对于初学者,这是一个很好的学习实践案例,可以帮助他们深入理解...

    iOS5 Programming Cookbook Source Code

    这本书的核心是通过实际的代码示例来讲解iOS5开发中的各种技术和技巧,让读者能够快速掌握编程实践。 在iOS5中,Apple引入了许多新特性,如Storyboards、Auto Layout、Notification Center、Game Kit等,这些都在书...

    Silverlight:手把手教你写俄罗斯方块

    在本文中,我们将深入探讨如何使用Microsoft的Silverlight技术来创建一个经典的俄罗斯方块游戏。Silverlight是一款强大的网络应用程序框架,允许开发者构建丰富的交互式用户体验,尤其适合开发多媒体和游戏应用。 ...

    IOS6 by tutorials

    书中会解释如何有效地使用Storyboards进行应用开发。 7. **其他API更新**:书中还会涵盖其他的API更新,如Game Center的改进,新的多任务处理机制,以及增强的多媒体支持等。 通过阅读《iOS 6 By Tutorials》,...

    iOS6基础教程(英文版)

    这一章节可能会讲解标签栏控制器的使用方法和技巧,以及如何在用户界面中集成选择器控件,例如日期选择器、分段控制器等,以方便用户进行复杂选择。 ### 第8章:表格视图简介 表格视图(TableView)是iOS中重要的...

    iOS.5.Programming.Cookbook 中文版 前言

    1. **中文资料匮乏**:高质量的技术文档大多为英文原版,这对于英语水平一般的开发者来说是个不小的障碍。 2. **语言障碍**:不少开发者对于英文文档阅读感到困难,这限制了他们获取最新技术信息的能力。 3. **知识...

    developing windows applications c#.pdf

    整体而言,本书针对UWP平台的开发提供了一个全面的介绍,涵盖了从基础到高级的应用开发技巧,并结合了大量示例和代码片段来帮助理解。无论读者是初学者还是有经验的开发者,都可以从这本书中获得宝贵的UWP开发经验。

    iOS.5.Programming.Cookbook.code

    《iOS 5编程实战秘籍代码》是一本深入探讨iOS应用程序开发的专业书籍,其配套代码库包含了一系列示例代码,旨在帮助开发者掌握iOS 5版本中的各种编程技巧和最佳实践。这本书聚焦于Xcode集成开发环境,是学习和提升...

    ios 7 programming cookbook source code

    了解Xcode 5的各项功能,如Interface Builder、Auto Layout、Storyboards等,对高效开发至关重要。书中的源代码是用Objective-C或Swift编写的,这两种语言是iOS开发的主要语言。 书中可能涵盖了以下知识点: 1. **...

    苹果applewatch界面

    综上所述,Apple Watch的界面设计和开发涉及多个层面,从设计原则到具体组件,再到开发工具和技巧,都需要开发者对Apple的人机交互指南有深入理解,并具备良好的视觉设计和编程能力。通过不断优化和创新,开发者可以...

Global site tag (gtag.js) - Google Analytics