Classes/TeslameterViewController.m
/* |
File: TeslameterViewController.m |
Abstract: A view controller that manages the primary view within the application. It creates a CLLocationManager and turns on heading updates. As updates are received, it displays them in a graph, x, y, and z labels, and also computes the magnitude (size or strength) of the magnetic vector. The units for all values are microteslas. |
Version: 1.2 |
Disclaimer: IMPORTANT: This Apple software is supplied to you by Apple |
Inc. ("Apple") in consideration of your agreement to the following |
terms, and your use, installation, modification or redistribution of |
this Apple software constitutes acceptance of these terms. If you do |
not agree with these terms, please do not use, install, modify or |
redistribute this Apple software. |
In consideration of your agreement to abide by the following terms, and |
subject to these terms, Apple grants you a personal, non-exclusive |
license, under Apple's copyrights in this original Apple software (the |
"Apple Software"), to use, reproduce, modify and redistribute the Apple |
Software, with or without modifications, in source and/or binary forms; |
provided that if you redistribute the Apple Software in its entirety and |
without modifications, you must retain this notice and the following |
text and disclaimers in all such redistributions of the Apple Software. |
Neither the name, trademarks, service marks or logos of Apple Inc. may |
be used to endorse or promote products derived from the Apple Software |
without specific prior written permission from Apple. Except as |
expressly stated in this notice, no other rights or licenses, express or |
implied, are granted by Apple herein, including but not limited to any |
patent rights that may be infringed by your derivative works or by other |
works in which the Apple Software may be incorporated. |
The Apple Software is provided by Apple on an "AS IS" basis. APPLE |
MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION |
THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS |
FOR A PARTICULAR PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND |
OPERATION ALONE OR IN COMBINATION WITH YOUR PRODUCTS. |
IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL |
OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, |
MODIFICATION AND/OR DISTRIBUTION OF THE APPLE SOFTWARE, HOWEVER CAUSED |
AND WHETHER UNDER THEORY OF CONTRACT, TORT (INCLUDING NEGLIGENCE), |
STRICT LIABILITY OR OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE |
POSSIBILITY OF SUCH DAMAGE. |
Copyright (C) 2010 Apple Inc. All Rights Reserved. |
*/ |
#import "TeslameterViewController.h" |
#import "GraphView.h" |
@implementation TeslameterViewController |
@synthesize magnitudeLabel; |
@synthesize xLabel; |
@synthesize yLabel; |
@synthesize zLabel; |
@synthesize graphView; |
@synthesize locationManager; |
- (void)viewDidLoad { |
[super viewDidLoad]; |
// setup the location manager |
self.locationManager = [[[CLLocationManager alloc] init] autorelease]; |
// check if the hardware has a compass |
if ([CLLocationManager headingAvailable] == NO) { |
// No compass is available. This application cannot function without a compass, |
// so a dialog will be displayed and no magnetic data will be measured. |
self.locationManager = nil; |
UIAlertView *noCompassAlert = [[UIAlertView alloc] initWithTitle:@"No Compass!" message:@"This device does not have the ability to measure magnetic fields." delegate:nil cancelButtonTitle:@"OK" otherButtonTitles:nil]; |
[noCompassAlert show]; |
[noCompassAlert release]; |
} else { |
// heading service configuration |
locationManager.headingFilter = kCLHeadingFilterNone; |
// setup delegate callbacks |
locationManager.delegate = self; |
// start the compass |
[locationManager startUpdatingHeading]; |
} |
} |
- (void)viewDidUnload { |
self.magnitudeLabel = nil; |
self.xLabel = nil; |
self.yLabel = nil; |
self.zLabel = nil; |
self.graphView = nil; |
} |
- (void)dealloc { |
[magnitudeLabel release]; |
[xLabel release]; |
[yLabel release]; |
[zLabel release]; |
[graphView release]; |
// Stop the compass |
[locationManager stopUpdatingHeading]; |
[locationManager release]; |
[super dealloc]; |
} |
// This delegate method is invoked when the location manager has heading data. |
- (void)locationManager:(CLLocationManager *)manager didUpdateHeading:(CLHeading *)heading { |
// Update the labels with the raw x, y, and z values. |
[xLabel setText:[NSString stringWithFormat:@"%.1f", heading.x]]; |
[yLabel setText:[NSString stringWithFormat:@"%.1f", heading.y]]; |
[zLabel setText:[NSString stringWithFormat:@"%.1f", heading.z]]; |
// Compute and display the magnitude (size or strength) of the vector. |
// magnitude = sqrt(x^2 + y^2 + z^2) |
CGFloat magnitude = sqrt(heading.x*heading.x + heading.y*heading.y + heading.z*heading.z); |
[magnitudeLabel setText:[NSString stringWithFormat:@"%.1f", magnitude]]; |
// Update the graph with the new magnetic reading. |
[graphView updateHistoryWithX:heading.x y:heading.y z:heading.z]; |
} |
// This delegate method is invoked when the location managed encounters an error condition. |
- (void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error { |
if ([error code] == kCLErrorDenied) { |
// This error indicates that the user has denied the application's request to use location services. |
[manager stopUpdatingHeading]; |
} else if ([error code] == kCLErrorHeadingFailure) { |
// This error indicates that the heading could not be determined, most likely because of strong magnetic interference. |
} |
} |
@end |
© 2010 Apple Inc. All Rights Reserved. (Last updated: 2010-06-28)