Swipes(4)~マルチプルスワイプ(Gesture Recognizer)

2012. 03. 02
iOS 4.x版のサンプルコードでは、Gesture Recognizerを使った『Swipes(2)~Gesture Recognizer』をマルチプルスワイプへ改造します。


●SwipesViewController.mソースファイルの編集

マルチプルスワイプに対応するため、viewDidLoadメソッドとラベルを更新するreportHorizontalSwipeとreportVerticalSwipeメソッドの改修、そしてタッチポイント数に応じてテキストを生成するdescriptionForTouchCount:メソッドの追加を行います。
(太字が追加修正した部分)

#import "SwipesViewController.h"

@implementation SwipesViewController

@synthesize label;
@synthesize gestureStartPoint;

- (void)eraseText {
    label.text = @"";
}

// Implement viewDidLoad to do additional setup after loading the view, typically from a nib.

- (void)viewDidLoad {
    [super viewDidLoad];

    for (NSUInteger touchCount = 1; touchCount <= 5; touchCount++) {
        UISwipeGestureRecognizer *vertical = [[[UISwipeGestureRecognizer alloc]
            initWithTarget:self action:@selector(reportVerticalSwipe:)] autorelease];
        vertical.direction = UISwipeGestureRecognizerDirectionUp |
            UISwipeGestureRecognizerDirectionDown;
        vertical.numberOfTouchesRequired = touchCount;
        [self.view addGestureRecognizer:vertical];

        UISwipeGestureRecognizer *horizontal = [[[UISwipeGestureRecognizer alloc]
            initWithTarget:self action:@selector(reportHorizontalSwipe:)] autorelease];
        horizontal.direction = UISwipeGestureRecognizerDirectionLeft |
            UISwipeGestureRecognizerDirectionRight;
        horizontal.numberOfTouchesRequired = touchCount;
        [self.view addGestureRecognizer:horizontal];
    }
}

// Override to allow orientations other than the default portrait orientation.
- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
    // Return YES for supported orientations
    return (interfaceOrientation == UIInterfaceOrientationPortrait);
}

- (void)didReceiveMemoryWarning {
    // Releases the view if it doesn't have a superview.
    [super didReceiveMemoryWarning];

    // Release any cached data, images, etc that aren't in use.
}

- (void)viewDidUnload {
    // Release any retained subviews of the main view.
    // e.g. self.myOutlet = nil;

    self.label = nil;
    [super viewDidUnload];
}

- (void)dealloc {
    [label release];
    [super dealloc];
}

- (NSString *)descriptionForTouchCount:(NSUInteger)touchCount {
    if (touchCount == 2)
        return @"Double ";
    else if (touchCount == 3)
        return @"Triple ";
    else if (touchCount == 4)
        return @"Quadruple ";
    else if (touchCount == 5)
        return @"Quintuple ";
    else
        return @"";
}


#pragma mark -

- (void)reportHorizontalSwipe:(UIGestureRecognizer *)recognizer {
    label.text = [NSString stringWithFormat:@"%@Horizontal swipe detected",
        [self descriptionForTouchCount:[recognizer numberOfTouches]]];

    [self performSelector:@selector(eraseText) withObject:nil afterDelay:2];
}

- (void)reportVerticalSwipe:(UIGestureRecognizer *)recognizer {
    label.text = [NSString stringWithFormat:@"%@Vertical swipe detected",
        [self descriptionForTouchCount:[recognizer numberOfTouches]]];

    [self performSelector:@selector(eraseText) withObject:nil afterDelay:2];
}

@end

7844


1)viewDidLoadメソッド

スワイプGesture Recognizerでは、タッチ数をスワイプジェスチャを認識する条件として設定することができます。

そのため、viewDidLoadメソッド内のGesture Recognizerの初期化コード全体を、対応させるタッチ数分(ここでは1から5)設定する必要があります。

タッチ数touchCountの1から5までのforループでGesture Recognizerの初期化コードを包み、水平/垂直スワイプそれぞれにnumberOfTouchesRequiredプロパティで認識させるタッチ数の設定を追加します。

iOS 4.x版のサンプルコードでは、何故かverticalの宣言だけをforループ外で行っていたり、horizontalの宣言と初期化を別の行に分けていたりしていますが、特に意味は無いので、ここでは元のコードをそのまま使っています。

numberOfTouchesRequired

@property(nonatomic) NSUInteger numberOfTouchesRequired

スワイプジェスチャを認識するために必要なタッチ数です。

デフォルト値は1です。


2)descriptionForTouchCount:メソッド

descriptionForTouchCount:メソッドは、タッチ数touchCountに応じてラベルに追加するタッチ数の文字列を設定しています。


3)reportHorizontalSwipe:メソッド

reportHorizontalSwipe:メソッドは水平スワイプが認識された時に呼び出されるメソッドで、マルチプルスワイプに対応するためラベルに表示するテキストにタッチ数を示す文字列の追加を行っています。

タッチ数を示す文字列はdesctiptionForTouchCount:メソッドの呼び出しで設定しており、引数として渡すタッチ数はnumberOfTouchesメソッドで取得しています。

numberOfTouches

- (NSUInteger)numberOfTouches

レシーバによって表されるジェスチャに関するタッチ数を返します。

戻り値は、レシーバによってプライベートな配列内に保持される、UITouchオブジェクト数です。

これらの各オブジェクトは、現在のジェスチャのタッチを表しています。

ループ内でこのメソッドによって返される値を使用して、locationOfTouch:inView:メソッドを使用して個々のタッチ位置を尋ねることができます。


4)reportVerticalSwipe:メソッド

reportVerticalSwipe:メソッドは垂直スワイプが認識された時に呼び出されるメソッドで、reportHorizontalSwipe:メソッドと同様に、マルチプルスワイプに対応するためラベルに表示するテキストにタッチ数を示す文字列の追加を行っています。


●問題点

Swipes(3)~マルチプルスワイプ(イベント処理メソッド)』で示したイベント処理メソッドでの問題点の内、(内部でどのような処理がされているのかは分かりませんが)複数のタッチポイントが近接している際にスワイプの認識距離が伸びる問題は無いようです。

ただ(ピンチ用のGesture Recognizerを実装していないため)ピンチイン/アウトなどをスワイプと判定される問題は残っています。

精密に認識させようとする場合は『iOSイベント処理ガイド』の『ほかのGesture Recognizerとのやり取り(p.41)』などを参考に工夫する必要があるようです。



参考文献

iOSイベント処理ガイド

UISwipeGestureRecognizer Class Reference

UIGestureRecognizer Class Reference

はじめてのiPhone3プログラミングはじめてのiPhone3プログラミング
(2009/12/17)
Dave Mark、Jeff LaMarche 他

商品詳細を見る

Beginning Ios 6 Development: Exploring the Ios SdkBeginning Ios 6 Development: Exploring the Ios Sdk
(2012/12/26)
David Mark、Jack Nutting 他

商品詳細を見る






Bose QuietComfort 20
0 Comments
Leave a comment
管理者にだけ表示を許可する
Top
0 Trackbacks
Top
Calendar
08 | 2017/09 | 10
Sun Mon Tue Wed Thu Fri Sat
- - - - - 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 30
Recent Articles
iTunes


Swift
Categories
Tips
Profile

水月杏香

Author:水月杏香
永遠の初心者プログラマ。

Wish List
WACOM


ARC
Technical Q&A
情報プロパティリストキー
Start Developing iOS Apps Today
BOSE

Bose QuietComfort 20
Reference
NSApplicationDelegateプロトコル
NSArrayクラス
NSAutoreleasePoolクラス
NSBundleクラス
NSBundle UIKit追加分
NSCalendarクラス
NSCoderクラス
NSCodingプロトコル
NSCopyingプロトコル
NSDataクラス
NSDateクラス
NSDateFormatterクラス
NSDictionaryクラス
NSEntityDescriptionクラス
NSEnumeratorクラス
NSErrorクラス
NSExceptionクラス
NSFetchRequestクラス
NSFileHandleクラス
NSFileManagerクラス
NSIndexPathクラス
NSIndexPath UIKit追加分
NSKeyedArchiverクラス
NSKeyedUnarchiverクラス
NSKeyValueCodingプロトコル
NSLocaleクラス
NSManagedObjectクラス
NSManagedObjectContextクラス
NSManagedObjectModelクラス
NSMutableArrayクラス
NSMutableCopyingプロトコル
NSMutableDictionaryクラス
NSMutableSetクラス
NSNotificationクラス
NSNotificationCenterクラス
NSNullクラス
NSNumberクラス
NSObjectクラス
NSObject UIKit追加分
NSObjectプロトコル
NSPersistentStoreクラス
NSPersistentStoreCoordinatorクラス
NSPredicateクラス
NSPropertyListSerializationクラス
NSRunLoopクラス
NSSetクラス
NSStringクラス
NSString UIKit追加分
NSTimerクラス
NSTimeZoneクラス
NSURLクラス
NSURLProtectionSpaceクラス
NSURLRequestクラス
NSUserDefaultsクラス
NSValueクラス

UIActionSheetクラス
UIActionSheetDelegateプロトコル
UIActivityIndicatorViewクラス
UIAlertViewクラス
UIAlertViewDelegateプロトコル
UIApplicationクラス
UIApplicationDelegateプロトコル
UIBarButtonItemクラス
UIBarItemクラス
UIButtonクラス
UIColorクラス
UIControlクラス
UIDatePickerクラス
UIDeviceクラス
UIEventクラス
UIFontクラス
UIGestureRecognizerクラス
UIImageクラス
UIImageViewクラス
UIKit Function
UILabelクラス
UINavigationControllerクラス
UINavigationItemクラス
UIPickerViewクラス
UIPickerViewDataSourceプロトコル
UIPickerViewDelegateプロトコル
UIPinchGestureRecognizerクラス
UIResponderクラス
UIScreenクラス
UIScrollViewクラス
UISearchBarクラス
UISearchBarDelegateプロトコル
UISegmentedControlクラス
UISliderクラス
UISwipeGestureRecognizerクラス
UISwitchクラス
UITableViewクラス
UITableViewCellクラス
UITableViewControllerクラス
UITableViewDataSourceプロトコル
UITableViewDelegateプロトコル
UITapGestureRecognizerクラス
UITextFieldクラス
UITextFieldDelegateプロトコル
UITextInputTraitsプロトコル
UITextViewクラス
UITextViewDelegateプロトコル
UIToolbarクラス
UITouchクラス
UIViewクラス
UIViewControllerクラス
UIWebViewクラス
UIWebViewDelegateプロトコル
UIWindowクラス

AVAudioPlayerクラス
AVAudioPlayerDelegateプロトコル

CADisplayLinkクラス
CAEAGLLayerクラス
CALayerクラス

CGAffineTransform
CGBitmapContext
CGColor
CGColorSpace
CGContext
CGGeometry
CGImage
CGPath

EAGLContextクラス
EAGLDrawableプロトコル

Foundation Constants
Foundation Data Types
Foundation Functions

MPMediaItemクラス
MPMediaItemArtworkクラス
MPMediaPlaylistクラス
MPMediaPropertyPredicateクラス
MPMediaQueryクラス
MPMusicPlayerControllerクラス

Randomization Services

System Sound Services
Amazon


OpenGL ES
SQLite
Monthly Archives
Recent Comments
Recent TrackBacks
RSS Link
Visitors
QR Code
QR