转换到 StoryBoard 的发布说明(Converting to Storyboards Release Notes)
太阳火神的美丽人生 (http://blog.csdn.net/opengl_es)
本文遵循“署名-非商业用途-保持一致”创作公用协议
转换到 StoryBoard 的发布说明(Converting to Storyboards Release Notes)
Storyboarding 是一种新的方式用于创建 iOS 应用的用户界面,从 iOS 5 和 Xcode 4.2 开始引入。使用 storyboard,你可以把组成你的应用的视图控制器设计成 Xcode 设计画布中的场景,并且使用 segue 在场景间可视化地定义导航。
Storyboarding is a new way to create user interfaces for iOS applications, beginning with iOS 5 and Xcode 4.2. Using storyboards, you can design the view controllers that compose your application as scenes in the Xcode design canvas and visually define the navigation between the scenes using segues.
把一个已有的 iOS 应用转换成使用 storyboard 需要采取一些步骤。另外,有一些其它模式可以采用。
There are a few steps you need to take to convert an existing iOS application project to use storyboards. In addition, there are other new patterns you can adopt.
内容如下:
Contents:
- 配置应用代理
Configure the Application Delegate - 添加 Storyboard 到工程
Add a Storyboard to the Project - 为工程设置主 Storyboard
Set the Main Storyboard for the Project - 访问第一个视图控制器
Accessing the First View Controller - 配置表视图
Configuring Table Views
配置应用代理
Configure the Application Delegate
应用代理负责加载 storyboard 并管理窗口。你需要在 UIApplicationMain 中指定应用代理类的名称,并确保应用代理有一个叫 window 的属性。
The application delegate is responsible for loading the storyboard and managing the window. You need to specify the name of the application delegate class in UIApplicationMain, and ensure that the application delegate has a property called window.
如果你没有应用代理类,那么需要创建一个。一个最小实现会像这样:
If you don’t have an existing application delegate class, you need to create one. A minimal implementation would look like this:
Listing 1-1 最小应用代理头文件
Listing 1-1 Minimal application delegate header file
#import <UIKit/UIKit.h> |
@interface AppDelegate : NSObject <UIApplicationDelegate> |
@property (strong, nonatomic) UIWindow *window; |
@end |
Listing 1-2 最小应用代理实现文件
Listing 1-2 Minimal application delegate implementation file
#import "AppDelegate.h" |
@implementation AppDelegate |
@synthesize window = _window; |
@end |
注意: 在当前的 Xcode 模板中,应用代理类继承自 UIResponder.。这样应用代理实例可以参与到 响应链 (responder chain) 以便处理应用层动作。如果你已存在的应用中未使用这种模式,就没有必须为 storyboard 采纳它。
Note: In the current Xcode templates, the application delegate class inherits from UIResponder. This is so that the delegate instance can participate in the responder chain and so handle application-level actions. If you haven’t made use of this pattern in an existing application, there’s no need to adopt it for storyboards.
在 main.m 文件中 UIApplicationMain 类里设置应用代理。
In the main.m file, set the application delegate class in UIApplicationMain.
已有的 main.m 文件可能看起来像是这样:
Your existing main.m file probably looks something like this:
#import <UIKit/UIKit.h> |
|
int main(int argc, char *argv[]) { |
|
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init]; |
int retVal = UIApplicationMain(argc, argv, nil, nil); |
[pool release]; |
return retVal; |
} |
把它改成这样:
Change it to look like this:
#import <UIKit/UIKit.h> |
#import "AppDelegate.h" |
|
int main(int argc, char *argv[]) { |
|
@autoreleasepool { |
return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class])); |
} |
} |
(将 “AppDelegate” 替换为你的应用代理类的名字).
注意: @autoreleasepool 是一个新的 Objective-C 语句用于管理自动释放池;它可用于所有 Objective-C 模式,并且比使用 NSAutoReleasePool 类更高效(参看 迁移到 ARC 的发布说明(Transitioning to ARC Release Notes))。
Note: @autoreleasepool is a new Objective-C statement for managing autorelease pools; it is available in all Objective-C modes, and is more efficient than using the NSAutoReleasePool class (see Transitioning to ARC Release Notes).
添加 Storyboard 到工程中
Add a Storyboard to the Project
添加一个新的 storyboard 到工程中。按惯例,初始 storyboard 命名为 MainStoryboard 。
Add a new storyboard file to the project. By convention, the initial storyboard is named MainStoryboard.
从对象库中添加第一个视图控制器到 storyboard。你应该会看一个无源的 segue,它指示这是第一个场景。
Add your first view controller to the storyboard from the Object library. You should see a sourceless segue indicating that this is the first scene.
如果第一个视图控制器嵌入在诸如导航控制器或分页控制器这样的容器中,那么使用 Editor > Embed In 来正确地嵌入它。无源 segue 现在应该指向容器视图控制器了。
If the first view controller is embedded in a container such as a navigation controller or tab bar controller, then use Editor > Embed In to embed it appropriately. The sourceless segue should now point to the container view controller:
为项目设置主 Storyboard
Set the Main Storyboard for the Project
In the Summary for application Target, set the value of the Main Storyboard to the name of the storyboard file you created. If there is a value for Main Interface (to specify the first nib file), make sure you remove it.
访问第一个视图控制器
Accessing the First View Controller
The application delegate is not represented in the storyboard. If you need to access the first view controller (for example, if you are creating a Core Data application and want to pass the delegate’s managed object context to the first view controller), you can do so via the window’s rootViewController. If the root view controller is a container controller—such as an instance of UINavigationController—then you can access your view controller using the appropriate accessor for the container’s contents, for example:
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { |
|
UINavigationController *rootNavigationController = (UINavigationController *)self.window.rootViewController; |
MyViewController *myViewController = (MyViewController *)[rootNavigationController topViewController]; |
// Configure myViewController. |
return YES; |
} |
配置表视图
Configuring Table Views
There are several new ways of working with table views when you use storyboards.
- The dequeueReusableCellWithIdentifier: method is guaranteed to return a cell (provided that you have defined a cell with the given identifier). Thus there is no need to use the “check the return value of the method” pattern as was the case in the previous typical implementation of tableView:cellForRowAtIndexPath:. Instead of:
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier]; |
if (cell == nil) { |
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier]; |
} |
// Configure and return the cell. |
you would now write just:
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier]; |
// Configure and return the cell. |
You can configure table view cells directly in the table view. By default, the prototype cell style is set to Custom, so that you can design your own cell. You can also set the style to one of the built-in UITableViewCell cell styles by using the Attributes Inspector. For a table view that is the view of a UITableViewController instance, you can configure static content directly in the storyboard. In the Attributes Inspector, set the content of the table view to Static Cells.
If you use static cells, you can connect outlets from the table view controller to individual cells so that you can configure the cell’s content at runtime.
// Declare properties for the outlets. |
@property (nonatomic, weak) IBOutlet UITableViewCell *firstGroupFirstRowCell; |
// Configure cells directly. |
firstGroupFirstRowCell.detailTextLabel.text = newTextValue; |
Copyright © 2014 Apple Inc. All rights reserved. Terms of Use | Privacy Policy | Updated: 2011-10-12