Thứ Sáu, 30 tháng 7, 2010

Touch Tutorial - Part One (touchesEnded Event)

Welcome to the first part of Multi Touch tutorial series. In this tutorial I will show you how you can respond to a tap event.
First tutorial in this series, I will show how to zoom and image in and out. This is how the application will look like.

To get started, we have to
  1. Create a new project by selecting "Windows-based Application"
  2. Create a new UIView using IB and name it ImgView.
  3. Create a new file in XCode by selecting File -> New File -> UIViewController sub class and name it "ImgViewController".
  4. In IB, select File's owner object of the "ImgView" nib file and select Tools -> Identity Inspector. Under Class Identity select "ImgViewContoller" as the class.
  5. Select Tools - > Connections Inspector and create a connection from the view property to the view object in IB.
  6. Place a UIImageView on the view we just created.
  7. Add a image to the resource folder, to be used by the UIImageView.
  8. Select the Image and select Tools -> Attributes Inspector in IB. From the Image drop down select your image.
  9. Set the Mode to Center.
  10. Un-check "User Interaction Enabled" and "Multiple Touch".
  11. Select the view and select "Multiple Touch" in the Attributes Inspector. Note that "User Interaction Enabled" should already be checked, if not check it.
Using the last two settings all the touches events will be sent to ImgViewController. Since we need to control the image, we need a variable of type UIImageView. This is how the header file of "MultiTouchTutorialAppDelegate" will look like.

#import >

@class ImgViewController;

@interface MultiTouchTutorialAppDelegate : NSObject {
UIWindow *window;
ImgViewController *ivController;
}

@property (nonatomic, retain) IBOutlet UIWindow *window;

@end


Using IB, select File's owner object and open Tools -> Connections Inspector. Create a connection from the imgView to the UIImageView placed on the view. Now we will be able to control the UIImageView from code.

Now we need to add the view "ImgView" as a subview in applicationDidFinishLaunching method. This is how the source code will look like

- (void)applicationDidFinishLaunching:(UIApplication *)application {

ivController = [[ImgViewController alloc] initWithNibName:@"ImgView" bundle:[NSBundle mainBundle]];

[window addSubview:[ivController view]];

// Override point for customization after application launch
[window makeKeyAndVisible];
}


Click on Ctrl+return to run the application in simulator. You should see the image loaded in the simulator.

Right now the application does not respond to any events, but all we have to do is implement some methods. Let's implement the touchesEnded method which will be called when touches are ended.

- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {
}


In this method we will respond to a single tap and double tap. On single tap we will zoom out the image and on double tap we will set the mode to "Center", which is doing the same as in step 9.

This is how the code looks like

- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {

//Get all the touches.
NSSet *allTouches = [event allTouches];

//Number of touches on the screen
switch ([allTouches count])
{
case 1:
{
//Get the first touch.
UITouch *touch = [[allTouches allObjects] objectAtIndex:0];

switch([touch tapCount])
{
case 1://Single tap
imgView.contentMode = UIViewContentModeScaleAspectFit;
break;
case 2://Double tap.
imgView.contentMode = UIViewContentModeCenter;
break;
}
}
break;
}

}


We get all the touches from the event into allTouches variable. We thenfind out how many fingers were touching the screen, since in our case we only want to zoom in and out, it seems normal to assume that the user will only be using one finger. We then find out how many tocuhs are touching the screen by calling the count method of allTouches variable. If there is only one finger touching the screen, we get the Touch object at index zero and find out the tap count of that object. If the tap count is one we will zoom out the image and if it is two we are going to zoom in. We zoom out the image by setting the contentMode to UIViewContentModeScaleAspectFit and zoom in the image by setting it to UIViewContentModeCenter.

In this tutorial we learnt how to respond to touchesEnded event and in the ftuture tutorials we will learn ho wto respond to touches began, touches moved and touches cancelled.

You can download the source code for this tutorial here. Please leave me your comments and let me know your thoughts.

Không có nhận xét nào:

Đăng nhận xét