「なぜこの代替が必要なのですか?」 これは、SplitViewの動作に関するものです。SDKからの抜粋です。「両方のView Controllerは横向きで表示されますが、Detail View Controllerのみが縦向きで表示されます」。 つまり 縦向きでは、右側(MasterView)は単純に非表示になります(図1を参照)。
data:image/s3,"s3://crabby-images/7b938/7b938bbf41cf518f1144fa3b8413cef5de5980f7" alt=""
data:image/s3,"s3://crabby-images/999e6/999e6dbf1800f7dd843c22ba7fd4f634a5a7d49b" alt=""
図1-横(a)および縦(b)方向のSplitView
iPadのメイン設定を見ると、まったく異なる画像が表示されます。縦向きと横向きでは、左側の部分(MasterView)が同じように表示されます(非表示になりません)
data:image/s3,"s3://crabby-images/838b2/838b274858fd41a5f1020ce4adce52d96f45fabf" alt=""
図2-基本的なiPad設定
さて、
Xcode(ビューベースのアプリケーション)で新しいプロジェクトを作成することから始めましょう。 AlternativeSplitという名前を付けました(図3を参照)。
data:image/s3,"s3://crabby-images/240f9/240f9afa8be952a55954f9c9d9d2585f9dd6916e" alt=""
図3-新しいプロジェクトの作成
次に、メニューからFile-> New file ...-> Cocoa Touch Class-> UIViewControllerサブクラスを選択して、MasterViewController(UITableViewControllerのサブクラス)とDetailViewController(UIViewControllerのサブクラス)の2つの新しいクラスをプロジェクトに追加します。
InterfaceBuilderでAlternativeSplitViewController.xibを開き、「このような絵を描く」:
data:image/s3,"s3://crabby-images/64785/64785598cac5a785996ea117e4f772f337b69191" alt=""
図4-AlternativeSplitViewController.xibの編集
ある方向から別の方向に切り替えるときにビューが「フロート」しないように、自動サイズ設定を構成します。 マスターの左側(NavigationBarとTableView)には、図5.aと同じパラメーターを指定し、右側の詳細(NavigationBarとView)には、図5 5.b
data:image/s3,"s3://crabby-images/3fe77/3fe7756bf317399c01b84e2bbc83ba29b4481961" alt=""
data:image/s3,"s3://crabby-images/e3089/e3089d4ef585321a29939f27a3d95dfdfc6286fe" alt=""
図5-自動サイズ設定オプション
ファイルを編集して、AlternativeSplitViewControlle.hクラスに新しいIBOutlet変数を追加します
次のAlternativeSplitViewController.h
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
// // AlternativeSplitViewController.h // AlternativeSplit // #import <UIKit/UIKit.h> @ class MasterViewController; @ interface AlternativeSplitViewController : UIViewController { IBOutlet MasterViewController* masterViewController; } @end * This source code was highlighted with Source Code Highlighter .
MasterViewControllerクラスは、メニュー項目を含むテーブルを担当します。 次のように書き直します(要するに、以下のコードではテーブルにデータを入力し、ユーザーがテーブルセル(didSelectRowAtIndexPath)を選択するとDetailViewメッセージを送信します):
*このソースコードは、 ソースコードハイライターで強調表示されました。
- //
- // MasterViewController.h
- // AlternativeSplit
- //
- #import <UIKit / UIKit.h>
- @ class DetailViewController;
- @ インターフェイス MasterViewController:UITableViewController {
- IBOutlet DetailViewController * detailViewController;
- }
- @end
*このソースコードは、 ソースコードハイライターで強調表示されました。
- //
- // MasterViewController.m
- // AlternativeSplit
- //
- #import "MasterViewController.h"
- #import "DetailViewController.h"
- @implementation MasterViewController
- #プラグママーク-
- #pragma markライフサイクルを表示
- -(BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
- //オーバーライドして、デフォルトの縦向き以外の向きを許可します。
- YESを返します。
- }
- #プラグママーク-
- #pragma markテーブルビューデータソース
- -(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
- //セクションの数を返します。
- 1を返します。
- }
- -(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)セクション{
- //セクション内の行数を返します。
- return 5;
- }
- //テーブルビューセルの外観をカスタマイズします。
- -(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
- static NSString * CellIdentifier = @ "Cell" ;
- UITableViewCell * cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
- if (cell == nil){
- cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reloadIdentifier:CellIdentifier] autorelease];
- }
- //セルを構成します...
- cell.textLabel.text = [NSString stringWithFormat: @ "Row%i" 、indexPath.row];
- 戻りセル。
- }
- #プラグママーク-
- #pragma markテーブルビューデリゲート
- -( void )tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
- [detailViewController setNewText:[NSString stringWithFormat: @ "Row%i" 、indexPath.row]];
- }
- #プラグママーク-
- #pragma markメモリ管理
- -( void )didReceiveMemoryWarning {
- //ビューにスーパービューがない場合、ビューを解放します。
- [super didReceiveMemoryWarning];
- //使用されていないキャッシュデータ、画像などの所有権を放棄します。
- }
- -( void )dealloc {
- [super dealloc];
- }
- @end
DetailViewControllerが適切な部分を担当します。 DetailViewControllerクラスを編集しましょう(新しいIBOutlet変数UILabel * lblと、lblのテキストを変更する新しいsetNewTextメソッドを追加します)
*このソースコードは、 ソースコードハイライターで強調表示されました。
- //
- // DetailViewController.h
- // AlternativeSplit
- //
- #import <UIKit / UIKit.h>
- @ インターフェース DetailViewController:UIViewController {
- IBOutlet UILabel * lbl;
- }
- -( void )setNewText:(NSString *)テキスト;
- @end
*このソースコードは、<a href="http://virtser.net/blog/post/source-code-highlighter.aspx"> ソースコードハイライターで強調表示されました 。
- //
- // DetailViewController.m
- // AlternativeSplit
- //
- #import "DetailViewController.h"
- @implementation DetailViewController
- -( void )setNewText:(NSString *)テキスト{
- lbl.text = text;
- }
- -(BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
- //任意の方向を許可するためにオーバーライドされます。
- YESを返します。
- }
- -( void )didReceiveMemoryWarning {
- //ビューにスーパービューがない場合、ビューを解放します。
- [super didReceiveMemoryWarning];
- //使用されていないキャッシュデータ、画像などを解放します。
- }
- -( void )viewDidUnload {
- [super viewDidUnload];
- //メインビューの保持されているサブビューを解放します。
- //例:self.myOutlet = nil;
- }
- -( void )dealloc {
- [super dealloc];
- }
- @end
あとは、interfaceBuildereでIBOutlet変数をバインドするだけです(図6を参照)。 そして、問題は帽子です。
data:image/s3,"s3://crabby-images/e3cc3/e3cc32493e55299cadd920cd9a9b52e657062caa" alt=""
図6-IBOutlet変数のバインド
結果:
data:image/s3,"s3://crabby-images/6b0a3/6b0a339a9f97c0ca48d0e5d838389d8097aeb3f1" alt=""
data:image/s3,"s3://crabby-images/c7abf/c7abf31e610de92983238bb18cdc4e0a2c940787" alt=""
図7-別のSplitView
ソースコードはこちらまたはこちらからダウンロードできます 。
ご清聴ありがとうございました。
PSこの記事には、「手を少し動かすと、UITabBar